X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Fdriver.h;h=a0e5cc434405a194e56099bd5e3f63dd7512e8b4;hb=862d8bea6d31e6fe9a60747e0b9559f77e72bf44;hp=ec143e83d244c24f32b308fa8d3b646f07e4d68d;hpb=d15ac13f2e170f155b4bbd124df48400c339b644;p=r2c2.git diff --git a/source/libr2c2/driver.h b/source/libr2c2/driver.h index ec143e8..a0e5cc4 100644 --- a/source/libr2c2/driver.h +++ b/source/libr2c2/driver.h @@ -1,22 +1,59 @@ #ifndef LIBR2C2_DRIVER_H_ #define LIBR2C2_DRIVER_H_ +#include #include #include +#include namespace R2C2 { +class SignalType; class TrackType; class VehicleType; class Driver { public: + class Options + { + private: + typedef std::map OptionMap; + + OptionMap opts; + + public: + Options() { } + Options(const std::string &); + + void set(const std::string &, const std::string &); + + template + T get(const std::string &k, const T &d = T()) const + { + OptionMap::const_iterator i = opts.find(k); + if(i==opts.end()) + return d; + return Msp::lexical_cast(i->second); + } + }; + + struct DetectedLocomotive + { + std::string protocol; + unsigned address; + std::string name; + }; + sigc::signal signal_power; sigc::signal signal_halt; + sigc::signal signal_locomotive_detected; + sigc::signal signal_locomotive_gone; sigc::signal signal_loco_speed; sigc::signal signal_loco_function; sigc::signal signal_turnout; + sigc::signal signal_turnout_failed; + sigc::signal signal_signal; sigc::signal signal_sensor; protected: @@ -31,16 +68,26 @@ public: virtual const char *enumerate_protocols(unsigned) const = 0; virtual unsigned get_protocol_speed_steps(const std::string &) const = 0; - virtual void add_loco(unsigned, const std::string &, const VehicleType &) = 0; + + virtual const DetectedLocomotive *enumerate_detected_locos(unsigned) const = 0; + virtual unsigned add_loco(unsigned, const std::string &, const VehicleType &) = 0; + virtual void remove_loco(unsigned) = 0; virtual void set_loco_speed(unsigned, unsigned) = 0; virtual void set_loco_reverse(unsigned, bool) = 0; virtual void set_loco_function(unsigned, unsigned, bool) = 0; - virtual void add_turnout(unsigned, const TrackType &) = 0; + virtual unsigned add_turnout(unsigned, const TrackType &) = 0; + virtual void remove_turnout(unsigned) = 0; virtual void set_turnout(unsigned, unsigned) = 0; virtual unsigned get_turnout(unsigned) const = 0; - virtual void add_sensor(unsigned) = 0; + virtual unsigned add_signal(unsigned, const SignalType &) = 0; + virtual void remove_signal(unsigned) = 0; + virtual void set_signal(unsigned, unsigned) = 0; + virtual unsigned get_signal(unsigned) const = 0; + + virtual unsigned add_sensor(unsigned) = 0; + virtual void remove_sensor(unsigned) = 0; virtual void set_sensor(unsigned, bool) = 0; virtual bool get_sensor(unsigned) const = 0;