]> git.tdb.fi Git - r2c2.git/blobdiff - source/libmarklin/layout.h
Major architecture rework
[r2c2.git] / source / libmarklin / layout.h
index 86836b87f16e01fe7cbcba495fd08ab514ae553d..608ddece1eed1c2398fc36b101d2b0d6fb0c5063 100644 (file)
@@ -1,33 +1,42 @@
 /* $Id$
 
 This file is part of the MSP Märklin suite
-Copyright © 2006-2009 Mikkosoft Productions, Mikko Rasa
+Copyright © 2006-2010  Mikkosoft Productions, Mikko Rasa
 Distributed under the GPL
 */
 
 #ifndef LIBMARKLIN_LAYOUT_H_
 #define LIBMARKLIN_LAYOUT_H_
 
+#include <set>
 #include <sigc++/sigc++.h>
 #include <msp/datafile/loader.h>
-#include "route.h"
-#include "track.h"
+#include <msp/time/timestamp.h>
 
 namespace Marklin {
 
+class Block;
 class Catalogue;
+class Driver;
+class Route;
+class Track;
+class Train;
 
 class Layout
 {
 public:
        class Loader: public Msp::DataFile::BasicLoader<Layout>
        {
+       private:
+               bool new_tracks;
+
        public:
                Loader(Layout &);
        private:
                virtual void finish();
                void route(const std::string &);
                void track(unsigned);
+               void train(unsigned, unsigned);
        };
 
 public:
@@ -35,27 +44,55 @@ public:
        sigc::signal<void, Track &> signal_track_removed;
        sigc::signal<void, Route &> signal_route_added;
        sigc::signal<void, Route &> signal_route_removed;
+       sigc::signal<void, Train &> signal_train_added;
+       sigc::signal<void, Train &> signal_train_removed;
+       sigc::signal<void, Block &, Train *> signal_block_reserved;
 
 private:
        Catalogue &catalogue;
+       Driver *driver;
        std::string base;
        std::set<Track *> tracks;
        std::map<std::string, Route *> routes;
+       std::set<Block *> blocks;
+       std::map<unsigned, Train *> trains;
+       Msp::Time::TimeStamp last_tick;
 
 public:
-       Layout(Catalogue &);
+       Layout(Catalogue &, Driver * = 0);
        ~Layout();
 
        Catalogue &get_catalogue() const { return catalogue; }
+       bool has_driver() const { return driver; }
+       Driver &get_driver() const;
        const std::string &get_base() const { return base; }
-       const std::set<Track *> &get_tracks() const { return tracks; }
+
        void add_track(Track &);
+       const std::set<Track *> &get_tracks() const { return tracks; }
        void remove_track(Track &);
+
+       void add_block(Block &);
+       Block &get_block(unsigned) const;
+       Block &get_block_by_track(const Track &) const;
+       const std::set<Block *> &get_blocks() const { return blocks; }
+       void create_blocks();
+       void create_blocks(const Track &);
+       void remove_block(Block &);
+
        void add_route(Route &);
        const std::map<std::string, Route *> &get_routes() const { return routes; }
        Route &get_route(const std::string &) const;
        void remove_route(Route &);
+
+       void add_train(Train &);
+       Train &get_train(unsigned) const;
+       const std::map<unsigned, Train *> &get_trains() const { return trains; }
+       void remove_train(Train &);
+
+       void tick();
+
        void save(const std::string &);
+       void save_trains(const std::string &);
 private:
        void check_links();
        void check_routes();