tests + instructions for map matching
This commit is contained in:
parent
5ac024788e
commit
de29574314
@ -52,15 +52,8 @@ template <class DataFacadeT> class JSONDescriptor final : public BaseDescriptor<
|
|||||||
DescriptorConfig config;
|
DescriptorConfig config;
|
||||||
DescriptionFactory description_factory, alternate_description_factory;
|
DescriptionFactory description_factory, alternate_description_factory;
|
||||||
FixedPointCoordinate current;
|
FixedPointCoordinate current;
|
||||||
unsigned entered_restricted_area_count;
|
|
||||||
struct RoundAbout
|
|
||||||
{
|
|
||||||
RoundAbout() : start_index(INT_MAX), name_id(INVALID_NAMEID), leave_at_exit(INT_MAX) {}
|
|
||||||
int start_index;
|
|
||||||
unsigned name_id;
|
|
||||||
int leave_at_exit;
|
|
||||||
} round_about;
|
|
||||||
|
|
||||||
|
public:
|
||||||
struct Segment
|
struct Segment
|
||||||
{
|
{
|
||||||
Segment() : name_id(INVALID_NAMEID), length(-1), position(0) {}
|
Segment() : name_id(INVALID_NAMEID), length(-1), position(0) {}
|
||||||
@ -69,11 +62,12 @@ template <class DataFacadeT> class JSONDescriptor final : public BaseDescriptor<
|
|||||||
int length;
|
int length;
|
||||||
unsigned position;
|
unsigned position;
|
||||||
};
|
};
|
||||||
|
private:
|
||||||
std::vector<Segment> shortest_path_segments, alternative_path_segments;
|
std::vector<Segment> shortest_path_segments, alternative_path_segments;
|
||||||
ExtractRouteNames<DataFacadeT, Segment> GenerateRouteNames;
|
ExtractRouteNames<DataFacadeT, Segment> GenerateRouteNames;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit JSONDescriptor(DataFacadeT *facade) : facade(facade), entered_restricted_area_count(0)
|
explicit JSONDescriptor(DataFacadeT *facade) : facade(facade)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -143,9 +137,7 @@ template <class DataFacadeT> class JSONDescriptor final : public BaseDescriptor<
|
|||||||
}
|
}
|
||||||
if (config.instructions)
|
if (config.instructions)
|
||||||
{
|
{
|
||||||
osrm::json::Array json_route_instructions;
|
osrm::json::Array json_route_instructions = BuildTextualDescription(description_factory, shortest_path_segments);
|
||||||
BuildTextualDescription(description_factory, json_route_instructions,
|
|
||||||
raw_route.shortest_path_length, shortest_path_segments);
|
|
||||||
json_result.values["route_instructions"] = json_route_instructions;
|
json_result.values["route_instructions"] = json_route_instructions;
|
||||||
}
|
}
|
||||||
description_factory.BuildRouteSummary(description_factory.get_entire_length(),
|
description_factory.BuildRouteSummary(description_factory.get_entire_length(),
|
||||||
@ -222,9 +214,7 @@ template <class DataFacadeT> class JSONDescriptor final : public BaseDescriptor<
|
|||||||
osrm::json::Array json_current_alt_instructions;
|
osrm::json::Array json_current_alt_instructions;
|
||||||
if (config.instructions)
|
if (config.instructions)
|
||||||
{
|
{
|
||||||
BuildTextualDescription(
|
json_alt_instructions = BuildTextualDescription(alternate_description_factory, alternative_path_segments);
|
||||||
alternate_description_factory, json_current_alt_instructions,
|
|
||||||
raw_route.alternative_path_length, alternative_path_segments);
|
|
||||||
json_alt_instructions.values.push_back(json_current_alt_instructions);
|
json_alt_instructions.values.push_back(json_current_alt_instructions);
|
||||||
json_result.values["alternative_instructions"] = json_alt_instructions;
|
json_result.values["alternative_instructions"] = json_alt_instructions;
|
||||||
}
|
}
|
||||||
@ -276,6 +266,11 @@ template <class DataFacadeT> class JSONDescriptor final : public BaseDescriptor<
|
|||||||
json_result.values["alternative_names"] = json_alternate_names_array;
|
json_result.values["alternative_names"] = json_alternate_names_array;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
json_result.values["hint_data"] = BuildHintData(raw_route);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline osrm::json::Object BuildHintData(const InternalRouteResult& raw_route) const
|
||||||
|
{
|
||||||
osrm::json::Object json_hint_object;
|
osrm::json::Object json_hint_object;
|
||||||
json_hint_object.values["checksum"] = facade->GetCheckSum();
|
json_hint_object.values["checksum"] = facade->GetCheckSum();
|
||||||
osrm::json::Array json_location_hint_array;
|
osrm::json::Array json_location_hint_array;
|
||||||
@ -290,24 +285,27 @@ template <class DataFacadeT> class JSONDescriptor final : public BaseDescriptor<
|
|||||||
hint);
|
hint);
|
||||||
json_location_hint_array.values.push_back(hint);
|
json_location_hint_array.values.push_back(hint);
|
||||||
json_hint_object.values["locations"] = json_location_hint_array;
|
json_hint_object.values["locations"] = json_location_hint_array;
|
||||||
json_result.values["hint_data"] = json_hint_object;
|
|
||||||
|
|
||||||
// render the content to the output array
|
return json_hint_object;
|
||||||
// TIMER_START(route_render);
|
|
||||||
// osrm::json::render(reply.content, json_result);
|
|
||||||
// TIMER_STOP(route_render);
|
|
||||||
// SimpleLogger().Write(logDEBUG) << "rendering took: " << TIMER_MSEC(route_render);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: reorder parameters
|
inline osrm::json::Array BuildTextualDescription(const DescriptionFactory &description_factory,
|
||||||
inline void BuildTextualDescription(DescriptionFactory &description_factory,
|
std::vector<Segment> &route_segments_list) const
|
||||||
osrm::json::Array &json_instruction_array,
|
|
||||||
const int route_length,
|
|
||||||
std::vector<Segment> &route_segments_list)
|
|
||||||
{
|
{
|
||||||
|
osrm::json::Array json_instruction_array;
|
||||||
|
|
||||||
// Segment information has following format:
|
// Segment information has following format:
|
||||||
//["instruction id","streetname",length,position,time,"length","earth_direction",azimuth]
|
//["instruction id","streetname",length,position,time,"length","earth_direction",azimuth]
|
||||||
unsigned necessary_segments_running_index = 0;
|
unsigned necessary_segments_running_index = 0;
|
||||||
|
|
||||||
|
struct RoundAbout
|
||||||
|
{
|
||||||
|
RoundAbout() : start_index(INT_MAX), name_id(INVALID_NAMEID), leave_at_exit(INT_MAX) {}
|
||||||
|
int start_index;
|
||||||
|
unsigned name_id;
|
||||||
|
int leave_at_exit;
|
||||||
|
} round_about;
|
||||||
|
|
||||||
round_about.leave_at_exit = 0;
|
round_about.leave_at_exit = 0;
|
||||||
round_about.name_id = 0;
|
round_about.name_id = 0;
|
||||||
std::string temp_dist, temp_length, temp_duration, temp_bearing, temp_instruction;
|
std::string temp_dist, temp_length, temp_duration, temp_bearing, temp_instruction;
|
||||||
@ -317,7 +315,6 @@ template <class DataFacadeT> class JSONDescriptor final : public BaseDescriptor<
|
|||||||
{
|
{
|
||||||
osrm::json::Array json_instruction_row;
|
osrm::json::Array json_instruction_row;
|
||||||
TurnInstruction current_instruction = segment.turn_instruction;
|
TurnInstruction current_instruction = segment.turn_instruction;
|
||||||
entered_restricted_area_count += (current_instruction != segment.turn_instruction);
|
|
||||||
if (TurnInstructionsClass::TurnIsNecessary(current_instruction))
|
if (TurnInstructionsClass::TurnIsNecessary(current_instruction))
|
||||||
{
|
{
|
||||||
if (TurnInstruction::EnterRoundAbout == current_instruction)
|
if (TurnInstruction::EnterRoundAbout == current_instruction)
|
||||||
@ -386,6 +383,8 @@ template <class DataFacadeT> class JSONDescriptor final : public BaseDescriptor<
|
|||||||
json_last_instruction_row.values.push_back(bearing::get(0.0));
|
json_last_instruction_row.values.push_back(bearing::get(0.0));
|
||||||
json_last_instruction_row.values.push_back(0.);
|
json_last_instruction_row.values.push_back(0.);
|
||||||
json_instruction_array.values.push_back(json_last_instruction_row);
|
json_instruction_array.values.push_back(json_last_instruction_row);
|
||||||
|
|
||||||
|
return json_instruction_array;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -58,9 +58,6 @@ When /^I match I should get$/ do |table|
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
puts table
|
|
||||||
puts sub_matchings
|
|
||||||
|
|
||||||
ok = true
|
ok = true
|
||||||
encoded_result = ""
|
encoded_result = ""
|
||||||
extended_target = ""
|
extended_target = ""
|
||||||
@ -97,3 +94,170 @@ When /^I match I should get$/ do |table|
|
|||||||
table.diff! actual
|
table.diff! actual
|
||||||
end
|
end
|
||||||
|
|
||||||
|
When /^I match with turns I should get$/ do |table|
|
||||||
|
reprocess
|
||||||
|
actual = []
|
||||||
|
OSRMLoader.load(self,"#{prepared_file}.osrm") do
|
||||||
|
table.hashes.each_with_index do |row,ri|
|
||||||
|
if row['request']
|
||||||
|
got = {'request' => row['request'] }
|
||||||
|
response = request_url row['request']
|
||||||
|
else
|
||||||
|
params = @query_params
|
||||||
|
trace = []
|
||||||
|
timestamps = []
|
||||||
|
if row['from'] and row['to']
|
||||||
|
node = find_node_by_name(row['from'])
|
||||||
|
raise "*** unknown from-node '#{row['from']}" unless node
|
||||||
|
trace << node
|
||||||
|
|
||||||
|
node = find_node_by_name(row['to'])
|
||||||
|
raise "*** unknown to-node '#{row['to']}" unless node
|
||||||
|
trace << node
|
||||||
|
|
||||||
|
got = {'from' => row['from'], 'to' => row['to'] }
|
||||||
|
response = request_matching trace, timestamps, params
|
||||||
|
elsif row['trace']
|
||||||
|
row['trace'].each_char do |n|
|
||||||
|
node = find_node_by_name(n.strip)
|
||||||
|
raise "*** unknown waypoint node '#{n.strip}" unless node
|
||||||
|
trace << node
|
||||||
|
end
|
||||||
|
if row['timestamps']
|
||||||
|
timestamps = row['timestamps'].split(" ").compact.map { |t| t.to_i}
|
||||||
|
end
|
||||||
|
got = {'trace' => row['trace'] }
|
||||||
|
response = request_matching trace, timestamps, params
|
||||||
|
else
|
||||||
|
raise "*** no trace"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
row.each_pair do |k,v|
|
||||||
|
if k =~ /param:(.*)/
|
||||||
|
if v=='(nil)'
|
||||||
|
params[$1]=nil
|
||||||
|
elsif v!=nil
|
||||||
|
params[$1]=v
|
||||||
|
end
|
||||||
|
got[k]=v
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if response.body.empty? == false
|
||||||
|
json = JSON.parse response.body
|
||||||
|
end
|
||||||
|
if response.body.empty? == false
|
||||||
|
if response.code == "200"
|
||||||
|
instructions = way_list json['matchings'][0]['instructions']
|
||||||
|
bearings = bearing_list json['matchings'][0]['instructions']
|
||||||
|
compasses = compass_list json['matchings'][0]['instructions']
|
||||||
|
turns = turn_list json['matchings'][0]['instructions']
|
||||||
|
modes = mode_list json['matchings'][0]['instructions']
|
||||||
|
times = time_list json['matchings'][0]['instructions']
|
||||||
|
distances = distance_list json['matchings'][0]['instructions']
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if table.headers.include? 'status'
|
||||||
|
got['status'] = json['status'].to_s
|
||||||
|
end
|
||||||
|
if table.headers.include? 'message'
|
||||||
|
got['message'] = json['status_message']
|
||||||
|
end
|
||||||
|
if table.headers.include? '#' # comment column
|
||||||
|
got['#'] = row['#'] # copy value so it always match
|
||||||
|
end
|
||||||
|
|
||||||
|
sub_matchings = []
|
||||||
|
if response.code == "200"
|
||||||
|
if table.headers.include? 'matchings'
|
||||||
|
sub_matchings = json['matchings'].compact.map { |sub| sub['matched_points']}
|
||||||
|
|
||||||
|
got['route'] = (instructions || '').strip
|
||||||
|
if table.headers.include?('distance')
|
||||||
|
if row['distance']!=''
|
||||||
|
raise "*** Distance must be specied in meters. (ex: 250m)" unless row['distance'] =~ /\d+m/
|
||||||
|
end
|
||||||
|
got['distance'] = instructions ? "#{json['route_summary']['total_distance'].to_s}m" : ''
|
||||||
|
end
|
||||||
|
if table.headers.include?('time')
|
||||||
|
raise "*** Time must be specied in seconds. (ex: 60s)" unless row['time'] =~ /\d+s/
|
||||||
|
got['time'] = instructions ? "#{json['route_summary']['total_time'].to_s}s" : ''
|
||||||
|
end
|
||||||
|
if table.headers.include?('speed')
|
||||||
|
if row['speed'] != '' && instructions
|
||||||
|
raise "*** Speed must be specied in km/h. (ex: 50 km/h)" unless row['speed'] =~ /\d+ km\/h/
|
||||||
|
time = json['route_summary']['total_time']
|
||||||
|
distance = json['route_summary']['total_distance']
|
||||||
|
speed = time>0 ? (3.6*distance/time).to_i : nil
|
||||||
|
got['speed'] = "#{speed} km/h"
|
||||||
|
else
|
||||||
|
got['speed'] = ''
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if table.headers.include? 'bearing'
|
||||||
|
got['bearing'] = instructions ? bearings : ''
|
||||||
|
end
|
||||||
|
if table.headers.include? 'compass'
|
||||||
|
got['compass'] = instructions ? compasses : ''
|
||||||
|
end
|
||||||
|
if table.headers.include? 'turns'
|
||||||
|
got['turns'] = instructions ? turns : ''
|
||||||
|
end
|
||||||
|
if table.headers.include? 'modes'
|
||||||
|
got['modes'] = instructions ? modes : ''
|
||||||
|
end
|
||||||
|
if table.headers.include? 'times'
|
||||||
|
got['times'] = instructions ? times : ''
|
||||||
|
end
|
||||||
|
if table.headers.include? 'distances'
|
||||||
|
got['distances'] = instructions ? distances : ''
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if table.headers.include? 'start'
|
||||||
|
got['start'] = instructions ? json['route_summary']['start_point'] : nil
|
||||||
|
end
|
||||||
|
if table.headers.include? 'end'
|
||||||
|
got['end'] = instructions ? json['route_summary']['end_point'] : nil
|
||||||
|
end
|
||||||
|
if table.headers.include? 'geometry'
|
||||||
|
got['geometry'] = json['route_geometry']
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
ok = true
|
||||||
|
encoded_result = ""
|
||||||
|
extended_target = ""
|
||||||
|
row['matchings'].split(',').each_with_index do |sub, sub_idx|
|
||||||
|
if sub_idx >= sub_matchings.length
|
||||||
|
ok = false
|
||||||
|
break
|
||||||
|
end
|
||||||
|
sub.length.times do |node_idx|
|
||||||
|
node = find_node_by_name(sub[node_idx])
|
||||||
|
out_node = sub_matchings[sub_idx][node_idx]
|
||||||
|
if FuzzyMatch.match_location out_node, node
|
||||||
|
encoded_result += sub[node_idx]
|
||||||
|
extended_target += sub[node_idx]
|
||||||
|
else
|
||||||
|
encoded_result += "? [#{out_node[0]},#{out_node[1]}]"
|
||||||
|
extended_target += "#{sub[node_idx]} [#{node.lat},#{node.lon}]"
|
||||||
|
ok = false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if ok
|
||||||
|
got['matchings'] = row['matchings']
|
||||||
|
got['timestamps'] = row['timestamps']
|
||||||
|
else
|
||||||
|
got['matchings'] = encoded_result
|
||||||
|
row['matchings'] = extended_target
|
||||||
|
log_fail row,got, { 'matching' => {:query => @query, :response => response} }
|
||||||
|
end
|
||||||
|
|
||||||
|
actual << got
|
||||||
|
end
|
||||||
|
end
|
||||||
|
table.diff! actual
|
||||||
|
end
|
||||||
|
@ -3,7 +3,7 @@ require 'net/http'
|
|||||||
HOST = "http://127.0.0.1:#{OSRM_PORT}"
|
HOST = "http://127.0.0.1:#{OSRM_PORT}"
|
||||||
|
|
||||||
def request_matching trace=[], timestamps=[], options={}
|
def request_matching trace=[], timestamps=[], options={}
|
||||||
defaults = { 'output' => 'json' }
|
defaults = { 'output' => 'json', 'instructions' => 'true' }
|
||||||
locs = trace.compact.map { |w| "loc=#{w.lat},#{w.lon}" }
|
locs = trace.compact.map { |w| "loc=#{w.lat},#{w.lon}" }
|
||||||
ts = timestamps.compact.map { |t| "t=#{t}" }
|
ts = timestamps.compact.map { |t| "t=#{t}" }
|
||||||
if ts.length > 0
|
if ts.length > 0
|
||||||
|
82
features/testbot/matching_turns.feature
Normal file
82
features/testbot/matching_turns.feature
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
@routing @turns @testbot
|
||||||
|
Feature: Turn directions/codes
|
||||||
|
|
||||||
|
Background:
|
||||||
|
Given the profile "testbot"
|
||||||
|
|
||||||
|
Scenario: Turn directions
|
||||||
|
Given the node map
|
||||||
|
| o | p | a | b | c |
|
||||||
|
| n | | | | d |
|
||||||
|
| m | | x | | e |
|
||||||
|
| l | | | | f |
|
||||||
|
| k | j | i | h | g |
|
||||||
|
|
||||||
|
And the ways
|
||||||
|
| nodes |
|
||||||
|
| xa |
|
||||||
|
| xb |
|
||||||
|
| xc |
|
||||||
|
| xd |
|
||||||
|
| xe |
|
||||||
|
| xf |
|
||||||
|
| xg |
|
||||||
|
| xh |
|
||||||
|
| xi |
|
||||||
|
| xj |
|
||||||
|
| xk |
|
||||||
|
| xl |
|
||||||
|
| xm |
|
||||||
|
| xn |
|
||||||
|
| xo |
|
||||||
|
| xp |
|
||||||
|
|
||||||
|
When I match with turns I should get
|
||||||
|
| trace | route | turns | matchings |
|
||||||
|
| im | xi,xm | head,left,destination | im |
|
||||||
|
| io | xi,xo | head,slight_left,destination | io |
|
||||||
|
| ia | xi,xa | head,straight,destination | ia |
|
||||||
|
| ic | xi,xc | head,slight_right,destination | ic |
|
||||||
|
| ie | xi,xe | head,right,destination | ie |
|
||||||
|
|
||||||
|
| ko | xk,xo | head,left,destination | ko |
|
||||||
|
| ka | xk,xa | head,slight_left,destination | ka |
|
||||||
|
| kc | xk,xc | head,straight,destination | kc |
|
||||||
|
| ke | xk,xe | head,slight_right,destination | ke |
|
||||||
|
| kg | xk,xg | head,right,destination | kg |
|
||||||
|
|
||||||
|
| ma | xm,xa | head,left,destination | ma |
|
||||||
|
| mc | xm,xc | head,slight_left,destination | mc |
|
||||||
|
| me | xm,xe | head,straight,destination | me |
|
||||||
|
| mg | xm,xg | head,slight_right,destination | mg |
|
||||||
|
| mi | xm,xi | head,right,destination | mi |
|
||||||
|
|
||||||
|
| oc | xo,xc | head,left,destination | oc |
|
||||||
|
| oe | xo,xe | head,slight_left,destination | oe |
|
||||||
|
| og | xo,xg | head,straight,destination | og |
|
||||||
|
| oi | xo,xi | head,slight_right,destination | oi |
|
||||||
|
| ok | xo,xk | head,right,destination | ok |
|
||||||
|
|
||||||
|
| ae | xa,xe | head,left,destination | ae |
|
||||||
|
| ag | xa,xg | head,slight_left,destination | ag |
|
||||||
|
| ai | xa,xi | head,straight,destination | ai |
|
||||||
|
| ak | xa,xk | head,slight_right,destination | ak |
|
||||||
|
| am | xa,xm | head,right,destination | am |
|
||||||
|
|
||||||
|
| cg | xc,xg | head,left,destination | cg |
|
||||||
|
| ci | xc,xi | head,slight_left,destination | ci |
|
||||||
|
| ck | xc,xk | head,straight,destination | ck |
|
||||||
|
| cm | xc,xm | head,slight_right,destination | cm |
|
||||||
|
| co | xc,xo | head,right,destination | co |
|
||||||
|
|
||||||
|
| ei | xe,xi | head,left,destination | ei |
|
||||||
|
| ek | xe,xk | head,slight_left,destination | ek |
|
||||||
|
| em | xe,xm | head,straight,destination | em |
|
||||||
|
| eo | xe,xo | head,slight_right,destination | eo |
|
||||||
|
| ea | xe,xa | head,right,destination | ea |
|
||||||
|
|
||||||
|
| gk | xg,xk | head,left,destination | gk |
|
||||||
|
| gm | xg,xm | head,slight_left,destination | gm |
|
||||||
|
| go | xg,xo | head,straight,destination | go |
|
||||||
|
| ga | xg,xa | head,slight_right,destination | ga |
|
||||||
|
| gc | xg,xc | head,right,destination | gc |
|
@ -187,7 +187,12 @@ template <class DataFacadeT> class MapMatchingPlugin : public BasePlugin
|
|||||||
subtrace.values["confidence"] = sub.confidence;
|
subtrace.values["confidence"] = sub.confidence;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (route_parameters.geometry)
|
JSONDescriptor<DataFacadeT> json_descriptor(facade);
|
||||||
|
json_descriptor.SetConfig(route_parameters);
|
||||||
|
|
||||||
|
subtrace.values["hint_data"] = json_descriptor.BuildHintData(raw_route);
|
||||||
|
|
||||||
|
if (route_parameters.geometry || route_parameters.print_instructions)
|
||||||
{
|
{
|
||||||
DescriptionFactory factory;
|
DescriptionFactory factory;
|
||||||
FixedPointCoordinate current_coordinate;
|
FixedPointCoordinate current_coordinate;
|
||||||
@ -205,13 +210,22 @@ template <class DataFacadeT> class MapMatchingPlugin : public BasePlugin
|
|||||||
raw_route.target_traversed_in_reverse[i],
|
raw_route.target_traversed_in_reverse[i],
|
||||||
raw_route.is_via_leg(i));
|
raw_route.is_via_leg(i));
|
||||||
}
|
}
|
||||||
// we need this because we don't run DP
|
|
||||||
for (auto &segment : factory.path_description)
|
// we run this to get the instructions
|
||||||
|
factory.Run(route_parameters.zoom_level);
|
||||||
|
|
||||||
|
if (route_parameters.geometry)
|
||||||
{
|
{
|
||||||
segment.necessary = true;
|
subtrace.values["geometry"] = factory.AppendGeometryString(route_parameters.compression);
|
||||||
}
|
}
|
||||||
subtrace.values["geometry"] =
|
|
||||||
factory.AppendGeometryString(route_parameters.compression);
|
|
||||||
|
if (route_parameters.print_instructions)
|
||||||
|
{
|
||||||
|
std::vector<typename JSONDescriptor<DataFacadeT>::Segment> temp_segments;
|
||||||
|
subtrace.values["instructions"] = json_descriptor.BuildTextualDescription(factory, temp_segments);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
subtrace.values["indices"] = osrm::json::make_array(sub.indices);
|
subtrace.values["indices"] = osrm::json::make_array(sub.indices);
|
||||||
|
Loading…
Reference in New Issue
Block a user