X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Flayout.h;h=26df423ed731b3f461f912ee04b4c57e19fde08e;hb=a5e1363ceac1ab552849640c9021fcda362c4416;hp=f9a2ba1bd5f7cf73f06dbd39956c0afa4166cffb;hpb=e214fd389b9819eac0379cfb78e0f446e267b839;p=r2c2.git diff --git a/source/libr2c2/layout.h b/source/libr2c2/layout.h index f9a2ba1..26df423 100644 --- a/source/libr2c2/layout.h +++ b/source/libr2c2/layout.h @@ -7,10 +7,12 @@ #include #include "geometry.h" #include "sensor.h" +#include "clock.h" namespace R2C2 { class ArticleNumber; +class BeamGate; class Block; class Catalogue; class Driver; @@ -18,6 +20,7 @@ class Object; class Route; class Signal; class Track; +class TrackChain; class Train; class Vehicle; class Zone; @@ -33,12 +36,10 @@ public: public: Loader(Layout &); private: + void beamgate(); void route(); - void route(const std::string &); void signal(ArticleNumber); - void track(unsigned); void track(ArticleNumber); - void train(unsigned, unsigned, const std::string &); void train(ArticleNumber, unsigned, const std::string &); void turnout(unsigned, unsigned); void zone(); @@ -68,15 +69,12 @@ private: }; public: - typedef std::set ZoneSet; typedef std::vector ZoneArray; sigc::signal signal_object_added; sigc::signal signal_object_removed; - sigc::signal signal_route_added; - sigc::signal signal_route_removed; - sigc::signal signal_zone_added; - sigc::signal signal_zone_removed; + sigc::signal signal_track_chain_added; + sigc::signal signal_track_chain_removed; sigc::signal signal_train_added; sigc::signal signal_train_removed; sigc::signal signal_block_reserved; @@ -86,12 +84,11 @@ public: private: Catalogue &catalogue; Driver *driver; + Clock clock; std::string base; Storage objects; - std::set routes; - ZoneSet zones; - std::set blocks; - std::set sensors; + Storage track_chains; + Storage sensors; std::map trains; Msp::Time::TimeStamp last_tick; unsigned next_turnout_id; @@ -103,10 +100,15 @@ public: Catalogue &get_catalogue() const { return catalogue; } bool has_driver() const { return driver; } Driver &get_driver() const; + const Clock &get_clock() const { return clock; } const std::string &get_base() const { return base; } void add(Object &); void add(Track &); + void add(TrackChain &); + void add(Block &); + void add(Sensor &); + void add(BeamGate &); template const std::set &get_all() const; @@ -116,36 +118,27 @@ public: void remove(Object &); void remove(Track &); + void remove(TrackChain &); + void remove(Sensor &); + void remove(BeamGate &); unsigned allocate_turnout_id(); - void add_block(Block &); Block &get_block(unsigned) const; - const std::set &get_blocks() const { return blocks; } void create_blocks(); void create_blocks(Track &); - void remove_block(Block &); - void add_route(Route &); - const std::set &get_routes() const { return routes; } Route &get_route(const std::string &) const; void update_routes(); - void remove_route(Route &); - void add_zone(Zone &); - const ZoneSet &get_zones() const { return zones; } ZoneArray get_zones(const std::string &) const; Zone &get_zone(const std::string &, unsigned) const; - void remove_zone(Zone &); void add_train(Train &); Train &get_train(unsigned) const; const std::map &get_trains() const { return trains; } void remove_train(Train &); - void add_sensor(Sensor &); - void remove_sensor(Sensor &); - void tick(); void emergency(const std::string &);