destination_changed = true;
}
+void TrainRouter::set_trip_duration(const Time::TimeDelta &d)
+{
+ duration = d;
+}
+
void TrainRouter::message(const Message &msg)
{
if(msg.type=="set-route")
}
else if(msg.type=="set-departure-delay")
set_departure_delay(msg.value.value<Time::TimeDelta>());
+ else if(msg.type=="set-trip-duration")
+ set_trip_duration(msg.value.value<Time::TimeDelta>());
}
void TrainRouter::tick(const Time::TimeDelta &dt)
if(delay)
{
delay -= dt;
- if(delay<=Time::zero)
+ if(delay<Time::zero)
+ {
+ duration = max(duration+delay, Time::zero);
delay = Time::zero;
+ }
}
+ else if(duration)
+ duration = max(duration-dt, Time::zero);
if(destination_changed && !planner)
start_planning(train.get_layout());