]> git.tdb.fi Git - r2c2.git/blobdiff - source/libr2c2/trainrouter.h
Refactor TrainRoutePlanner so that the same object may be used again
[r2c2.git] / source / libr2c2 / trainrouter.h
index c69d28c9389057c3ea37cb14fd5ed3ed5ad0a52a..6f697f997b6349ba686b409022ce9e1d6fd79e86 100644 (file)
@@ -29,12 +29,14 @@ public:
        sigc::signal<void, const TrackChain *> signal_waypoint_reached;
 
 private:
-       struct Wait
+       struct SequencePoint
        {
                Block *block;
-               Train *train;
+               Train *preceding_train;
+               unsigned sequence_in;
+               unsigned sequence_out;
 
-               Wait();
+               SequencePoint(Block &, unsigned);
        };
 
        typedef std::list<const Route *> RouteList;
@@ -45,7 +47,9 @@ private:
        const TrackChain *destination;
        std::vector<const TrackChain *> waypoints;
        std::vector<TrainRouteMetric *> metrics;
-       std::list<Wait> waits;
+       std::list<SequencePoint> sequence_points;
+       std::list<SequencePoint *> pending_sequence_checks;
+       unsigned current_sequence;
        Msp::Time::TimeDelta delay;
 
        bool update_pending;
@@ -58,8 +62,11 @@ public:
        int get_priority() const { return priority; }
 
        bool set_route(const Route *);
-       void add_wait(Block &, Train *);
+       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; }
 
        void set_destination(const TrackChain &);
        const TrackChain *get_destination() const { return destination; }