(svn r2514) - Codechange: [NPF] Move the checking of railtype into a funciton IsCompatibleRail().
- Codechange: [NPF] Check the railtype along a route against the engine type instead of against the previouse tile. This clears the way for electriefied rails. - Add: [NPF] [ 1209644 ] A penalty for crossings (peter1138)
This commit is contained in:
		
							
								
								
									
										11
									
								
								npf.h
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								npf.h
									
									
									
									
									
								
							| @@ -35,6 +35,7 @@ typedef struct NPFFindStationOrTileData { /* Meant to be stored in AyStar.target | ||||
| enum { /* Indices into AyStar.userdata[] */ | ||||
| 	NPF_TYPE = 0, /* Contains a TransportTypes value */ | ||||
| 	NPF_OWNER, /* Contains an Owner value */ | ||||
| 	NPF_RAILTYPE, /* Contains the RailType value of the engine when NPF_TYPE == TRANSPORT_RAIL. Unused otherwise. */ | ||||
| }; | ||||
|  | ||||
| enum { /* Indices into AyStarNode.userdata[] */ | ||||
| @@ -59,27 +60,27 @@ typedef struct NPFFoundTargetData { /* Meant to be stored in AyStar.userpath */ | ||||
| /* Will search from the given tile and direction, for a route to the given | ||||
|  * station for the given transport type. See the declaration of | ||||
|  * NPFFoundTargetData above for the meaning of the result. */ | ||||
| NPFFoundTargetData NPFRouteToStationOrTile(TileIndex tile, Trackdir trackdir, NPFFindStationOrTileData* target, TransportType type, Owner owner); | ||||
| NPFFoundTargetData NPFRouteToStationOrTile(TileIndex tile, Trackdir trackdir, NPFFindStationOrTileData* target, TransportType type, Owner owner, RailType railtype); | ||||
| /* Will search as above, but with two start nodes, the second being the | ||||
|  * reverse. Look at the NPF_FLAG_REVERSE flag in the result node to see which | ||||
|  * direction was taken (NPFGetBit(result.node, NPF_FLAG_REVERSE)) */ | ||||
| NPFFoundTargetData NPFRouteToStationOrTileTwoWay(TileIndex tile1, Trackdir trackdir1, TileIndex tile2, Trackdir trackdir2, NPFFindStationOrTileData* target, TransportType type, Owner owner); | ||||
| NPFFoundTargetData NPFRouteToStationOrTileTwoWay(TileIndex tile1, Trackdir trackdir1, TileIndex tile2, Trackdir trackdir2, NPFFindStationOrTileData* target, TransportType type, Owner owner, RailType railtype); | ||||
|  | ||||
| /* Will search a route to the closest depot. */ | ||||
|  | ||||
| /* Search using breadth first. Good for little track choice and inaccurate | ||||
|  * heuristic, such as railway/road.*/ | ||||
| NPFFoundTargetData NPFRouteToDepotBreadthFirst(TileIndex tile, Trackdir trackdir, TransportType type, Owner owner); | ||||
| NPFFoundTargetData NPFRouteToDepotBreadthFirst(TileIndex tile, Trackdir trackdir, TransportType type, Owner owner, RailType railtype); | ||||
| /* Same as above but with two start nodes, the second being the reverse. Call | ||||
|  * NPFGetBit(result.node, NPF_FLAG_REVERSE) to see from which node the path | ||||
|  * orginated. All pathfs from the second node will have the given | ||||
|  * reverse_penalty applied (NPF_TILE_LENGTH is the equivalent of one full | ||||
|  * tile). | ||||
|  */ | ||||
| NPFFoundTargetData NPFRouteToDepotBreadthFirstTwoWay(TileIndex tile1, Trackdir trackdir1, TileIndex tile2, Trackdir trackdir2, TransportType type, Owner owner, uint reverse_penalty); | ||||
| NPFFoundTargetData NPFRouteToDepotBreadthFirstTwoWay(TileIndex tile1, Trackdir trackdir1, TileIndex tile2, Trackdir trackdir2, TransportType type, Owner owner, RailType railtype, uint reverse_penalty); | ||||
| /* Search by trying each depot in order of Manhattan Distance. Good for lots | ||||
|  * of choices and accurate heuristics, such as water. */ | ||||
| NPFFoundTargetData NPFRouteToDepotTrialError(TileIndex tile, Trackdir trackdir, TransportType type, Owner owner); | ||||
| NPFFoundTargetData NPFRouteToDepotTrialError(TileIndex tile, Trackdir trackdir, TransportType type, Owner owner, RailType railtype); | ||||
|  | ||||
| void NPFFillWithOrderData(NPFFindStationOrTileData* fstd, Vehicle* v); | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 matthijs
					matthijs