1 #ifndef LIBR2C2_DUMMY_H_
2 #define LIBR2C2_DUMMY_H_
5 #include <msp/time/timedelta.h>
6 #include <msp/time/timestamp.h>
11 class Dummy: public Driver
18 Msp::Time::TimeStamp timeout;
28 std::map<unsigned, TurnoutState> turnouts;
29 std::map<unsigned, LocoState> locos;
30 std::map<unsigned, bool> sensors;
31 Msp::Time::TimeDelta turnout_delay;
34 Dummy(const std::string &);
36 virtual void set_power(bool);
37 virtual bool get_power() const { return power; }
38 virtual void halt(bool) { }
39 virtual bool is_halted() const { return false; }
41 virtual const char *enumerate_protocols(unsigned) const;
42 virtual unsigned get_protocol_speed_steps(const std::string &) const;
43 virtual unsigned add_loco(unsigned a, const std::string &, const VehicleType &) { return a; }
44 virtual void remove_loco(unsigned) { }
45 virtual void set_loco_speed(unsigned, unsigned);
46 virtual void set_loco_reverse(unsigned, bool);
47 virtual void set_loco_function(unsigned, unsigned, bool);
49 virtual unsigned add_turnout(unsigned, const TrackType &);
50 virtual void remove_turnout(unsigned) { }
51 virtual void set_turnout(unsigned, unsigned);
52 virtual unsigned get_turnout(unsigned) const;
54 virtual unsigned add_signal(unsigned a, const SignalType &) { return a; }
55 virtual void remove_signal(unsigned) { }
56 virtual void set_signal(unsigned, unsigned) { }
57 virtual unsigned get_signal(unsigned) const { return 0; }
59 virtual unsigned add_sensor(unsigned a) { return a; }
60 virtual void remove_sensor(unsigned) { }
61 virtual void set_sensor(unsigned, bool);
62 virtual bool get_sensor(unsigned) const;
65 virtual void flush() { }