1 #ifndef LIBR2C2_TRAINROUTER_H_
2 #define LIBR2C2_TRAINROUTER_H_
5 #include <msp/datafile/objectloader.h>
15 class TrainRouter: public TrainAI
18 class Loader: public Msp::DataFile::ObjectLoader<TrainRouter>
21 Loader(TrainRouter &);
23 void route(const std::string &);
26 sigc::signal<void, const Route *> signal_route_changed;
27 sigc::signal<void, const TrackChain *> signal_arrived;
28 sigc::signal<void, const TrackChain *> signal_waypoint_reached;
39 typedef std::list<const Route *> RouteList;
44 const TrackChain *destination;
45 std::vector<const TrackChain *> waypoints;
46 std::list<Wait> waits;
47 Msp::Time::TimeDelta delay;
54 void set_priority(int);
55 int get_priority() const { return priority; }
57 bool set_route(const Route *);
58 void add_wait(Block &, Train *);
59 const Route *get_route() const;
61 void set_destination(const TrackChain &);
62 const TrackChain *get_destination() const { return destination; }
63 bool is_destination(Track &) const;
64 void add_waypoint(const TrackChain &);
65 unsigned get_n_waypoints() const { return waypoints.size(); }
66 bool is_waypoint(unsigned, Track &) const;
67 void set_departure_delay(const Msp::Time::TimeDelta &);
68 const Msp::Time::TimeDelta &get_departure_delay() const { return delay; }
70 virtual void message(const Message &);
71 virtual void tick(const Msp::Time::TimeDelta &);
73 void save(std::list<Msp::DataFile::Statement> &) const;
76 void block_reserved(Block &, Train *);
77 void train_advanced(Block &);
78 const Route *get_route_for_block(const Block &) const;
80 Route *create_lead_route(Route *, const Route *);
81 bool advance_route(RouteList::iterator &, const Block &);
82 bool is_on_route(const Block &);
84 static void create_plans(Layout &);