X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Flayout.h;h=e06d4fb04f50d8ccb1e581a363e2dce18d13d91a;hb=065d35f5f86a5b9cda95736f59e63845e0bb6fa6;hp=c32795594bd253b43d03299e0dfe2e30f3b74d81;hpb=2910db1364914c0ab98a0f80250cc39137821577;p=r2c2.git diff --git a/source/libr2c2/layout.h b/source/libr2c2/layout.h index c327955..e06d4fb 100644 --- a/source/libr2c2/layout.h +++ b/source/libr2c2/layout.h @@ -1,22 +1,29 @@ #ifndef LIBR2C2_LAYOUT_H_ #define LIBR2C2_LAYOUT_H_ +#include #include #include #include +#include #include -#include "block.h" +#include "geometry.h" +#include "sensor.h" +#include "clock.h" namespace R2C2 { class ArticleNumber; +class BeamGate; +class Block; class Catalogue; class Driver; +class Object; class Route; class Signal; class Track; +class TrackChain; class Train; -class Vector; class Vehicle; class Zone; @@ -25,56 +32,78 @@ class Layout public: class Loader: public Msp::DataFile::ObjectLoader { - private: - bool new_tracks; - public: Loader(Layout &); private: - virtual void finish(); + void beamgate(); + void clock(); 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 signal(const std::string &); + void terrain(const std::string &); + void track(const std::string &); + void train(const std::string &, unsigned, const std::string &); + void turnout(unsigned); + void turnout2(unsigned, unsigned); void zone(); }; - typedef std::set ZoneSet; +private: + template + class Storage + { + private: + std::set base; + mutable std::list caches; + + public: + ~Storage(); + + bool insert(B &); + bool erase(B &); + + const std::set &get() const { return base; } + + template + const std::set &get() const; + + template + void del(); + }; + + struct BlockReservation + { + Block *block; + Train *train; + + BlockReservation(Block &, Train *); + }; + +public: 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_object_added; + sigc::signal signal_object_removed; + sigc::signal signal_track_chain_added; + sigc::signal signal_track_chain_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; + sigc::signal signal_sensor_state_changed; + sigc::signal signal_emergency; private: Catalogue &catalogue; Driver *driver; + Clock clock; std::string base; - std::set tracks; - std::set signals; - std::set routes; - ZoneSet zones; - std::set blocks; + Storage objects; + Storage track_chains; + Storage sensors; std::map trains; - std::set vehicles; Msp::Time::TimeStamp last_tick; - unsigned next_turnout_id; + unsigned next_turnout_addr; + bool emitting_block_reserved; + std::deque block_reserve_queue; public: Layout(Catalogue &, Driver * = 0); @@ -83,60 +112,56 @@ public: Catalogue &get_catalogue() const { return catalogue; } bool has_driver() const { return driver; } Driver &get_driver() const; + Clock &get_clock() { return clock; } const std::string &get_base() const { return base; } - 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(); + void add(Object &); + void add(Track &); + void add(TrackChain &); + void add(Block &); + void add(Sensor &); + void add(BeamGate &); - 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 &); + template + const std::set &get_all() const; -private: template - static T *pick(const std::set &, const Vector &, const Vector &); + T *pick(const Ray &); + + void remove(Object &); + void remove(Track &); + void remove(TrackChain &); + void remove(Sensor &); + void remove(BeamGate &); + + unsigned allocate_turnout_address(); -public: - void add_block(Block &); Block &get_block(unsigned) const; - const std::set &get_blocks() const { return blocks; } void create_blocks(); void create_blocks(Track &); - void remove_block(Block &); - void add_route(Route &); - const std::set &get_routes() const { return routes; } Route &get_route(const std::string &) const; 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; } void remove_train(Train &); - void add_vehicle(Vehicle &); - void remove_vehicle(Vehicle &); - - void tick(); - void emergency(const std::string &); + void tick(float = 1.0f); +private: + void step(const Msp::Time::TimeDelta &); +public: + void emergency(Block *, const std::string &); void save(const std::string &) const; void save_dynamic(const std::string &) const; private: - void block_state_changed(Block &, Block::State); + void sensor_state_changed(Sensor &, Sensor::State); + void block_reserved(Block &, Train *); }; } // namespace R2C2