X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;ds=sidebyside;f=source%2Flibr2c2%2Ftrainrouter.h;h=4f620764fd8c1a679205f59bb49662ad0fc0d20a;hb=3d5779e12351547dded382f2d05d3f3f037dbcfd;hp=b36a0135dfcde0850e6a5036cdea30d915ce00b4;hpb=32739f060d1c025756b3ed702da1cbbdd6793064;p=r2c2.git diff --git a/source/libr2c2/trainrouter.h b/source/libr2c2/trainrouter.h index b36a013..4f62076 100644 --- a/source/libr2c2/trainrouter.h +++ b/source/libr2c2/trainrouter.h @@ -9,9 +9,8 @@ namespace R2C2 { class Block; class Layout; -class Route; class Track; -class Zone; +class TrackChain; class TrainRouter: public TrainAI { @@ -25,7 +24,8 @@ public: }; sigc::signal signal_route_changed; - sigc::signal signal_arrived; + sigc::signal signal_arrived; + sigc::signal signal_waypoint_reached; private: struct Wait @@ -41,9 +41,10 @@ private: int priority; RouteList routes; unsigned arriving; - const Zone *dest_zone; - const Block *dest_block; + const TrackChain *destination; + std::vector waypoints; std::list waits; + Msp::Time::TimeDelta delay; bool update_pending; @@ -57,10 +58,14 @@ public: void add_wait(Block &, Train *); const Route *get_route() const; - void set_destination(const Zone &); - void set_destination(const Block &); - bool has_destination() const; + 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; + void set_departure_delay(const Msp::Time::TimeDelta &); + const Msp::Time::TimeDelta &get_departure_delay() const { return delay; } virtual void message(const Message &); virtual void tick(const Msp::Time::TimeDelta &);