X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouter.h;h=27307e7849a885569b358d8bb8f2bcff49f4ac80;hb=bc2b44d50fb144f0f2ddaecc187607d6967e2ffb;hp=47a409cd7cb2bdb36064f753e5c2f9cadd4bca77;hpb=0ac334781fcb5029e4ea9236a8e93f43169eb7f2;p=r2c2.git diff --git a/source/libr2c2/trainrouter.h b/source/libr2c2/trainrouter.h index 47a409c..27307e7 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,8 +40,15 @@ public: private: typedef std::list RouteList; +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; const TrackChain *destination; std::vector waypoints; @@ -90,12 +93,11 @@ public: private: void block_reserved(Block &, Train *); void train_advanced(Block &); - const Route *get_route_for_block(const Block &) const; void create_metrics(); Route *create_lead_route(Route *, const Route *); - bool advance_route(RouteList::iterator &, const Block &); - bool is_on_route(const Block &); + bool is_valid_for_track(const Route &, Track &) const; + bool advance_to_track(RouteList::iterator &, Track &); static void start_planning(Layout &); };