X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Flayout.h;h=73c74b8d4c6cc1177415aead1990360a58080b96;hb=3051264c306adc12b6028061a3257f523c211f81;hp=86db65895c3fead5aa8b83206a2d26e84043b3ee;hpb=1ff06c5bc46a677fa389ef86c6b26664368f1653;p=r2c2.git diff --git a/source/libr2c2/layout.h b/source/libr2c2/layout.h index 86db658..73c74b8 100644 --- a/source/libr2c2/layout.h +++ b/source/libr2c2/layout.h @@ -1,33 +1,29 @@ -/* $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 "block.h" namespace R2C2 { class ArticleNumber; -class Block; class Catalogue; class Driver; class Route; +class Signal; class Track; class Train; +class Vector; class Vehicle; +class Zone; class Layout { public: - class Loader: public Msp::DataFile::BasicLoader + class Loader: public Msp::DataFile::ObjectLoader { private: bool new_tracks; @@ -38,22 +34,32 @@ public: 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(); }; -public: + typedef std::set ZoneSet; + typedef std::vector ZoneArray; + 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; + sigc::signal signal_zone_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_block_state_changed; sigc::signal signal_emergency; private: @@ -61,7 +67,9 @@ private: Driver *driver; std::string base; std::set tracks; + std::set signals; std::set routes; + ZoneSet zones; std::set blocks; std::map trains; std::set vehicles; @@ -79,8 +87,13 @@ public: void add_track(Track &); const std::set &get_tracks() const { return tracks; } + Track *pick_track(const Vector &, const Vector &); 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; } + void remove_signal(Signal &); void add_block(Block &); Block &get_block(unsigned) const; @@ -95,6 +108,12 @@ public: 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; } @@ -106,10 +125,10 @@ public: void tick(); void emergency(const std::string &); - void save(const std::string &); - void save_trains(const std::string &); + void save(const std::string &) const; + void save_dynamic(const std::string &) const; private: - void sensor_event(unsigned, bool); + void block_state_changed(Block &, Block::State); }; } // namespace R2C2