1 #ifndef LIBR2C2_BLOCK_H_
2 #define LIBR2C2_BLOCK_H_
26 Endpoint(Track *, unsigned);
28 TrackIter track_iter() const;
31 sigc::signal<void, Train *> signal_reserved;
39 std::set<Track *> tracks;
40 std::vector<Endpoint> endpoints;
44 Block(Layout &, Track &);
47 unsigned get_id() const { return id; }
48 unsigned get_sensor_id() const { return sensor_id; }
49 unsigned get_turnout_id() const { return turnout_id; }
50 TrackCircuit &get_sensor() const { return *sensor; }
51 const std::set<Track *> &get_tracks() const { return tracks; }
52 bool has_track(Track &) const;
53 const std::vector<Endpoint> &get_endpoints() const { return endpoints; }
54 const Endpoint &get_endpoint(unsigned) const;
55 int get_endpoint_by_link(Block &) const;
56 float get_path_length(unsigned, const Route * = 0) const;
57 void check_link(Block &);
58 void break_link(Block &);
59 Block *get_link(unsigned) const;
60 bool reserve(Train *);
61 Train *get_train() const { return train; }
63 void find_paths(const TrackIter &, unsigned);