10#ifndef YAPF_COMMON_HPP
11#define YAPF_COMMON_HPP
13#include "../../core/bitmath_func.hpp"
14#include "../../tile_type.h"
15#include "../../track_type.h"
22 typedef typename Types::Tpf
Tpf;
23 typedef typename Types::NodeList::Item
Node;
24 typedef typename Node::Key
Key;
33 return *
static_cast<Tpf *
>(
this);
40 this->origin_tile = tile;
41 this->origin_trackdirs = trackdirs;
51 n1.Set(
nullptr, this->origin_tile, td, is_choice);
52 Yapf().AddStartupNode(n1);
62 typedef typename Types::Tpf
Tpf;
63 typedef typename Types::NodeList::Item
Node;
64 typedef typename Node::Key
Key;
76 return *
static_cast<Tpf *
>(
this);
83 this->origin_tile = tile;
85 this->reverse_tile = tiler;
86 this->reverse_td = tdr;
95 n1.Set(
nullptr, this->origin_tile, this->origin_td,
false);
96 Yapf().AddStartupNode(n1);
100 n2.Set(
nullptr, this->reverse_tile, this->reverse_td,
false);
102 Yapf().AddStartupNode(n2);
113template <
class Ttypes>
115 :
public Ttypes::PfBase
116 ,
public Ttypes::PfCost
117 ,
public Ttypes::PfCache
118 ,
public Ttypes::PfOrigin
119 ,
public Ttypes::PfDestination
120 ,
public Ttypes::PfFollow
constexpr uint8_t FindFirstBit(T x)
Search the first set bit in a value.
constexpr T KillFirstBit(T value)
Clear the first bit in an integer.
YAPF origin provider base class - used when origin is one tile / multiple trackdirs.
Node::Key Key
key to hash tables
Tpf & Yapf()
to access inherited path finder
Types::Tpf Tpf
the pathfinder class (derived from THIS class)
TrackdirBits origin_trackdirs
origin trackdir mask
void SetOrigin(TileIndex tile, TrackdirBits trackdirs)
Set origin tile / trackdir mask.
void PfSetStartupNodes()
Called when YAPF needs to place origin nodes into open list.
TileIndex origin_tile
origin tile
Types::NodeList::Item Node
this will be our node type
YAPF origin provider base class - used when there are two tile/trackdir origins.
Trackdir reverse_td
second (reverse) origin trackdir
void PfSetStartupNodes()
Called when YAPF needs to place origin nodes into open list.
Tpf & Yapf()
to access inherited path finder
void SetOrigin(TileIndex tile, Trackdir td, TileIndex tiler=INVALID_TILE, Trackdir tdr=INVALID_TRACKDIR, int reverse_penalty=0)
set origin (tiles, trackdirs, etc.)
int reverse_penalty
penalty to be added for using the reverse origin
Node::Key Key
key to hash tables
TileIndex reverse_tile
second (reverse) origin tile
Trackdir origin_td
first origin trackdir
Types::Tpf Tpf
the pathfinder class (derived from THIS class)
Types::NodeList::Item Node
this will be our node type
TileIndex origin_tile
first origin tile
YAPF template that uses Ttypes template argument to determine all YAPF components (base classes) from...
constexpr TileIndex INVALID_TILE
The very nice invalid tile marker.
Trackdir
Enumeration for tracks and directions.
@ INVALID_TRACKDIR
Flag for an invalid trackdir.
TrackdirBits
Allow incrementing of Trackdir variables.
@ TRACKDIR_BIT_NONE
No track build.