mirror of
https://github.com/OpenTTD/OpenTTD.git
synced 2025-02-11 08:49:50 +00:00
Change: Automatically use Trackdir node key as needed if ship curve penalties differ.
This commit is contained in:
parent
b8a0107ad1
commit
7ca1793ec4
@ -241,6 +241,16 @@ struct CYapfShip1 : CYapfT<CYapfShip_TypesT<CYapfShip1, CFollowTrackWater , C
|
|||||||
/* YAPF type 2 - uses TileIndex/DiagDirection as Node key */
|
/* YAPF type 2 - uses TileIndex/DiagDirection as Node key */
|
||||||
struct CYapfShip2 : CYapfT<CYapfShip_TypesT<CYapfShip2, CFollowTrackWater , CShipNodeListExitDir > > {};
|
struct CYapfShip2 : CYapfT<CYapfShip_TypesT<CYapfShip2, CFollowTrackWater , CShipNodeListExitDir > > {};
|
||||||
|
|
||||||
|
static inline bool RequireTrackdirKey()
|
||||||
|
{
|
||||||
|
/* If the two curve penalties are not equal, then it is not possible to use the
|
||||||
|
* ExitDir keyed node list, as it there will be key overlap. Using Trackdir keyed
|
||||||
|
* nodes means potentially more paths are tested, which would be wasteful if it's
|
||||||
|
* not necessary.
|
||||||
|
*/
|
||||||
|
return _settings_game.pf.yapf.ship_curve45_penalty != _settings_game.pf.yapf.ship_curve90_penalty;
|
||||||
|
}
|
||||||
|
|
||||||
/** Ship controller helper - path finder invoker */
|
/** Ship controller helper - path finder invoker */
|
||||||
Track YapfShipChooseTrack(const Ship *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool &path_found, ShipPathCache &path_cache)
|
Track YapfShipChooseTrack(const Ship *v, TileIndex tile, DiagDirection enterdir, TrackBits tracks, bool &path_found, ShipPathCache &path_cache)
|
||||||
{
|
{
|
||||||
@ -249,7 +259,7 @@ Track YapfShipChooseTrack(const Ship *v, TileIndex tile, DiagDirection enterdir,
|
|||||||
PfnChooseShipTrack pfnChooseShipTrack = CYapfShip2::ChooseShipTrack; // default: ExitDir
|
PfnChooseShipTrack pfnChooseShipTrack = CYapfShip2::ChooseShipTrack; // default: ExitDir
|
||||||
|
|
||||||
/* check if non-default YAPF type needed */
|
/* check if non-default YAPF type needed */
|
||||||
if (_settings_game.pf.yapf.disable_node_optimization) {
|
if (_settings_game.pf.yapf.disable_node_optimization || RequireTrackdirKey()) {
|
||||||
pfnChooseShipTrack = &CYapfShip1::ChooseShipTrack; // Trackdir
|
pfnChooseShipTrack = &CYapfShip1::ChooseShipTrack; // Trackdir
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -267,7 +277,7 @@ bool YapfShipCheckReverse(const Ship *v)
|
|||||||
PfnCheckReverseShip pfnCheckReverseShip = CYapfShip2::CheckShipReverse; // default: ExitDir
|
PfnCheckReverseShip pfnCheckReverseShip = CYapfShip2::CheckShipReverse; // default: ExitDir
|
||||||
|
|
||||||
/* check if non-default YAPF type needed */
|
/* check if non-default YAPF type needed */
|
||||||
if (_settings_game.pf.yapf.disable_node_optimization) {
|
if (_settings_game.pf.yapf.disable_node_optimization || RequireTrackdirKey()) {
|
||||||
pfnCheckReverseShip = &CYapfShip1::CheckShipReverse; // Trackdir
|
pfnCheckReverseShip = &CYapfShip1::CheckShipReverse; // Trackdir
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user