2017-02-22 20:51:45 +00:00
|
|
|
/*
|
|
|
|
* This file is part of OpenTTD.
|
|
|
|
* OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
|
|
|
|
* OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
* See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** @file order_cmd.h Functions related to order commands. */
|
|
|
|
|
|
|
|
#ifndef ORDER_CMD_H
|
|
|
|
#define ORDER_CMD_H
|
|
|
|
|
|
|
|
#include "order_base.h"
|
|
|
|
#include "order_func.h"
|
|
|
|
#include "vehicle_base.h"
|
|
|
|
|
2019-08-27 16:14:49 +00:00
|
|
|
void UpdateOrderDestinationRefcount(const Order *order, VehicleType type, Owner owner, int delta);
|
|
|
|
|
|
|
|
inline void RegisterOrderDestination(const Order *order, VehicleType type, Owner owner)
|
|
|
|
{
|
|
|
|
if (_order_destination_refcount_map_valid) UpdateOrderDestinationRefcount(order, type, owner, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void UnregisterOrderDestination(const Order *order, VehicleType type, Owner owner)
|
|
|
|
{
|
|
|
|
if (_order_destination_refcount_map_valid) UpdateOrderDestinationRefcount(order, type, owner, -1);
|
|
|
|
}
|
|
|
|
|
2017-02-22 20:51:45 +00:00
|
|
|
/**
|
|
|
|
* Removes all orders from a vehicle for which order_predicate returns true.
|
|
|
|
* Handles timetable updating, removing implicit orders correctly, etc.
|
|
|
|
* @param v The vehicle.
|
|
|
|
* @param order_predicate Functor with signature: bool (const Order *)
|
|
|
|
*/
|
|
|
|
template <typename F> void RemoveVehicleOrdersIf(Vehicle * const v, F order_predicate) {
|
|
|
|
/* Clear the order from the order-list */
|
|
|
|
int id = -1;
|
2021-01-30 23:24:40 +00:00
|
|
|
for(Order *order = v->GetFirstOrder(); order != nullptr; order = order->next) {
|
2017-02-22 20:51:45 +00:00
|
|
|
id++;
|
|
|
|
restart:
|
|
|
|
|
|
|
|
if (order_predicate(const_cast<const Order *>(order))) {
|
|
|
|
/* We want to clear implicit orders, but we don't want to make them
|
|
|
|
* dummy orders. They should just vanish. Also check the actual order
|
|
|
|
* type as ot is currently OT_GOTO_STATION. */
|
|
|
|
if (order->IsType(OT_IMPLICIT)) {
|
|
|
|
order = order->next; // DeleteOrder() invalidates current order
|
|
|
|
DeleteOrder(v, id);
|
2019-04-11 17:14:13 +00:00
|
|
|
if (order != nullptr) goto restart;
|
2017-02-22 20:51:45 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2019-08-27 16:14:49 +00:00
|
|
|
UnregisterOrderDestination(order, v->type, v->owner);
|
|
|
|
|
2017-02-22 20:51:45 +00:00
|
|
|
/* Clear wait time */
|
2017-12-18 01:26:27 +00:00
|
|
|
if (!order->IsType(OT_CONDITIONAL)) v->orders.list->UpdateTotalDuration(-order->GetWaitTime());
|
2017-02-22 20:51:45 +00:00
|
|
|
if (order->IsWaitTimetabled()) {
|
2017-12-18 01:26:27 +00:00
|
|
|
if (!order->IsType(OT_CONDITIONAL)) v->orders.list->UpdateTimetableDuration(-order->GetTimetabledWait());
|
2017-02-22 20:51:45 +00:00
|
|
|
order->SetWaitTimetabled(false);
|
|
|
|
}
|
|
|
|
order->SetWaitTime(0);
|
|
|
|
|
|
|
|
/* Clear order, preserving travel time */
|
|
|
|
bool travel_timetabled = order->IsTravelTimetabled();
|
|
|
|
order->MakeDummy();
|
|
|
|
order->SetTravelTimetabled(travel_timetabled);
|
|
|
|
|
2019-04-11 17:14:13 +00:00
|
|
|
for (const Vehicle *w = v->FirstShared(); w != nullptr; w = w->NextShared()) {
|
2017-02-22 20:51:45 +00:00
|
|
|
/* In GUI, simulate by removing the order and adding it back */
|
2020-10-12 22:48:54 +00:00
|
|
|
InvalidateVehicleOrder(w, id | (INVALID_VEH_ORDER_ID << 16));
|
|
|
|
InvalidateVehicleOrder(w, (INVALID_VEH_ORDER_ID << 16) | id);
|
2017-02-22 20:51:45 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* ORDER_CMD_H */
|