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();
38 void route(const std::string &);
40 void train(unsigned, unsigned);
44 sigc::signal<void, Track &> signal_track_added;
45 sigc::signal<void, Track &> signal_track_removed;
46 sigc::signal<void, Route &> signal_route_added;
47 sigc::signal<void, Route &> signal_route_removed;
48 sigc::signal<void, Train &> signal_train_added;
49 sigc::signal<void, Train &> signal_train_removed;
50 sigc::signal<void, Vehicle &> signal_vehicle_added;
51 sigc::signal<void, Vehicle &> signal_vehicle_removed;
52 sigc::signal<void, Block &, Train *> signal_block_reserved;
53 sigc::signal<void, const std::string &> signal_emergency;
59 std::set<Track *> tracks;
60 std::map<std::string, Route *> routes;
61 std::set<Block *> blocks;
62 std::map<unsigned, Train *> trains;
63 std::set<Vehicle *> vehicles;
64 Msp::Time::TimeStamp last_tick;
67 Layout(Catalogue &, Driver * = 0);
70 Catalogue &get_catalogue() const { return catalogue; }
71 bool has_driver() const { return driver; }
72 Driver &get_driver() const;
73 const std::string &get_base() const { return base; }
75 void add_track(Track &);
76 const std::set<Track *> &get_tracks() const { return tracks; }
77 void remove_track(Track &);
79 void add_block(Block &);
80 Block &get_block(unsigned) const;
81 Block &get_block_by_track(const Track &) const;
82 const std::set<Block *> &get_blocks() const { return blocks; }
84 void create_blocks(const Track &);
85 void remove_block(Block &);
87 void add_route(Route &);
88 const std::map<std::string, Route *> &get_routes() const { return routes; }
89 Route &get_route(const std::string &) const;
90 void remove_route(Route &);
92 void add_train(Train &);
93 Train &get_train(unsigned) const;
94 const std::map<unsigned, Train *> &get_trains() const { return trains; }
95 void remove_train(Train &);
97 void add_vehicle(Vehicle &);
98 void remove_vehicle(Vehicle &);
101 void emergency(const std::string &);
103 void save(const std::string &);
104 void save_trains(const std::string &);
108 void sensor_event(unsigned, bool);
111 } // namespace Marklin