(svn r21509) -Codechange: rename the rail pathfinders "path_not_found" parameter to "path_found" and remove the ! where the variables are set / read
This commit is contained in:
		| @@ -1240,7 +1240,7 @@ bool NPFTrainCheckReverse(const Train *v) | ||||
| 	return ftd.best_bird_dist != 0 && NPFGetFlag(&ftd.node, NPF_FLAG_REVERSE); | ||||
| } | ||||
|  | ||||
| Track NPFTrainChooseTrack(const Train *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool *path_not_found, bool reserve_track, struct PBSTileInfo *target) | ||||
| Track NPFTrainChooseTrack(const Train *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool &path_found, bool reserve_track, struct PBSTileInfo *target) | ||||
| { | ||||
| 	NPFFindStationOrTileData fstd; | ||||
| 	NPFFillWithOrderData(&fstd, v, reserve_track); | ||||
| @@ -1260,7 +1260,7 @@ Track NPFTrainChooseTrack(const Train *v, TileIndex tile, DiagDirection enterdir | ||||
| 		/* We are already at our target. Just do something | ||||
| 		 * @todo maybe display error? | ||||
| 		 * @todo: go straight ahead if possible? */ | ||||
| 		if (path_not_found) *path_not_found = false; | ||||
| 		path_found = true; | ||||
| 		return FindFirstTrack(tracks); | ||||
| 	} | ||||
|  | ||||
| @@ -1268,7 +1268,7 @@ Track NPFTrainChooseTrack(const Train *v, TileIndex tile, DiagDirection enterdir | ||||
| 	 * the direction we need to take to get there, if ftd.best_bird_dist is not 0, | ||||
| 	 * we did not find our target, but ftd.best_trackdir contains the direction leading | ||||
| 	 * to the tile closest to our target. */ | ||||
| 	if (path_not_found != NULL) *path_not_found = (ftd.best_bird_dist != 0); | ||||
| 	path_found = (ftd.best_bird_dist == 0); | ||||
| 	/* Discard enterdir information, making it a normal track */ | ||||
| 	return TrackdirToTrack(ftd.best_trackdir); | ||||
| } | ||||
|   | ||||
| @@ -81,11 +81,11 @@ bool NPFTrainCheckReverse(const Train *v); | ||||
|  * @param tile     the tile to find the path from (should be next tile the train is about to enter) | ||||
|  * @param enterdir diagonal direction which the RV will enter this new tile from | ||||
|  * @param tracks   available trackdirs on the new tile (to choose from) | ||||
|  * @param path_not_found [out] true is returned if no path can be found (returned Trackdir is only a 'guess') | ||||
|  * @param path_found [out] Whether a path has been found (true) or has been guessed (false) | ||||
|  * @param reserve_track indicates whether YAPF should try to reserve the found path | ||||
|  * @param target   [out] the target tile of the reservation, free is set to true if path was reserved | ||||
|  * @return         the best track for next turn | ||||
|  */ | ||||
| Track NPFTrainChooseTrack(const Train *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool *path_not_found, bool reserve_track, struct PBSTileInfo *target); | ||||
| Track NPFTrainChooseTrack(const Train *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool &path_found, bool reserve_track, struct PBSTileInfo *target); | ||||
|  | ||||
| #endif /* NPF_FUNC_H */ | ||||
|   | ||||
| @@ -43,12 +43,12 @@ Trackdir YapfRoadVehicleChooseTrack(const RoadVehicle *v, TileIndex tile, DiagDi | ||||
|  * @param tile     the tile to find the path from (should be next tile the train is about to enter) | ||||
|  * @param enterdir diagonal direction which the RV will enter this new tile from | ||||
|  * @param tracks   available trackdirs on the new tile (to choose from) | ||||
|  * @param path_not_found [out] true is returned if no path can be found (returned Trackdir is only a 'guess') | ||||
|  * @param path_found [out] Whether a path has been found (true) or has been guessed (false) | ||||
|  * @param reserve_track indicates whether YAPF should try to reserve the found path | ||||
|  * @param target   [out] the target tile of the reservation, free is set to true if path was reserved | ||||
|  * @return         the best track for next turn | ||||
|  */ | ||||
| Track YapfTrainChooseTrack(const Train *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool *path_not_found, bool reserve_track, struct PBSTileInfo *target); | ||||
| Track YapfTrainChooseTrack(const Train *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool &path_found, bool reserve_track, struct PBSTileInfo *target); | ||||
|  | ||||
| /** | ||||
|  * Used when user sends road vehicle to the nearest depot or if road vehicle needs servicing using YAPF. | ||||
|   | ||||
| @@ -399,18 +399,18 @@ public: | ||||
| 		return 't'; | ||||
| 	} | ||||
|  | ||||
| 	static Trackdir stChooseRailTrack(const Train *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool *path_not_found, bool reserve_track, PBSTileInfo *target) | ||||
| 	static Trackdir stChooseRailTrack(const Train *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool &path_found, bool reserve_track, PBSTileInfo *target) | ||||
| 	{ | ||||
| 		/* create pathfinder instance */ | ||||
| 		Tpf pf1; | ||||
| #if !DEBUG_YAPF_CACHE | ||||
| 		Trackdir result1 = pf1.ChooseRailTrack(v, tile, enterdir, tracks, path_not_found, reserve_track, target); | ||||
| 		Trackdir result1 = pf1.ChooseRailTrack(v, tile, enterdir, tracks, path_found, reserve_track, target); | ||||
|  | ||||
| #else | ||||
| 		Trackdir result1 = pf1.ChooseRailTrack(v, tile, enterdir, tracks, path_not_found, false, NULL); | ||||
| 		Trackdir result1 = pf1.ChooseRailTrack(v, tile, enterdir, tracks, path_found, false, NULL); | ||||
| 		Tpf pf2; | ||||
| 		pf2.DisableCache(true); | ||||
| 		Trackdir result2 = pf2.ChooseRailTrack(v, tile, enterdir, tracks, path_not_found, reserve_track, target); | ||||
| 		Trackdir result2 = pf2.ChooseRailTrack(v, tile, enterdir, tracks, path_found, reserve_track, target); | ||||
| 		if (result1 != result2) { | ||||
| 			DEBUG(yapf, 0, "CACHE ERROR: ChooseRailTrack() = [%d, %d]", result1, result2); | ||||
| 			DumpState(pf1, pf2); | ||||
| @@ -420,7 +420,7 @@ public: | ||||
| 		return result1; | ||||
| 	} | ||||
|  | ||||
| 	FORCEINLINE Trackdir ChooseRailTrack(const Train *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool *path_not_found, bool reserve_track, PBSTileInfo *target) | ||||
| 	FORCEINLINE Trackdir ChooseRailTrack(const Train *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool &path_found, bool reserve_track, PBSTileInfo *target) | ||||
| 	{ | ||||
| 		if (target != NULL) target->tile = INVALID_TILE; | ||||
|  | ||||
| @@ -430,12 +430,7 @@ public: | ||||
| 		Yapf().SetDestination(v); | ||||
|  | ||||
| 		/* find the best path */ | ||||
| 		bool path_found = Yapf().FindPath(v); | ||||
| 		if (path_not_found != NULL) { | ||||
| 			/* tell controller that the path was only 'guessed' | ||||
| 			 * treat the path as found if stopped on the first two way signal(s) */ | ||||
| 			*path_not_found = !(path_found || Yapf().m_stopped_on_first_two_way_signal); | ||||
| 		} | ||||
| 		path_found = Yapf().FindPath(v); | ||||
|  | ||||
| 		/* if path not found - return INVALID_TRACKDIR */ | ||||
| 		Trackdir next_trackdir = INVALID_TRACKDIR; | ||||
| @@ -459,6 +454,9 @@ public: | ||||
|  | ||||
| 			if (reserve_track && path_found) this->TryReservePath(target); | ||||
| 		} | ||||
|  | ||||
| 		/* Treat the path as found if stopped on the first two way signal(s). */ | ||||
| 		path_found |= Yapf().m_stopped_on_first_two_way_signal; | ||||
| 		return next_trackdir; | ||||
| 	} | ||||
|  | ||||
| @@ -533,10 +531,10 @@ struct CYapfAnySafeTileRail1 : CYapfT<CYapfRail_TypesT<CYapfAnySafeTileRail1, CF | ||||
| struct CYapfAnySafeTileRail2 : CYapfT<CYapfRail_TypesT<CYapfAnySafeTileRail2, CFollowTrackFreeRailNo90, CRailNodeListTrackDir, CYapfDestinationAnySafeTileRailT , CYapfFollowAnySafeTileRailT> > {}; | ||||
|  | ||||
|  | ||||
| Track YapfTrainChooseTrack(const Train *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool *path_not_found, bool reserve_track, PBSTileInfo *target) | ||||
| Track YapfTrainChooseTrack(const Train *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool &path_found, bool reserve_track, PBSTileInfo *target) | ||||
| { | ||||
| 	/* default is YAPF type 2 */ | ||||
| 	typedef Trackdir (*PfnChooseRailTrack)(const Train*, TileIndex, DiagDirection, TrackBits, bool*, bool, PBSTileInfo*); | ||||
| 	typedef Trackdir (*PfnChooseRailTrack)(const Train*, TileIndex, DiagDirection, TrackBits, bool&, bool, PBSTileInfo*); | ||||
| 	PfnChooseRailTrack pfnChooseRailTrack = &CYapfRail1::stChooseRailTrack; | ||||
|  | ||||
| 	/* check if non-default YAPF type needed */ | ||||
| @@ -544,7 +542,7 @@ Track YapfTrainChooseTrack(const Train *v, TileIndex tile, DiagDirection enterdi | ||||
| 		pfnChooseRailTrack = &CYapfRail2::stChooseRailTrack; // Trackdir, forbid 90-deg | ||||
| 	} | ||||
|  | ||||
| 	Trackdir td_ret = pfnChooseRailTrack(v, tile, enterdir, tracks, path_not_found, reserve_track, target); | ||||
| 	Trackdir td_ret = pfnChooseRailTrack(v, tile, enterdir, tracks, path_found, reserve_track, target); | ||||
| 	return (td_ret != INVALID_TRACKDIR) ? TrackdirToTrack(td_ret) : FindFirstTrack(tracks); | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 rubidium
					rubidium