X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouteplanner.h;h=d24c3dc6a2ae54903bd4f6dd731861f9e000e110;hb=932c76bc0358eeaf1c18cc950201226262d0df17;hp=726ebe4229e5fb9d7a3b931bff9e1d8602e5c9f3;hpb=1c072afdb1866ba397ee8e6155f5f68c6c7ab4da;p=r2c2.git diff --git a/source/libr2c2/trainrouteplanner.h b/source/libr2c2/trainrouteplanner.h index 726ebe4..d24c3dc 100644 --- a/source/libr2c2/trainrouteplanner.h +++ b/source/libr2c2/trainrouteplanner.h @@ -22,9 +22,10 @@ private: struct TrainRoutingInfo { Train *train; + float speed; TrainRouter *router; Route *route; - std::list waits; + std::list waits; TrainRoutingInfo(Train &); }; @@ -59,6 +60,9 @@ private: float offset; float back_offset; TrainState state; + Msp::Time::TimeDelta delay; + int waypoint; + int blocked_by; TrainRoutingState(TrainRoutingInfo &); TrainRoutingState(const TrainRoutingState &); @@ -66,6 +70,7 @@ private: Msp::Time::TimeDelta get_time_to_next_track() const; bool is_occupied(Track &) const; + bool check_arrival(); void advance(float); void advance_track(unsigned); }; @@ -74,12 +79,18 @@ private: { Msp::Time::TimeDelta time; std::vector trains; - RoutingStep *prev; + const RoutingStep *prev; RoutingStep(); - RoutingStep(RoutingStep *); + RoutingStep(const RoutingStep *); + 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 &); + bool is_viable() const; bool is_goal() const; bool operator<(const RoutingStep &) const; @@ -93,12 +104,8 @@ public: void plan(); private: - bool update_states(RoutingStep &); - int find_next_train(RoutingStep &); - void add_steps(RoutingStep &, unsigned); - void add_waiting_step(RoutingStep &, unsigned); - void add_steps(RoutingStep &, TrainRoutingState &train); - void create_routes(RoutingStep &); + void add_steps(const RoutingStep &); + void create_routes(const RoutingStep &); }; } // namespace R2C2