Fix bug in snapping=any when bearings or radiuses are supplied.
This commit is contained in:
		
							parent
							
								
									5ddbb25237
								
							
						
					
					
						commit
						2c7c18fd24
					
				| @ -60,3 +60,66 @@ Feature: Car - Allowed start/end modes | |||||||
|             | from | to | route    | |             | from | to | route    | | ||||||
|             | 1    | 2  | ab,bc,cd | |             | 1    | 2  | ab,bc,cd | | ||||||
|             | 2    | 1  | cd,bc,ab | |             | 2    | 1  | cd,bc,ab | | ||||||
|  | 
 | ||||||
|  |     Scenario: Car - URL override of non-startpoints | ||||||
|  |         Given the node map | ||||||
|  |             """ | ||||||
|  |             a 1 b   c 2 d | ||||||
|  |             """ | ||||||
|  | 
 | ||||||
|  |         Given the query options | ||||||
|  |             | snapping  | any          | | ||||||
|  |             | bearings  | 90,180;      | | ||||||
|  | 
 | ||||||
|  |         And the ways | ||||||
|  |             | nodes | highway | access  | | ||||||
|  |             | ab    | service | private | | ||||||
|  |             | bc    | primary |         | | ||||||
|  |             | cd    | service | private | | ||||||
|  | 
 | ||||||
|  |         When I route I should get | ||||||
|  |             | from | to | route    | | ||||||
|  |             | 1    | 2  | ab,bc,cd | | ||||||
|  |             | 2    | 1  | cd,bc,ab | | ||||||
|  | 
 | ||||||
|  |     Scenario: Car - URL override of non-startpoints | ||||||
|  |         Given the node map | ||||||
|  |             """ | ||||||
|  |             a 1 b   c 2 d | ||||||
|  |             """ | ||||||
|  | 
 | ||||||
|  |         Given the query options | ||||||
|  |             | snapping  | any           | | ||||||
|  |             | radiuses  | 100;unlimited | | ||||||
|  | 
 | ||||||
|  |         And the ways | ||||||
|  |             | nodes | highway | access  | | ||||||
|  |             | ab    | service | private | | ||||||
|  |             | bc    | primary |         | | ||||||
|  |             | cd    | service | private | | ||||||
|  | 
 | ||||||
|  |         When I route I should get | ||||||
|  |             | from | to | route    | | ||||||
|  |             | 1    | 2  | ab,bc,cd | | ||||||
|  |             | 2    | 1  | cd,bc,ab | | ||||||
|  | 
 | ||||||
|  |     Scenario: Car - URL override of non-startpoints | ||||||
|  |         Given the node map | ||||||
|  |             """ | ||||||
|  |             a 1 b   c 2 d | ||||||
|  |             """ | ||||||
|  | 
 | ||||||
|  |         Given the query options | ||||||
|  |             | snapping  | any            | | ||||||
|  |             | bearings  | 90,180;0,180;; | | ||||||
|  | 
 | ||||||
|  |         And the ways | ||||||
|  |             | nodes | highway | access  | | ||||||
|  |             | ab    | service | private | | ||||||
|  |             | bc    | primary |         | | ||||||
|  |             | cd    | service | private | | ||||||
|  | 
 | ||||||
|  |         When I request a travel time matrix I should get | ||||||
|  |             |   | 2    | c    | | ||||||
|  |             | 1 | 59.1 | 35.1 | | ||||||
|  |             | b | 35.1 | 11.1 | | ||||||
| @ -327,13 +327,12 @@ template <typename RTreeT, typename DataFacadeT> class GeospatialQuery | |||||||
|                     (!has_small_component || (!has_big_component && !IsTinyComponent(segment))); |                     (!has_small_component || (!has_big_component && !IsTinyComponent(segment))); | ||||||
|                 auto use_directions = std::make_pair(use_segment, use_segment); |                 auto use_directions = std::make_pair(use_segment, use_segment); | ||||||
|                 const auto admissible_segments = CheckSegmentExclude(segment); |                 const auto admissible_segments = CheckSegmentExclude(segment); | ||||||
|                 use_directions = boolPairAnd(use_directions, HasValidEdge(segment, use_all_edges)); |  | ||||||
| 
 | 
 | ||||||
|                 if (use_segment) |                 if (use_segment) | ||||||
|                 { |                 { | ||||||
|                     use_directions = |                     use_directions = | ||||||
|                         boolPairAnd(CheckSegmentBearing(segment, bearing, bearing_range), |                         boolPairAnd(CheckSegmentBearing(segment, bearing, bearing_range), | ||||||
|                                     HasValidEdge(segment)); |                                     HasValidEdge(segment, use_all_edges)); | ||||||
|                     use_directions = boolPairAnd(use_directions, admissible_segments); |                     use_directions = boolPairAnd(use_directions, admissible_segments); | ||||||
|                     use_directions = boolPairAnd( |                     use_directions = boolPairAnd( | ||||||
|                         use_directions, CheckApproach(input_coordinate, segment, approach)); |                         use_directions, CheckApproach(input_coordinate, segment, approach)); | ||||||
| @ -387,13 +386,12 @@ template <typename RTreeT, typename DataFacadeT> class GeospatialQuery | |||||||
|                     (!has_small_component || (!has_big_component && !IsTinyComponent(segment))); |                     (!has_small_component || (!has_big_component && !IsTinyComponent(segment))); | ||||||
|                 auto use_directions = std::make_pair(use_segment, use_segment); |                 auto use_directions = std::make_pair(use_segment, use_segment); | ||||||
|                 const auto admissible_segments = CheckSegmentExclude(segment); |                 const auto admissible_segments = CheckSegmentExclude(segment); | ||||||
|                 use_directions = boolPairAnd(use_directions, HasValidEdge(segment, use_all_edges)); |  | ||||||
| 
 | 
 | ||||||
|                 if (use_segment) |                 if (use_segment) | ||||||
|                 { |                 { | ||||||
|                     use_directions = |                     use_directions = | ||||||
|                         boolPairAnd(CheckSegmentBearing(segment, bearing, bearing_range), |                         boolPairAnd(CheckSegmentBearing(segment, bearing, bearing_range), | ||||||
|                                     HasValidEdge(segment)); |                                     HasValidEdge(segment, use_all_edges)); | ||||||
|                     use_directions = boolPairAnd(use_directions, admissible_segments); |                     use_directions = boolPairAnd(use_directions, admissible_segments); | ||||||
|                     use_directions = boolPairAnd( |                     use_directions = boolPairAnd( | ||||||
|                         use_directions, CheckApproach(input_coordinate, segment, approach)); |                         use_directions, CheckApproach(input_coordinate, segment, approach)); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user