X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;ds=inline;f=source%2Flibr2c2%2Ftrainrouter.h;h=6f697f997b6349ba686b409022ce9e1d6fd79e86;hb=df72b71642bbc5b9a4e5010ebca8643fbeea3ca8;hp=4f620764fd8c1a679205f59bb49662ad0fc0d20a;hpb=0be77238bcd33baf23594f3b54464205d2d51b31;p=r2c2.git diff --git a/source/libr2c2/trainrouter.h b/source/libr2c2/trainrouter.h index 4f62076..6f697f9 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 { @@ -28,12 +29,14 @@ public: sigc::signal signal_waypoint_reached; private: - struct Wait + struct SequencePoint { Block *block; - Train *train; + Train *preceding_train; + unsigned sequence_in; + unsigned sequence_out; - Wait(); + SequencePoint(Block &, unsigned); }; typedef std::list RouteList; @@ -43,20 +46,27 @@ private: unsigned arriving; const TrackChain *destination; std::vector waypoints; - std::list waits; + std::vector metrics; + std::list sequence_points; + std::list pending_sequence_checks; + unsigned current_sequence; 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 *); - void add_wait(Block &, Train *); + bool add_route(const Route &); const Route *get_route() const; + void add_sequence_point(Block &, unsigned); + void add_sequence_point(Block &, Train &, unsigned, unsigned); + unsigned get_current_sequence() const { return current_sequence; } void set_destination(const TrackChain &); const TrackChain *get_destination() const { return destination; } @@ -64,6 +74,7 @@ public: 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; } @@ -77,6 +88,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 &);