X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouter.h;h=3c23496710a7b8e3b8df004ca40f1a988faf5e26;hb=d4c2cc962dc4c7b11c2db360fef7a80de3334c11;hp=28fc80246f522cb48d6f1db88db7e66c917b37b9;hpb=dec294d40194a640e7b4bccf20dd1baa4a87038c;p=r2c2.git diff --git a/source/libr2c2/trainrouter.h b/source/libr2c2/trainrouter.h index 28fc802..3c23496 100644 --- a/source/libr2c2/trainrouter.h +++ b/source/libr2c2/trainrouter.h @@ -8,9 +8,11 @@ namespace R2C2 { class Block; -class Route; +class Layout; class Track; -class Zone; +class TrackChain; +class TrainRouteMetric; +class TrainRoutePlanner; class TrainRouter: public TrainAI { @@ -24,41 +26,78 @@ public: }; sigc::signal signal_route_changed; - sigc::signal signal_arrived; + sigc::signal signal_arrived; + sigc::signal signal_waypoint_reached; + + struct SequencePoint + { + Block *block; + Train *preceding_train; + unsigned sequence_in; + unsigned sequence_out; + + SequencePoint(Block &, unsigned); + + bool is_cleared() const; + }; private: typedef std::list RouteList; int priority; RouteList routes; - bool arriving; - const Train *yielding_to; + RouteList::iterator reserving_route; + unsigned arriving; + const TrackChain *destination; + std::vector waypoints; + bool destination_changed; + std::vector metrics; + bool metrics_stale; + std::list sequence_points; + unsigned current_sequence; + bool sequence_check_pending; + Msp::Time::TimeDelta delay; + Msp::RefPtr planner; public: TrainRouter(Train &); + ~TrainRouter(); 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 &); const Route *get_route() const; + unsigned get_current_sequence() const { return current_sequence; } +private: + void route_changed(); + +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; } 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; private: void block_reserved(Block &, Train *); 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 &); + bool is_valid_for_track(const Route &, Track &) const; + bool advance_to_track(RouteList::iterator &, Track &); + + static void start_planning(Layout &); }; } // namespace R2C2