Track *track;
unsigned track_ep;
Block *link;
- unsigned paths;
Endpoint(Track *, unsigned);
private:
unsigned id;
- unsigned sensor_id;
- unsigned turnout_id;
+ unsigned sensor_addr;
+ unsigned turnout_addr;
+ bool conflict;
TrackCircuit *sensor;
std::vector<Endpoint> endpoints;
Train *train;
Block(Layout &, Track &);
~Block();
+ virtual void set_name(const std::string &);
+
private:
+ virtual void on_track_added(Track &);
virtual Validity check_validity(Track &) const;
public:
unsigned get_id() const { return id; }
- unsigned get_sensor_id() const { return sensor_id; }
- unsigned get_turnout_id() const { return turnout_id; }
- TrackCircuit &get_sensor() const { return *sensor; }
+ unsigned get_sensor_address() const { return sensor_addr; }
+ unsigned get_turnout_address() const { return turnout_addr; }
+ TrackCircuit *get_sensor() const { return sensor; }
const std::vector<Endpoint> &get_endpoints() const { return endpoints; }
const Endpoint &get_endpoint(unsigned) const;
int get_endpoint_by_link(Block &) const;
bool reserve(Train *);
Train *get_train() const { return train; }
private:
- void find_paths(const TrackIter &, unsigned);
void determine_id();
+
+public:
+ virtual Msp::DataFile::Statement save_reference() const;
};
} // namespace R2C2