namespace Marklin {
+class ArticleNumber;
class Route;
class Timetable;
class Vehicle;
void real_speed(unsigned, float, float);
void route(const std::string &);
void timetable();
- void vehicle(unsigned);
+ void vehicle(ArticleNumber);
};
sigc::signal<void, const std::string &> signal_name_changed;
int priority;
const Train *yielding_to;
std::vector<Vehicle *> vehicles;
- BlockList cur_blocks;
- BlockList rsv_blocks;
+ BlockList blocks;
+ BlockList::iterator cur_blocks_end;
+ BlockList::iterator clear_blocks_end;
Block *pending_block;
bool reserving;
bool advancing;
void set_timetable(Timetable *);
Timetable *get_timetable() { return timetable; }
- void set_route(const Route *);
- void go_to(Track &);
+ bool set_route(const Route *);
+ bool go_to(Track &);
bool divert(Track &);
const Route *get_route() const;
void place(Block &, unsigned);
void unplace();
- bool is_placed() const { return !cur_blocks.empty(); }
+ bool is_placed() const { return !blocks.empty(); }
bool free_block(Block &);
void free_noncritical_blocks();
int get_entry_to_block(Block &) const;
void loco_speed_event(unsigned, unsigned, bool);
void loco_func_event(unsigned, unsigned, bool);
void sensor_event(unsigned, bool);
- void turnout_event(unsigned, bool);
+ void turnout_path_changed(Track &);
void halt_event(bool);
void block_reserved(const Block &, const Train *);
- unsigned reserve_more();
+ void reserve_more();
+ void check_turnout_paths(bool);
float get_reserved_distance_until(const Block *, bool) const;
float get_real_speed(unsigned) const;
unsigned find_speed(float) const;
float get_travel_speed() const;
void set_status(const std::string &);
- void release_blocks(BlockList &);
- void release_blocks(BlockList &, BlockList::iterator, BlockList::iterator);
+ void release_blocks();
+ void release_blocks(BlockList::iterator, BlockList::iterator);
void reverse_blocks(BlockList &) const;
bool advance_route(std::list<RouteRef>::iterator &, Track &);
Route *create_lead_route(Route *, const Route *);
- bool is_valid_diversion(const Route &, Track &, unsigned);
+ bool is_valid_diversion(const Route &, const TrackIter &);
};
} // namespace Marklin