X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibmarklin%2Flayout.h;h=e96bc951298c385d7906075238a092a738a5ff16;hb=e9653dffd0026fb3c02c91a4c0feca688a86c721;hp=608ddece1eed1c2398fc36b101d2b0d6fb0c5063;hpb=651698847d5293cfb15b6fb23a394701388c0151;p=r2c2.git diff --git a/source/libmarklin/layout.h b/source/libmarklin/layout.h index 608ddec..e96bc95 100644 --- a/source/libmarklin/layout.h +++ b/source/libmarklin/layout.h @@ -21,6 +21,7 @@ class Driver; class Route; class Track; class Train; +class Vehicle; class Layout { @@ -34,6 +35,7 @@ public: Loader(Layout &); private: virtual void finish(); + void route(); void route(const std::string &); void track(unsigned); void train(unsigned, unsigned); @@ -46,17 +48,22 @@ public: sigc::signal signal_route_removed; sigc::signal signal_train_added; sigc::signal signal_train_removed; + sigc::signal signal_vehicle_added; + sigc::signal signal_vehicle_removed; sigc::signal signal_block_reserved; + sigc::signal signal_emergency; private: Catalogue &catalogue; Driver *driver; std::string base; std::set tracks; - std::map routes; + std::set routes; std::set blocks; std::map trains; + std::set vehicles; Msp::Time::TimeStamp last_tick; + unsigned next_turnout_id; public: Layout(Catalogue &, Driver * = 0); @@ -70,18 +77,19 @@ public: void add_track(Track &); const std::set &get_tracks() const { return tracks; } void remove_track(Track &); + unsigned allocate_turnout_id(bool); void add_block(Block &); Block &get_block(unsigned) const; - Block &get_block_by_track(const Track &) const; const std::set &get_blocks() const { return blocks; } void create_blocks(); - void create_blocks(const Track &); + void create_blocks(Track &); void remove_block(Block &); void add_route(Route &); - const std::map &get_routes() const { return routes; } + const std::set &get_routes() const { return routes; } Route &get_route(const std::string &) const; + void update_routes(); void remove_route(Route &); void add_train(Train &); @@ -89,13 +97,16 @@ public: const std::map &get_trains() const { return trains; } void remove_train(Train &); + void add_vehicle(Vehicle &); + void remove_vehicle(Vehicle &); + void tick(); + void emergency(const std::string &); void save(const std::string &); void save_trains(const std::string &); private: - void check_links(); - void check_routes(); + void sensor_event(unsigned, bool); }; } // namespace Marklin