void route(const std::string &);
};
- sigc::signal<void, const Route *> signal_route_changed;
- sigc::signal<void, const TrackChain *> signal_arrived;
- sigc::signal<void, const TrackChain *> signal_waypoint_reached;
-
struct SequencePoint
{
Block *block;
private:
typedef std::list<const Route *> RouteList;
+ enum ArrivalState
+ {
+ ON_THE_WAY,
+ RESERVED_TO_END,
+ ARRIVED
+ };
+
+public:
+ sigc::signal<void, const Route *> signal_route_changed;
+ sigc::signal<void, const TrackChain *> signal_arrived;
+ sigc::signal<void, const TrackChain *> signal_waypoint_reached;
+
+private:
int priority;
RouteList routes;
- unsigned arriving;
+ RouteList::iterator reserving_route;
+ ArrivalState arrival;
const TrackChain *destination;
std::vector<const TrackChain *> waypoints;
bool destination_changed;
unsigned current_sequence;
bool sequence_check_pending;
Msp::Time::TimeDelta delay;
+ Msp::Time::TimeDelta duration;
Msp::RefPtr<TrainRoutePlanner> planner;
public:
const TrainRouteMetric &get_metric(int = -1) const;
void set_departure_delay(const Msp::Time::TimeDelta &);
const Msp::Time::TimeDelta &get_departure_delay() const { return delay; }
+ void set_trip_duration(const Msp::Time::TimeDelta &);
+ const Msp::Time::TimeDelta &get_trip_duration() const { return duration; }
virtual void message(const Message &);
virtual void tick(const Msp::Time::TimeDelta &);
private:
void block_reserved(Block &, Train *);
void train_advanced(Block &);
- const Route *get_route_for_block(const Block &) const;
+ void train_rear_advanced(Block &);
void create_metrics();
Route *create_lead_route(Route *, const Route *);
- bool advance_route(RouteList::iterator &, const Block &);
- bool is_on_route(const Block &);
+ bool is_valid_for_track(const Route &, Track &) const;
+ bool advance_to_track(RouteList::iterator &, Track &);
static void start_planning(Layout &);
};