X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouteplanner.h;h=215cbfd6c9b1660356c375d1d1bb6aa471f8b4d3;hb=f2de56825be33196785c82a1418056f9e7a34461;hp=de88302d3f6c8e0a22d79fedd7edebf9580a32c0;hpb=19274ec3b805af126e562c805e0c14baa14c5833;p=r2c2.git diff --git a/source/libr2c2/trainrouteplanner.h b/source/libr2c2/trainrouteplanner.h index de88302..215cbfd 100644 --- a/source/libr2c2/trainrouteplanner.h +++ b/source/libr2c2/trainrouteplanner.h @@ -25,7 +25,7 @@ private: float speed; TrainRouter *router; Route *route; - std::list waits; + std::list waits; TrainRoutingInfo(Train &); }; @@ -62,6 +62,7 @@ private: TrainState state; Msp::Time::TimeDelta delay; int waypoint; + Msp::Time::TimeDelta remaining_estimate; int blocked_by; TrainRoutingState(TrainRoutingInfo &); @@ -69,27 +70,30 @@ private: ~TrainRoutingState(); Msp::Time::TimeDelta get_time_to_next_track() const; - bool is_occupied(Track &) const; + bool is_occupying(Track &) const; bool check_arrival(); void advance(float); void advance_track(unsigned); + void update_estimate(); }; struct RoutingStep { Msp::Time::TimeDelta time; + Msp::Time::TimeDelta total_estimate; std::vector trains; - RoutingStep *prev; + const RoutingStep *prev; RoutingStep(); - RoutingStep(RoutingStep *); + RoutingStep(const RoutingStep *); - void create_successors(std::list &); + void create_successors(std::list &) const; bool update_states(); bool check_deadlocks() const; int get_occupant(Track &) const; int find_next_train() const; void advance(const Msp::Time::TimeDelta &); + void update_estimate(); bool is_viable() const; bool is_goal() const; @@ -98,14 +102,16 @@ private: std::vector routed_trains; std::list steps; + std::list queue; public: TrainRoutePlanner(Layout &); void plan(); private: - void add_steps(RoutingStep &); - void create_routes(RoutingStep &); + const RoutingStep &get_step(); + void add_steps(const RoutingStep &); + void create_routes(const RoutingStep &); }; } // namespace R2C2