X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouter.h;h=c1b6977f3734d45b19f615146c899d0ef22dedc0;hb=de7380fdde172fa7e905e8af91d5842994faa9fb;hp=07afe2b722112bb4453b4b994ad7b517fff207f1;hpb=1c072afdb1866ba397ee8e6155f5f68c6c7ab4da;p=r2c2.git diff --git a/source/libr2c2/trainrouter.h b/source/libr2c2/trainrouter.h index 07afe2b..c1b6977 100644 --- a/source/libr2c2/trainrouter.h +++ b/source/libr2c2/trainrouter.h @@ -9,9 +9,9 @@ namespace R2C2 { class Block; class Layout; -class Route; class Track; -class Zone; +class TrackChain; +class TrainRouteMetric; class TrainRouter: public TrainAI { @@ -25,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 @@ -40,30 +41,39 @@ private: int priority; RouteList routes; - bool arriving; - const Zone *dest_zone; - const Block *dest_block; + unsigned arriving; + const TrackChain *destination; + std::vector waypoints; + std::vector metrics; std::list waits; + Msp::Time::TimeDelta delay; bool update_pending; public: TrainRouter(Train &); + ~TrainRouter(); void set_priority(int); int get_priority() const { return priority; } bool set_route(const Route *); + bool add_route(const Route &); 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; + 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; } virtual void message(const Message &); - virtual void tick(const Msp::Time::TimeStamp &, const Msp::Time::TimeDelta &); + virtual void tick(const Msp::Time::TimeDelta &); void save(std::list &) const; @@ -72,6 +82,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 &);