X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibmarklin%2Flayout.h;h=2fc761aebb4aa972c020105e62a7bc626f6d346e;hb=9b05c573a38639827697fe393d55b7c76f5bde45;hp=6683e2d7ddb8de5c91ac781781c9c9fdb1bc01d9;hpb=a4566a4a23ff676f11a90615e8e468ef50107946;p=r2c2.git diff --git a/source/libmarklin/layout.h b/source/libmarklin/layout.h index 6683e2d..2fc761a 100644 --- a/source/libmarklin/layout.h +++ b/source/libmarklin/layout.h @@ -15,6 +15,7 @@ Distributed under the GPL namespace Marklin { +class ArticleNumber; class Block; class Catalogue; class Driver; @@ -35,9 +36,12 @@ public: Loader(Layout &); private: virtual void finish(); + void route(); void route(const std::string &); void track(unsigned); - void train(unsigned, unsigned); + void track(ArticleNumber); + void train(unsigned, unsigned, const std::string &); + void train(ArticleNumber, unsigned, const std::string &); }; public: @@ -57,11 +61,12 @@ private: 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); @@ -75,18 +80,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 &); @@ -103,8 +109,6 @@ public: void save(const std::string &); void save_trains(const std::string &); private: - void check_links(); - void check_routes(); void sensor_event(unsigned, bool); };