X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouter.h;h=c69d28c9389057c3ea37cb14fd5ed3ed5ad0a52a;hb=83778cdecccaa02c943cb9b49fb20f1c546b15bd;hp=c518522590bc4fdda11cf330b8a5532ffc4d7d56;hpb=a7b4305930090851623da7e02e21650510ce7dae;p=r2c2.git diff --git a/source/libr2c2/trainrouter.h b/source/libr2c2/trainrouter.h index c518522..c69d28c 100644 --- a/source/libr2c2/trainrouter.h +++ b/source/libr2c2/trainrouter.h @@ -11,6 +11,7 @@ class Block; class Layout; class Track; class TrackChain; +class TrainRouteMetric; class TrainRouter: public TrainAI { @@ -24,7 +25,8 @@ public: }; sigc::signal signal_route_changed; - sigc::signal signal_arrived; + sigc::signal signal_arrived; + sigc::signal signal_waypoint_reached; private: struct Wait @@ -41,6 +43,8 @@ private: RouteList routes; unsigned arriving; const TrackChain *destination; + std::vector waypoints; + std::vector metrics; std::list waits; Msp::Time::TimeDelta delay; @@ -48,6 +52,7 @@ private: public: TrainRouter(Train &); + ~TrainRouter(); void set_priority(int); int get_priority() const { return priority; } @@ -59,6 +64,10 @@ public: void set_destination(const TrackChain &); const TrackChain *get_destination() const { return destination; } bool is_destination(Track &) const; + void add_waypoint(const TrackChain &); + unsigned get_n_waypoints() const { return waypoints.size(); } + bool is_waypoint(unsigned, Track &) 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; } @@ -72,6 +81,7 @@ private: void train_advanced(Block &); const Route *get_route_for_block(const Block &) const; + void create_metrics(); Route *create_lead_route(Route *, const Route *); bool advance_route(RouteList::iterator &, const Block &); bool is_on_route(const Block &);