OpenTTD Source 20241224-master-gee860a5c8e
|
A hop the refresh algorithm might evaluate. More...
#include <refresh.h>
Public Member Functions | |
Hop () | |
Default constructor should not be called but has to be visible for usage in std::set. | |
Hop (OrderID from, OrderID to, CargoID cargo) | |
Real constructor, only use this one. | |
bool | operator< (const Hop &other) const |
Comparison operator to allow hops to be used in a std::set. | |
Data Fields | |
OrderID | from |
Last order where vehicle could interact with cargo or absolute first order. | |
OrderID | to |
Next order to be processed. | |
CargoID | cargo |
Cargo the consist is probably carrying or INVALID_CARGO if unknown. | |
A hop the refresh algorithm might evaluate.
If the same hop is seen again the evaluation is stopped. This of course is a fairly simple heuristic. Sequences of refit orders can produce vehicles with all kinds of different cargoes and remembering only one can lead to early termination of the algorithm. However, as the order language is Turing complete, we are facing the halting problem here. At some point we have to draw the line.
|
inline |
|
inline |
bool LinkRefresher::Hop::operator< | ( | const Hop & | other | ) | const |
Comparison operator to allow hops to be used in a std::set.
other | Other hop to be compared with. |
Definition at line 46 of file refresh.cpp.
CargoID LinkRefresher::Hop::cargo |
Cargo the consist is probably carrying or INVALID_CARGO if unknown.
Definition at line 59 of file refresh.h.
Referenced by operator<().
OrderID LinkRefresher::Hop::from |
Last order where vehicle could interact with cargo or absolute first order.
Definition at line 57 of file refresh.h.
Referenced by operator<().
OrderID LinkRefresher::Hop::to |