]> git.tdb.fi Git - r2c2.git/blobdiff - source/libmarklin/train.h
Emit various signals from Train when it's loaded
[r2c2.git] / source / libmarklin / train.h
index 5f75a2a82bf837004352a7b537f841512a1f974d..530d0209015a6217165d5fe4217637a239aae024 100644 (file)
@@ -26,10 +26,17 @@ class Train: public sigc::trackable
 public:
        class Loader: public Msp::DataFile::BasicLoader<Train>
        {
+       private:
+               Block *prev_block;
+
        public:
                Loader(Train &);
        private:
+               void block(unsigned);
+               void block_hint(unsigned);
+               void name(const std::string &);
                void real_speed(unsigned, float, float);
+               void route(const std::string &);
        };
 
        sigc::signal<void, const std::string &> signal_name_changed;
@@ -63,7 +70,6 @@ private:
        Block *pending_block;
        unsigned target_speed;
        const Route *route;
-       Msp::Time::TimeStamp try_reserve;
        std::string status;
 
        Msp::Time::TimeStamp last_entry_time;
@@ -91,6 +97,7 @@ public:
        const std::string &get_status() const { return status; }
        const Point &get_position() const { return pos; }
        void place(Block &, unsigned);
+       bool is_placed() const { return !cur_blocks.empty(); }
        bool free_block(Block &);
        int get_entry_to_block(Block &) const;
        void tick(const Msp::Time::TimeStamp &, const Msp::Time::TimeDelta &);
@@ -100,6 +107,7 @@ private:
        void sensor_event(bool, Sensor *);
        void turnout_path_changing(unsigned, Turnout *);
        void turnout_path_changed(unsigned, Turnout *);
+       void block_reserved(const Block &, const Train *);
        unsigned reserve_more();
        void update_speed();
        float get_real_speed(unsigned) const;
@@ -107,6 +115,8 @@ private:
        void set_status(const std::string &);
        void set_position(const Block::Endpoint &);
        void release_blocks(std::list<BlockRef> &);
+       void release_blocks(std::list<BlockRef> &, std::list<BlockRef>::iterator, std::list<BlockRef>::iterator);
+       void reverse_blocks(std::list<BlockRef> &) const;
 };
 
 } // namespace Marklin