From e2cbcdb4dc32db05e2c6d7a7bb57952e1da6dab3 Mon Sep 17 00:00:00 2001 From: Teddy Wing Date: Fri, 23 Mar 2018 17:01:16 +0100 Subject: TomTom::Matrix#points_from_way_costs: Include stop IDs with points We need to persist stop IDs in order to properly construct `WayCost` objects from the costs returned from the TomTom matrix API. In order to persist stop IDs, my idea here is to group together a point and its corresponding ID into a bucket. When we later `#extract_costs_to_way_costs!`, we'll be able to grab the correct ID for a given coordinate to create a `WayCost` from it. Here, we create a new `TomTom::Matrix::Point` class that encapsulates a coordinate and an ID, and build a `Set` of those. I needed an `#eql?` and `#hash` method on `Point` as described in the `Set` documentation (https://ruby-doc.org/stdlib-1.9.3/libdoc/set/rdoc/Set.html) in order to properly maintain a unique set. Refs #6222 --- lib/tom_tom/matrix.rb | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) (limited to 'lib/tom_tom/matrix.rb') diff --git a/lib/tom_tom/matrix.rb b/lib/tom_tom/matrix.rb index 985055dae..4ef620f99 100644 --- a/lib/tom_tom/matrix.rb +++ b/lib/tom_tom/matrix.rb @@ -32,8 +32,20 @@ module TomTom points = Set.new way_costs.each do |way_cost| - points.add(way_cost.departure) - points.add(way_cost.arrival) + ids = way_cost.id.split('-') + + points.add( + TomTom::Matrix::Point.new( + way_cost.departure, + ids[0] + ) + ) + points.add( + TomTom::Matrix::Point.new( + way_cost.arrival, + ids[1] + ) + ) end points -- cgit v1.2.3