]> git.tdb.fi Git - r2c2.git/blobdiff - source/libmarklin/train.h
Add networking library and a remote control program
[r2c2.git] / source / libmarklin / train.h
index d95d4c43ea50b3e152d85bdc545fcccab70572e7..9b6344c2fa104066bbb782f0dc6e87bfa3fcd832 100644 (file)
@@ -28,6 +28,10 @@ public:
                Loader(Train &);
        };
 
+       sigc::signal<void, const std::string &> signal_name_changed;
+       sigc::signal<void, unsigned> signal_target_speed_changed;
+       sigc::signal<void, const std::string &> signal_status_changed;
+
 private:
        struct BlockRef
        {
@@ -59,15 +63,14 @@ private:
        Point pos;
 
 public:
-       sigc::signal<void, const std::string &> signal_name_changed;
-       sigc::signal<void, const std::string &> signal_status_changed;
-
        Train(TrafficManager &, Locomotive &);
 
        void set_name(const std::string &);
        void set_speed(unsigned);
+       void set_reverse(bool);
        const std::string &get_name() const { return name; }
        Locomotive &get_locomotive() const { return loco; }
+       unsigned get_target_speed() const { return target_speed; }
        const std::string &get_status() const { return status; }
        const Point &get_position() const { return pos; }
        void place(Block *, unsigned);
@@ -75,6 +78,7 @@ public:
        void tick(const Msp::Time::TimeStamp &, const Msp::Time::TimeDelta &);
        void save(std::list<Msp::DataFile::Statement> &) const;
 private:
+       void locomotive_reverse_changed(bool);
        void sensor_event(bool, Sensor *);
        void turnout_route_changing(unsigned, Turnout *);
        void turnout_route_changed(unsigned, Turnout *);