attr_reader :possible_points, :actual_points, :tracksegs
- def initialize(file)
+ def initialize(file, options = {})
@file = file
+ @maximum_points = options[:maximum_points] || Float::INFINITY
end
def parse_file(reader)
if reader.name == "trkpt"
point = TrkPt.new(@tracksegs, reader["lat"].to_f, reader["lon"].to_f)
@possible_points += 1
+ raise FileTooBigError if @possible_points > @maximum_points
elsif reader.name == "ele" && point
point.altitude = reader.read_string.to_f
elsif reader.name == "time" && point
- point.timestamp = Time.parse(reader.read_string)
+ point.timestamp = Time.parse(reader.read_string).utc
end
when XML::Reader::TYPE_END_ELEMENT
if reader.name == "trkpt" && point && point.valid?
output = StringIO.new
image.export(output)
- output.read
+ output
end
def icon(min_lat, min_lon, max_lat, max_lon)
end
end
- image.gif
+ StringIO.new(image.gif)
end
end
longitude >= -180 && longitude <= 180
end
end
+
+ class FileTooBigError < RuntimeError
+ def initialise
+ super("GPX File contains too many points")
+ end
+ end
end