X-Git-Url: http://git.tdb.fi/?p=r2c2.git;a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouter.h;h=835ec484737761663da76d30eb97246d0a6178bd;hp=9fab2892efe15803da1f413277f7a6bd25678122;hb=3dd660ffad729fbd6e75e6401f5c7f27b9013faf;hpb=1c15570729bbce44f0518373ca5bf8bf41cfa3b3 diff --git a/source/libr2c2/trainrouter.h b/source/libr2c2/trainrouter.h index 9fab289..835ec48 100644 --- a/source/libr2c2/trainrouter.h +++ b/source/libr2c2/trainrouter.h @@ -3,6 +3,7 @@ #include #include +#include "trackchain.h" #include "trainai.h" namespace R2C2 { @@ -10,7 +11,6 @@ namespace R2C2 { class Block; class Layout; class Track; -class TrackChain; class TrainRouteMetric; class TrainRoutePlanner; @@ -25,6 +25,14 @@ public: void route(const std::string &); }; + struct Waypoint + { + const TrackChain *chain; + TrackChain::Direction direction; + + Waypoint(const TrackChain &, TrackChain::Direction = TrackChain::UNSPECIFIED); + }; + struct SequencePoint { Block *block; @@ -59,7 +67,7 @@ private: RouteList routes; RouteList::iterator reserving_route; ArrivalState arrival; - std::vector waypoints; + std::vector waypoints; bool waypoints_changed; std::vector metrics; bool metrics_stale; @@ -86,10 +94,10 @@ private: public: void set_destination(const TrackChain &); - const TrackChain *get_destination() const { return waypoints.empty() ? 0 : waypoints.back(); } - void add_waypoint(const TrackChain &); + const TrackChain *get_destination() const { return waypoints.empty() ? 0 : waypoints.back().chain; } + void add_waypoint(const TrackChain &, TrackChain::Direction = TrackChain::UNSPECIFIED); unsigned get_n_waypoints() const { return waypoints.size(); } - const TrackChain &get_waypoint(unsigned) const; + const Waypoint &get_waypoint(unsigned) const; const TrainRouteMetric &get_metric(int = -1) const; void set_departure_delay(const Msp::Time::TimeDelta &); const Msp::Time::TimeDelta &get_departure_delay() const { return delay; }