]> git.tdb.fi Git - r2c2.git/blobdiff - source/libr2c2/trainrouter.h
Redesign the interface between TrainRouter and TrainRoutePlanner
[r2c2.git] / source / libr2c2 / trainrouter.h
index 6f697f997b6349ba686b409022ce9e1d6fd79e86..cbaa520cd20d945c5e1249ba5679fddb07c9b9b9 100644 (file)
@@ -12,6 +12,7 @@ class Layout;
 class Track;
 class TrackChain;
 class TrainRouteMetric;
+class TrainRoutePlanner;
 
 class TrainRouter: public TrainAI
 {
@@ -28,7 +29,6 @@ public:
        sigc::signal<void, const TrackChain *> signal_arrived;
        sigc::signal<void, const TrackChain *> signal_waypoint_reached;
 
-private:
        struct SequencePoint
        {
                Block *block;
@@ -39,6 +39,7 @@ private:
                SequencePoint(Block &, unsigned);
        };
 
+private:
        typedef std::list<const Route *> RouteList;
 
        int priority;
@@ -46,13 +47,14 @@ private:
        unsigned arriving;
        const TrackChain *destination;
        std::vector<const TrackChain *> waypoints;
+       bool destination_changed;
        std::vector<TrainRouteMetric *> metrics;
+       bool metrics_stale;
        std::list<SequencePoint> sequence_points;
        std::list<SequencePoint *> pending_sequence_checks;
        unsigned current_sequence;
        Msp::Time::TimeDelta delay;
-
-       bool update_pending;
+       Msp::RefPtr<TrainRoutePlanner> planner;
 
 public:
        TrainRouter(Train &);
@@ -62,12 +64,12 @@ public:
        int get_priority() const { return priority; }
 
        bool set_route(const Route *);
-       bool add_route(const Route &);
        const Route *get_route() const;
-       void add_sequence_point(Block &, unsigned);
-       void add_sequence_point(Block &, Train &, unsigned, unsigned);
        unsigned get_current_sequence() const { return current_sequence; }
+private:
+       void route_changed();
 
+public:
        void set_destination(const TrackChain &);
        const TrackChain *get_destination() const { return destination; }
        bool is_destination(Track &) const;
@@ -93,7 +95,7 @@ private:
        bool advance_route(RouteList::iterator &, const Block &);
        bool is_on_route(const Block &);
 
-       static void create_plans(Layout &);
+       static void start_planning(Layout &);
 };
 
 } // namespace R2C2