X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibmarklin%2Flocomotive.h;h=4a6770ec6c9feb701165828286d49bd52b9a1801;hb=010d8321e982d1684fcbff5bf6fc2bdec7cb7bae;hp=89b275ecb0db2020cc635dc695c8853648bd1d02;hpb=7839b7c3d782abb5c98a24d51cae109407068c02;p=r2c2.git diff --git a/source/libmarklin/locomotive.h b/source/libmarklin/locomotive.h index 89b275e..4a6770e 100644 --- a/source/libmarklin/locomotive.h +++ b/source/libmarklin/locomotive.h @@ -21,34 +21,37 @@ class Reply; class Locomotive { +public: + sigc::signal signal_speed_changing; + sigc::signal signal_speed_changed; + sigc::signal signal_reverse_changed; + sigc::signal signal_function_changed; + private: const LocoType &type; - Control &control; + Control &control; unsigned addr; unsigned speed; - bool reverse; + bool reverse; unsigned funcs; public: - sigc::signal signal_speed_changing; - sigc::signal signal_speed_changed; - sigc::signal signal_function_changed; - Locomotive(const LocoType &, Control &, unsigned); const LocoType &get_type() const { return type; } - void set_speed(unsigned); - void set_reverse(bool); - void set_function(unsigned, bool); - unsigned get_address() const { return addr; } - unsigned get_speed() const { return speed; } - bool get_reverse() const { return reverse; } - bool get_function(unsigned f) const { return (funcs>>f)&1; } - void refresh_status(); + unsigned get_address() const { return addr; } + void set_speed(unsigned); + void set_reverse(bool); + void set_function(unsigned, bool); + unsigned get_speed() const { return speed; } + bool get_reverse() const { return reverse; } + bool get_function(unsigned f) const { return (funcs>>f)&1; } + unsigned get_functions() const { return funcs; } + void refresh_status(); private: - void send_command(bool); - void status_reply(const Reply &); - bool reverse_timeout(); + void send_command(bool); + void status_reply(const Reply &); + bool reverse_timeout(); }; } // namespace Marklin