X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Flayout.h;h=44c4cde42efd861b804c3008525bc33ee62d0ef5;hb=f2de56825be33196785c82a1418056f9e7a34461;hp=7c61c4fdecf8ead4c767efc77ba564849a417f65;hpb=9f4f169affcedcf249e935f93e0a15ed60232f6a;p=r2c2.git diff --git a/source/libr2c2/layout.h b/source/libr2c2/layout.h index 7c61c4f..44c4cde 100644 --- a/source/libr2c2/layout.h +++ b/source/libr2c2/layout.h @@ -12,6 +12,7 @@ namespace R2C2 { class ArticleNumber; +class BeamGate; class Block; class Catalogue; class Driver; @@ -29,18 +30,15 @@ class Layout public: class Loader: public Msp::DataFile::ObjectLoader { - private: - bool new_tracks; - public: Loader(Layout &); private: + void beamgate(); + void clock(); void route(); - void route(const std::string &); void signal(ArticleNumber); - void track(unsigned); + void terrain(ArticleNumber); void track(ArticleNumber); - void train(unsigned, unsigned, const std::string &); void train(ArticleNumber, unsigned, const std::string &); void turnout(unsigned, unsigned); void zone(); @@ -92,7 +90,7 @@ private: Storage sensors; std::map trains; Msp::Time::TimeStamp last_tick; - unsigned next_turnout_id; + unsigned next_turnout_addr; public: Layout(Catalogue &, Driver * = 0); @@ -101,7 +99,7 @@ public: Catalogue &get_catalogue() const { return catalogue; } bool has_driver() const { return driver; } Driver &get_driver() const; - const Clock &get_clock() const { return clock; } + Clock &get_clock() { return clock; } const std::string &get_base() const { return base; } void add(Object &); @@ -109,6 +107,7 @@ public: void add(TrackChain &); void add(Block &); void add(Sensor &); + void add(BeamGate &); template const std::set &get_all() const; @@ -120,8 +119,9 @@ public: void remove(Track &); void remove(TrackChain &); void remove(Sensor &); + void remove(BeamGate &); - unsigned allocate_turnout_id(); + unsigned allocate_turnout_address(); Block &get_block(unsigned) const; void create_blocks();