X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Flayout.h;h=48a2796dcb7003affb134f99471e03ebcefb3324;hb=7a36d396eded897c421424905b2c938d770df341;hp=a4042316bbdc61d1af6b5f6357a7dbfaadd35cd8;hpb=b14059de03324aecde3efc649293d98ce5b7aaf2;p=r2c2.git diff --git a/source/libr2c2/layout.h b/source/libr2c2/layout.h index a404231..48a2796 100644 --- a/source/libr2c2/layout.h +++ b/source/libr2c2/layout.h @@ -1,18 +1,12 @@ -/* $Id$ - -This file is part of R²C² -Copyright © 2006-2011 Mikkosoft Productions, Mikko Rasa -Distributed under the GPL -*/ - #ifndef LIBR2C2_LAYOUT_H_ #define LIBR2C2_LAYOUT_H_ #include #include -#include +#include #include #include "block.h" +#include "geometry.h" namespace R2C2 { @@ -20,16 +14,16 @@ class ArticleNumber; 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; @@ -37,9 +31,9 @@ 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 &); @@ -53,6 +47,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; @@ -70,6 +66,7 @@ private: Driver *driver; std::string base; std::set tracks; + std::set signals; std::set routes; ZoneSet zones; std::set blocks; @@ -93,6 +90,18 @@ public: void remove_track(Track &); unsigned allocate_turnout_id(); + void add_signal(Signal &); + const std::set &get_signals() const { return signals; } + Signal *pick_signal(const Vector &, const Vector &); + void remove_signal(Signal &); + + Object *pick_object(const Vector &, const Vector &); + +private: + template + static T *pick(const std::set &, const Vector &, const Vector &); + +public: void add_block(Block &); Block &get_block(unsigned) const; const std::set &get_blocks() const { return blocks; }