X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Flayout.h;h=de5588cefb98449790a8f4ca3923c868399acbaf;hb=59bae8acd679127602cf35d22bcd37e316a5a056;hp=ecb801f0e07c5bc8d4c4af4f9edb300967fba6db;hpb=7e27b311e33beda1746eb63e0945633f262427f6;p=r2c2.git diff --git a/source/libr2c2/layout.h b/source/libr2c2/layout.h index ecb801f..de5588c 100644 --- a/source/libr2c2/layout.h +++ b/source/libr2c2/layout.h @@ -1,17 +1,12 @@ -/* $Id$ - -This file is part of R²C² -Copyright © 2006-2010 Mikkosoft Productions, Mikko Rasa -Distributed under the GPL -*/ - #ifndef LIBR2C2_LAYOUT_H_ #define LIBR2C2_LAYOUT_H_ #include #include -#include +#include #include +#include "geometry.h" +#include "sensor.h" namespace R2C2 { @@ -19,7 +14,9 @@ class ArticleNumber; class Block; class Catalogue; class Driver; +class Object; class Route; +class Signal; class Track; class Train; class Vehicle; @@ -28,7 +25,7 @@ class Zone; class Layout { public: - class Loader: public Msp::DataFile::BasicLoader + class Loader: public Msp::DataFile::ObjectLoader { private: bool new_tracks; @@ -36,13 +33,14 @@ public: public: Loader(Layout &); private: - virtual void finish(); 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(); }; @@ -51,6 +49,8 @@ public: sigc::signal signal_track_added; sigc::signal signal_track_removed; + sigc::signal signal_signal_added; + sigc::signal signal_signal_removed; sigc::signal signal_route_added; sigc::signal signal_route_removed; sigc::signal signal_zone_added; @@ -60,6 +60,7 @@ public: sigc::signal signal_vehicle_added; sigc::signal signal_vehicle_removed; sigc::signal signal_block_reserved; + sigc::signal signal_sensor_state_changed; sigc::signal signal_emergency; private: @@ -67,9 +68,11 @@ private: Driver *driver; std::string base; std::set tracks; + std::set signals; std::set routes; ZoneSet zones; std::set blocks; + std::set sensors; std::map trains; std::set vehicles; Msp::Time::TimeStamp last_tick; @@ -86,9 +89,22 @@ public: void add_track(Track &); const std::set &get_tracks() const { return tracks; } + Track *pick_track(const Ray &); void remove_track(Track &); - unsigned allocate_turnout_id(bool); + unsigned allocate_turnout_id(); + + void add_signal(Signal &); + const std::set &get_signals() const { return signals; } + Signal *pick_signal(const Ray &); + void remove_signal(Signal &); + + Object *pick_object(const Ray &); +private: + template + static T *pick(const std::set &, const Ray &); + +public: void add_block(Block &); Block &get_block(unsigned) const; const std::set &get_blocks() const { return blocks; } @@ -116,13 +132,16 @@ public: void add_vehicle(Vehicle &); void remove_vehicle(Vehicle &); + void add_sensor(Sensor &); + void remove_sensor(Sensor &); + void tick(); void emergency(const std::string &); void save(const std::string &) const; - void save_trains(const std::string &) const; + void save_dynamic(const std::string &) const; private: - void sensor_event(unsigned, bool); + void sensor_state_changed(Sensor &, Sensor::State); }; } // namespace R2C2