X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouter.h;h=542d1ffe8488c3e24d8b8beb2d976723d5075fc7;hb=67cd1b26d2833903e51b91e167a3d1f7ae884a31;hp=28862a221995577d8cb204ca1c546d766fbf8c6b;hpb=a7e320b46a7d4070613b3210c28e65f579750f37;p=r2c2.git diff --git a/source/libr2c2/trainrouter.h b/source/libr2c2/trainrouter.h index 28862a2..542d1ff 100644 --- a/source/libr2c2/trainrouter.h +++ b/source/libr2c2/trainrouter.h @@ -9,9 +9,10 @@ namespace R2C2 { class Block; class Layout; -class Route; class Track; -class Zone; +class TrackChain; +class TrainRouteMetric; +class TrainRoutePlanner; class TrainRouter: public TrainAI { @@ -24,46 +25,75 @@ public: void route(const std::string &); }; - sigc::signal signal_route_changed; - sigc::signal signal_arrived; - -private: - struct Wait + struct SequencePoint { Block *block; - Train *train; + Train *preceding_train; + unsigned sequence_in; + unsigned sequence_out; + + SequencePoint(Block &, unsigned); - Wait(); + bool is_cleared() const; }; +private: typedef std::list RouteList; + enum ArrivalState + { + ON_THE_WAY, + WAITING_FOR_SEQUENCE, + RESERVED_TO_END, + ARRIVED + }; + +public: + sigc::signal signal_route_changed; + sigc::signal signal_arrived; + sigc::signal signal_waypoint_reached; + +private: int priority; RouteList routes; - unsigned arriving; - const Zone *dest_zone; - const Block *dest_block; - std::list waits; + RouteList::iterator reserving_route; + ArrivalState arrival; + std::vector waypoints; + bool waypoints_changed; + std::vector metrics; + bool metrics_stale; + std::list sequence_points; + unsigned current_sequence; + bool sequence_check_pending; Msp::Time::TimeDelta delay; - - bool update_pending; + Msp::Time::TimeDelta duration; + Msp::RefPtr planner; public: TrainRouter(Train &); + ~TrainRouter(); void set_priority(int); int get_priority() const { return priority; } bool set_route(const Route *); - void add_wait(Block &, Train *); const Route *get_route() const; + unsigned get_current_sequence() const { return current_sequence; } +private: + void use_planned_route(); + void route_changed(); - void set_destination(const Zone &); - void set_destination(const Block &); - bool has_destination() const; - bool is_destination(Track &) const; +public: + void set_destination(const TrackChain &); + const TrackChain *get_destination() const { return waypoints.empty() ? 0 : waypoints.back(); } + void add_waypoint(const TrackChain &); + unsigned get_n_waypoints() const { return waypoints.size(); } + const TrackChain &get_waypoint(unsigned) 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; } + void set_trip_duration(const Msp::Time::TimeDelta &); + const Msp::Time::TimeDelta &get_trip_duration() const { return duration; } virtual void message(const Message &); virtual void tick(const Msp::Time::TimeDelta &); @@ -73,13 +103,16 @@ public: private: void block_reserved(Block &, Train *); void train_advanced(Block &); - const Route *get_route_for_block(const Block &) const; + void train_rear_advanced(Block &); - Route *create_lead_route(Route *, const Route *); - bool advance_route(RouteList::iterator &, const Block &); - bool is_on_route(const Block &); + void create_metrics(); + bool create_lead_route(); + bool is_valid_for_track(const Route &, const TrackIter &) const; + bool advance_to_track(RouteList::iterator &, const TrackIter &); - static void create_plans(Layout &); + static void get_routers(Layout &, std::vector &); + static void start_planning(Layout &); + static void apply_plan(Layout &, TrainRoutePlanner &); }; } // namespace R2C2