X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibmarklin%2Fcontrol.h;fp=source%2Flibmarklin%2Fcontrol.h;h=61469a8ea8c289f75316943e1404fa690a2c0d65;hb=449fb5de95ddb2ac9da4bd72a1c12150505d5549;hp=1d19263fb93da651807d5b0abaaa3d0978166eb5;hpb=65cbaf88a03497df08243ac27354b0c0ea1f640b;p=r2c2.git diff --git a/source/libmarklin/control.h b/source/libmarklin/control.h index 1d19263..61469a8 100644 --- a/source/libmarklin/control.h +++ b/source/libmarklin/control.h @@ -24,8 +24,13 @@ class Reply; class Control { +public: + sigc::signal signal_power_event; + sigc::signal signal_turnout_event; + sigc::signal signal_sensor_event; + private: - int serial_fd; + int serial_fd; bool power; std::list queue; std::map turnouts; @@ -37,36 +42,30 @@ private: Msp::Time::Timer timer; public: - sigc::signal signal_power_event; - sigc::signal signal_turnout_event; - sigc::signal signal_sensor_event; - Control(); ~Control(); - void set_power(bool); - bool get_power() const { return power; } - void set_debug(bool); - const std::map &get_turnouts() const { return turnouts; } - const std::map &get_sensors() const { return sensors; } - unsigned get_queue_length() const { return queue.size(); } - void open(const std::string &); - Command &command(Cmd); - Command &command(Cmd, unsigned char); - Command &command(Cmd, const unsigned char *, unsigned); + void open(const std::string &); + void set_debug(bool); + void set_power(bool); + bool get_power() const { return power; } + Command &command(Cmd); + Command &command(Cmd, unsigned char); + Command &command(Cmd, const unsigned char *, unsigned); + unsigned get_queue_length() const { return queue.size(); } - void add_turnout(Turnout &); - Turnout &get_turnout(unsigned) const; - void add_locomotive(Locomotive &); + void add_turnout(Turnout &); + Turnout &get_turnout(unsigned) const; + const std::map &get_turnouts() const { return turnouts; } + void add_locomotive(Locomotive &); Locomotive &get_locomotive(unsigned) const; - void add_sensor(Sensor &); - Sensor &get_sensor(unsigned) const; + void add_sensor(Sensor &); + Sensor &get_sensor(unsigned) const; + const std::map &get_sensors() const { return sensors; } - void tick(); + void tick(); Msp::Time::Timer::Slot &set_timer(const Msp::Time::TimeDelta &); private: - void read_all(int, char *, int); - std::string read_reply(Cmd); void status_done(const Reply &); void event_query_done(const Reply &); void turnout_event_done(const Reply &);