]> git.tdb.fi Git - r2c2.git/blobdiff - source/libr2c2/trainrouter.h
New routing system for trains
[r2c2.git] / source / libr2c2 / trainrouter.h
index 28fc80246f522cb48d6f1db88db7e66c917b37b9..07afe2b722112bb4453b4b994ad7b517fff207f1 100644 (file)
@@ -8,6 +8,7 @@
 namespace R2C2 {
 
 class Block;
+class Layout;
 class Route;
 class Track;
 class Zone;
@@ -27,25 +28,40 @@ public:
        sigc::signal<void> signal_arrived;
 
 private:
+       struct Wait
+       {
+               Block *block;
+               Train *train;
+
+               Wait();
+       };
+
        typedef std::list<const Route *> RouteList;
 
        int priority;
        RouteList routes;
        bool arriving;
-       const Train *yielding_to;
+       const Zone *dest_zone;
+       const Block *dest_block;
+       std::list<Wait> waits;
+
+       bool update_pending;
 
 public:
        TrainRouter(Train &);
 
        void set_priority(int);
        int get_priority() const { return priority; }
-       void yield_to(const Train &);
 
        bool set_route(const Route *);
-       bool go_to(Track &);
-       bool go_to(const Zone &);
+       void add_wait(Block &, Train *);
        const Route *get_route() const;
 
+       void set_destination(const Zone &);
+       void set_destination(const Block &);
+       bool has_destination() const;
+       bool is_destination(Track &) const;
+
        virtual void message(const Message &);
        virtual void tick(const Msp::Time::TimeStamp &, const Msp::Time::TimeDelta &);
 
@@ -59,6 +75,8 @@ private:
        Route *create_lead_route(Route *, const Route *);
        bool advance_route(RouteList::iterator &, const Block &);
        bool is_on_route(const Block &);
+
+       static void create_plans(Layout &);
 };
 
 } // namespace R2C2