X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouter.h;h=7a560a11904d7475b961198d191b6103585ec311;hb=462a04be004ab4b0ff3ce14c51a19b50271b17c7;hp=589c7297d648858472026be5ef8b42dc1459f948;hpb=d284c154438ffec9f0feb6b8dc4d9aa77ae13e24;p=r2c2.git diff --git a/source/libr2c2/trainrouter.h b/source/libr2c2/trainrouter.h index 589c729..7a560a1 100644 --- a/source/libr2c2/trainrouter.h +++ b/source/libr2c2/trainrouter.h @@ -66,6 +66,7 @@ private: unsigned current_sequence; bool sequence_check_pending; Msp::Time::TimeDelta delay; + Msp::Time::TimeDelta duration; Msp::RefPtr planner; public: @@ -84,13 +85,14 @@ private: 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 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 &); @@ -100,9 +102,10 @@ public: private: void block_reserved(Block &, Train *); void train_advanced(Block &); + void train_rear_advanced(Block &); void create_metrics(); - Route *create_lead_route(Route *, const Route *); + bool create_lead_route(); bool is_valid_for_track(const Route &, Track &) const; bool advance_to_track(RouteList::iterator &, Track &);