X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouter.h;h=07afe2b722112bb4453b4b994ad7b517fff207f1;hb=1c072afdb1866ba397ee8e6155f5f68c6c7ab4da;hp=28fc80246f522cb48d6f1db88db7e66c917b37b9;hpb=0db89b665527609582df98854c9e3255d1017811;p=r2c2.git diff --git a/source/libr2c2/trainrouter.h b/source/libr2c2/trainrouter.h index 28fc802..07afe2b 100644 --- a/source/libr2c2/trainrouter.h +++ b/source/libr2c2/trainrouter.h @@ -8,6 +8,7 @@ namespace R2C2 { class Block; +class Layout; class Route; class Track; class Zone; @@ -27,25 +28,40 @@ public: sigc::signal signal_arrived; private: + struct Wait + { + Block *block; + Train *train; + + Wait(); + }; + typedef std::list RouteList; int priority; RouteList routes; bool arriving; - const Train *yielding_to; + const Zone *dest_zone; + const Block *dest_block; + std::list waits; + + bool update_pending; public: TrainRouter(Train &); void set_priority(int); int get_priority() const { return priority; } - void yield_to(const Train &); bool set_route(const Route *); - bool go_to(Track &); - bool go_to(const Zone &); + void add_wait(Block &, Train *); const Route *get_route() const; + void set_destination(const Zone &); + void set_destination(const Block &); + bool has_destination() const; + bool is_destination(Track &) const; + virtual void message(const Message &); virtual void tick(const Msp::Time::TimeStamp &, const Msp::Time::TimeDelta &); @@ -59,6 +75,8 @@ private: Route *create_lead_route(Route *, const Route *); bool advance_route(RouteList::iterator &, const Block &); bool is_on_route(const Block &); + + static void create_plans(Layout &); }; } // namespace R2C2