X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibmarklin%2Flocomotive.h;h=4a6770ec6c9feb701165828286d49bd52b9a1801;hb=dcfa1e9503b7e97b61396d7458f0b2e5896779cd;hp=a127a173c3af4a395e0dad757467c7bdc393cbfb;hpb=447d621e93e71b710fed0920b473350122426b97;p=r2c2.git diff --git a/source/libmarklin/locomotive.h b/source/libmarklin/locomotive.h index a127a17..4a6770e 100644 --- a/source/libmarklin/locomotive.h +++ b/source/libmarklin/locomotive.h @@ -1,3 +1,10 @@ +/* $Id$ + +This file is part of the MSP Märklin suite +Copyright © 2006-2009 Mikkosoft Productions, Mikko Rasa +Distributed under the GPL +*/ + #ifndef LIBMARKLIN_LOCOMOTIVE_H_ #define LIBMARKLIN_LOCOMOTIVE_H_ @@ -10,36 +17,41 @@ namespace Marklin { class Control; class LocoType; +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_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(Error, const std::string &); - bool reverse_timeout(); + void send_command(bool); + void status_reply(const Reply &); + bool reverse_timeout(); }; } // namespace Marklin