]> git.tdb.fi Git - r2c2.git/blobdiff - source/libr2c2/trainrouter.h
Move members after type declarations
[r2c2.git] / source / libr2c2 / trainrouter.h
index 47a409cd7cb2bdb36064f753e5c2f9cadd4bca77..27307e7849a885569b358d8bb8f2bcff49f4ac80 100644 (file)
@@ -25,10 +25,6 @@ public:
                void route(const std::string &);
        };
 
-       sigc::signal<void, const Route *> signal_route_changed;
-       sigc::signal<void, const TrackChain *> signal_arrived;
-       sigc::signal<void, const TrackChain *> signal_waypoint_reached;
-
        struct SequencePoint
        {
                Block *block;
@@ -44,8 +40,15 @@ public:
 private:
        typedef std::list<const Route *> RouteList;
 
+public:
+       sigc::signal<void, const Route *> signal_route_changed;
+       sigc::signal<void, const TrackChain *> signal_arrived;
+       sigc::signal<void, const TrackChain *> signal_waypoint_reached;
+
+private:
        int priority;
        RouteList routes;
+       RouteList::iterator reserving_route;
        unsigned arriving;
        const TrackChain *destination;
        std::vector<const TrackChain *> 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 &);
 };