X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouter.h;h=91b7bac1a4e0730afb2e7b278911f4d74b4c5334;hb=e8d2abb48b5236cc3455a035628292ae7908240e;hp=1c523d89e96fe1d2d1c7bb04fa9d4f141d95b76b;hpb=9815c9f587063b3378e07bcd868c0ff6055a4e15;p=r2c2.git diff --git a/source/libr2c2/trainrouter.h b/source/libr2c2/trainrouter.h index 1c523d8..91b7bac 100644 --- a/source/libr2c2/trainrouter.h +++ b/source/libr2c2/trainrouter.h @@ -25,10 +25,6 @@ public: void route(const std::string &); }; - sigc::signal signal_route_changed; - sigc::signal signal_arrived; - sigc::signal signal_waypoint_reached; - struct SequencePoint { Block *block; @@ -44,10 +40,23 @@ public: private: typedef std::list RouteList; + enum ArrivalState + { + ON_THE_WAY, + RESERVED_TO_END, + ARRIVED + }; + +public: + sigc::signal signal_route_changed; + sigc::signal signal_arrived; + sigc::signal signal_waypoint_reached; + +private: int priority; RouteList routes; RouteList::iterator reserving_route; - unsigned arriving; + ArrivalState arrival; const TrackChain *destination; std::vector waypoints; bool destination_changed; @@ -57,6 +66,7 @@ private: unsigned current_sequence; bool sequence_check_pending; Msp::Time::TimeDelta delay; + Msp::Time::TimeDelta duration; Msp::RefPtr planner; public: @@ -82,6 +92,8 @@ public: 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 &); @@ -91,7 +103,7 @@ 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 &); void create_metrics(); Route *create_lead_route(Route *, const Route *);