3 This file is part of the MSP Märklin suite
4 Copyright © 2006-2010 Mikkosoft Productions, Mikko Rasa
5 Distributed under the GPL
8 #ifndef LIBMARKLIN_LAYOUT_H_
9 #define LIBMARKLIN_LAYOUT_H_
12 #include <sigc++/sigc++.h>
13 #include <msp/datafile/loader.h>
14 #include <msp/time/timestamp.h>
29 class Loader: public Msp::DataFile::BasicLoader<Layout>
37 virtual void finish();
39 void route(const std::string &);
41 void train(unsigned, unsigned);
45 sigc::signal<void, Track &> signal_track_added;
46 sigc::signal<void, Track &> signal_track_removed;
47 sigc::signal<void, Route &> signal_route_added;
48 sigc::signal<void, Route &> signal_route_removed;
49 sigc::signal<void, Train &> signal_train_added;
50 sigc::signal<void, Train &> signal_train_removed;
51 sigc::signal<void, Vehicle &> signal_vehicle_added;
52 sigc::signal<void, Vehicle &> signal_vehicle_removed;
53 sigc::signal<void, Block &, Train *> signal_block_reserved;
54 sigc::signal<void, const std::string &> signal_emergency;
60 std::set<Track *> tracks;
61 std::set<Route *> routes;
62 std::set<Block *> blocks;
63 std::map<unsigned, Train *> trains;
64 std::set<Vehicle *> vehicles;
65 Msp::Time::TimeStamp last_tick;
66 unsigned next_turnout_id;
69 Layout(Catalogue &, Driver * = 0);
72 Catalogue &get_catalogue() const { return catalogue; }
73 bool has_driver() const { return driver; }
74 Driver &get_driver() const;
75 const std::string &get_base() const { return base; }
77 void add_track(Track &);
78 const std::set<Track *> &get_tracks() const { return tracks; }
79 void remove_track(Track &);
80 unsigned allocate_turnout_id(bool);
82 void add_block(Block &);
83 Block &get_block(unsigned) const;
84 const std::set<Block *> &get_blocks() const { return blocks; }
86 void create_blocks(Track &);
87 void remove_block(Block &);
89 void add_route(Route &);
90 const std::set<Route *> &get_routes() const { return routes; }
91 Route &get_route(const std::string &) const;
93 void remove_route(Route &);
95 void add_train(Train &);
96 Train &get_train(unsigned) const;
97 const std::map<unsigned, Train *> &get_trains() const { return trains; }
98 void remove_train(Train &);
100 void add_vehicle(Vehicle &);
101 void remove_vehicle(Vehicle &);
104 void emergency(const std::string &);
106 void save(const std::string &);
107 void save_trains(const std::string &);
109 void sensor_event(unsigned, bool);
112 } // namespace Marklin