X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouteplanner.h;h=47d00b8079d4f3062702ed3a040e086cb6157e77;hb=c1f45677ffbe9ded079df99f998d8e2abfe548de;hp=3076c3978efa5ed0b27edae5cec7b4130e72afa7;hpb=528c4f8760ac54fb2d1f3002248ecf6774956030;p=r2c2.git diff --git a/source/libr2c2/trainrouteplanner.h b/source/libr2c2/trainrouteplanner.h index 3076c39..47d00b8 100644 --- a/source/libr2c2/trainrouteplanner.h +++ b/source/libr2c2/trainrouteplanner.h @@ -31,6 +31,7 @@ private: struct TrainRoutingInfo { Train *train; + float length; float speed; Block *first_noncritical; TrainRouter *router; @@ -81,6 +82,7 @@ private: float distance_traveled; float remaining_estimate; Msp::Time::TimeDelta wait_time; + Msp::Time::TimeDelta estimated_wait; int blocked_by; TrainRoutingState(TrainRoutingInfo &); @@ -88,11 +90,13 @@ private: ~TrainRoutingState(); Msp::Time::TimeDelta get_time_to_next_track() const; + Msp::Time::TimeDelta get_time_to_pass(Track &) const; bool is_occupying(Track &) const; bool check_arrival(); void advance(float); void advance(const Msp::Time::TimeDelta &); void advance_track(unsigned); + void set_path(unsigned); void update_estimate(); bool is_viable() const; }; @@ -100,8 +104,8 @@ private: struct RoutingStep { Msp::Time::TimeDelta time; - Msp::Time::TimeDelta penalty; Msp::Time::TimeDelta cost_estimate; + bool preferred; std::vector trains; const RoutingStep *prev; @@ -138,6 +142,7 @@ private: std::list steps; std::list queue; const RoutingStep *goal; + Msp::Time::TimeDelta path_switch_bias; Msp::Time::TimeDelta timeout; Result result; PlanningThread *thread;