mirror of https://github.com/OpenTTD/OpenTTD
(svn r11184) -Codechange: cleanup the code related to backup orders.
parent
e67b985bfa
commit
beeae81f60
|
@ -305,7 +305,7 @@ static void AiRestoreVehicleOrders(Vehicle *v, BackuppedOrders *bak)
|
||||||
static void AiHandleReplaceTrain(Player *p)
|
static void AiHandleReplaceTrain(Player *p)
|
||||||
{
|
{
|
||||||
const Vehicle* v = p->ai.cur_veh;
|
const Vehicle* v = p->ai.cur_veh;
|
||||||
BackuppedOrders orderbak[1];
|
BackuppedOrders orderbak;
|
||||||
EngineID veh;
|
EngineID veh;
|
||||||
|
|
||||||
// wait until the vehicle reaches the depot.
|
// wait until the vehicle reaches the depot.
|
||||||
|
@ -318,13 +318,13 @@ static void AiHandleReplaceTrain(Player *p)
|
||||||
if (veh != INVALID_ENGINE) {
|
if (veh != INVALID_ENGINE) {
|
||||||
TileIndex tile;
|
TileIndex tile;
|
||||||
|
|
||||||
BackupVehicleOrders(v, orderbak);
|
BackupVehicleOrders(v, &orderbak);
|
||||||
tile = v->tile;
|
tile = v->tile;
|
||||||
|
|
||||||
if (CmdSucceeded(DoCommand(0, v->index, 2, DC_EXEC, CMD_SELL_RAIL_WAGON)) &&
|
if (CmdSucceeded(DoCommand(0, v->index, 2, DC_EXEC, CMD_SELL_RAIL_WAGON)) &&
|
||||||
CmdSucceeded(DoCommand(tile, veh, 0, DC_EXEC, CMD_BUILD_RAIL_VEHICLE))) {
|
CmdSucceeded(DoCommand(tile, veh, 0, DC_EXEC, CMD_BUILD_RAIL_VEHICLE))) {
|
||||||
VehicleID veh = _new_vehicle_id;
|
VehicleID veh = _new_vehicle_id;
|
||||||
AiRestoreVehicleOrders(GetVehicle(veh), orderbak);
|
AiRestoreVehicleOrders(GetVehicle(veh), &orderbak);
|
||||||
DoCommand(0, veh, 0, DC_EXEC, CMD_START_STOP_TRAIN);
|
DoCommand(0, veh, 0, DC_EXEC, CMD_START_STOP_TRAIN);
|
||||||
|
|
||||||
DoCommand(0, veh, _ai_service_interval, DC_EXEC, CMD_CHANGE_SERVICE_INT);
|
DoCommand(0, veh, _ai_service_interval, DC_EXEC, CMD_CHANGE_SERVICE_INT);
|
||||||
|
|
|
@ -95,7 +95,7 @@ void CcBuildAircraft(bool success, TileIndex tile, uint32 p1, uint32 p2)
|
||||||
|
|
||||||
if (v->tile == _backup_orders_tile) {
|
if (v->tile == _backup_orders_tile) {
|
||||||
_backup_orders_tile = 0;
|
_backup_orders_tile = 0;
|
||||||
RestoreVehicleOrders(v, _backup_orders_data);
|
RestoreVehicleOrders(v);
|
||||||
}
|
}
|
||||||
ShowVehicleViewWindow(v);
|
ShowVehicleViewWindow(v);
|
||||||
}
|
}
|
||||||
|
|
|
@ -928,7 +928,7 @@ static void DepotWndProc(Window *w, WindowEvent *e)
|
||||||
|
|
||||||
if (is_engine) {
|
if (is_engine) {
|
||||||
_backup_orders_tile = v->tile;
|
_backup_orders_tile = v->tile;
|
||||||
BackupVehicleOrders(v, _backup_orders_data);
|
BackupVehicleOrders(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (v->type) {
|
switch (v->type) {
|
||||||
|
|
12
src/order.h
12
src/order.h
|
@ -116,18 +116,18 @@ struct Order : PoolItem<Order, OrderID, &_Order_pool> {
|
||||||
void FreeChain();
|
void FreeChain();
|
||||||
};
|
};
|
||||||
|
|
||||||
#define MAX_BACKUP_ORDER_COUNT 40
|
|
||||||
|
|
||||||
struct BackuppedOrders {
|
struct BackuppedOrders {
|
||||||
|
BackuppedOrders() : order(NULL) { }
|
||||||
|
|
||||||
VehicleID clone;
|
VehicleID clone;
|
||||||
VehicleOrderID orderindex;
|
VehicleOrderID orderindex;
|
||||||
Order order[MAX_BACKUP_ORDER_COUNT + 1];
|
Order *order;
|
||||||
uint16 service_interval;
|
uint16 service_interval;
|
||||||
char name[32];
|
char name[32];
|
||||||
};
|
};
|
||||||
|
|
||||||
VARDEF TileIndex _backup_orders_tile;
|
VARDEF TileIndex _backup_orders_tile;
|
||||||
VARDEF BackuppedOrders _backup_orders_data[1];
|
VARDEF BackuppedOrders _backup_orders_data;
|
||||||
|
|
||||||
static inline VehicleOrderID GetMaxOrderIndex()
|
static inline VehicleOrderID GetMaxOrderIndex()
|
||||||
{
|
{
|
||||||
|
@ -200,8 +200,8 @@ static inline Order UnpackOrder(uint32 packed)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Functions */
|
/* Functions */
|
||||||
void BackupVehicleOrders(const Vehicle *v, BackuppedOrders *order);
|
void BackupVehicleOrders(const Vehicle *v, BackuppedOrders *order = &_backup_orders_data);
|
||||||
void RestoreVehicleOrders(const Vehicle* v, const BackuppedOrders* order);
|
void RestoreVehicleOrders(const Vehicle *v, const BackuppedOrders *order = &_backup_orders_data);
|
||||||
void RemoveOrderFromAllVehicles(OrderType type, DestinationID destination);
|
void RemoveOrderFromAllVehicles(OrderType type, DestinationID destination);
|
||||||
void InvalidateVehicleOrder(const Vehicle *v);
|
void InvalidateVehicleOrder(const Vehicle *v);
|
||||||
bool VehicleHasDepotOrders(const Vehicle *v);
|
bool VehicleHasDepotOrders(const Vehicle *v);
|
||||||
|
|
|
@ -317,10 +317,6 @@ CommandCost CmdInsertOrder(TileIndex tile, uint32 flags, uint32 p1, uint32 p2)
|
||||||
|
|
||||||
if (!HasOrderPoolFree(1)) return_cmd_error(STR_8831_NO_MORE_SPACE_FOR_ORDERS);
|
if (!HasOrderPoolFree(1)) return_cmd_error(STR_8831_NO_MORE_SPACE_FOR_ORDERS);
|
||||||
|
|
||||||
/* XXX - This limit is only here because the backuppedorders can't
|
|
||||||
* handle any more then this.. */
|
|
||||||
if (v->num_orders >= MAX_BACKUP_ORDER_COUNT) return_cmd_error(STR_8832_TOO_MANY_ORDERS);
|
|
||||||
|
|
||||||
if (v->type == VEH_SHIP &&
|
if (v->type == VEH_SHIP &&
|
||||||
IsHumanPlayer(v->owner) &&
|
IsHumanPlayer(v->owner) &&
|
||||||
!_patches.new_pathfinding_all) {
|
!_patches.new_pathfinding_all) {
|
||||||
|
@ -920,6 +916,10 @@ CommandCost CmdOrderRefit(TileIndex tile, uint32 flags, uint32 p1, uint32 p2)
|
||||||
*/
|
*/
|
||||||
void BackupVehicleOrders(const Vehicle *v, BackuppedOrders *bak)
|
void BackupVehicleOrders(const Vehicle *v, BackuppedOrders *bak)
|
||||||
{
|
{
|
||||||
|
/* Make sure we always have freed the stuff */
|
||||||
|
free(bak->order);
|
||||||
|
bak->order = NULL;
|
||||||
|
|
||||||
/* Save general info */
|
/* Save general info */
|
||||||
bak->orderindex = v->cur_order_index;
|
bak->orderindex = v->cur_order_index;
|
||||||
bak->service_interval = v->service_interval;
|
bak->service_interval = v->service_interval;
|
||||||
|
@ -939,13 +939,21 @@ void BackupVehicleOrders(const Vehicle *v, BackuppedOrders *bak)
|
||||||
bak->clone = u->index;
|
bak->clone = u->index;
|
||||||
} else {
|
} else {
|
||||||
/* Else copy the orders */
|
/* Else copy the orders */
|
||||||
Order *order, *dest;
|
|
||||||
|
|
||||||
dest = bak->order;
|
|
||||||
|
|
||||||
/* We do not have shared orders */
|
/* We do not have shared orders */
|
||||||
bak->clone = INVALID_VEHICLE;
|
bak->clone = INVALID_VEHICLE;
|
||||||
|
|
||||||
|
|
||||||
|
/* Count the number of orders */
|
||||||
|
uint cnt = 0;
|
||||||
|
const Order *order;
|
||||||
|
FOR_VEHICLE_ORDERS(v, order) cnt++;
|
||||||
|
|
||||||
|
/* Allocate memory for the orders plus an end-of-orders marker */
|
||||||
|
bak->order = MallocT<Order>(cnt + 1);
|
||||||
|
|
||||||
|
Order *dest = bak->order;
|
||||||
|
|
||||||
/* Copy the orders */
|
/* Copy the orders */
|
||||||
FOR_VEHICLE_ORDERS(v, order) {
|
FOR_VEHICLE_ORDERS(v, order) {
|
||||||
*dest = *order;
|
*dest = *order;
|
||||||
|
@ -963,10 +971,8 @@ void BackupVehicleOrders(const Vehicle *v, BackuppedOrders *bak)
|
||||||
*/
|
*/
|
||||||
void RestoreVehicleOrders(const Vehicle *v, const BackuppedOrders *bak)
|
void RestoreVehicleOrders(const Vehicle *v, const BackuppedOrders *bak)
|
||||||
{
|
{
|
||||||
uint i;
|
|
||||||
|
|
||||||
/* If we have a custom name, process that */
|
/* If we have a custom name, process that */
|
||||||
if (bak->name[0] != 0) {
|
if (!StrEmpty(bak->name)) {
|
||||||
_cmd_text = bak->name;
|
_cmd_text = bak->name;
|
||||||
DoCommandP(0, v->index, 0, NULL, CMD_NAME_VEHICLE);
|
DoCommandP(0, v->index, 0, NULL, CMD_NAME_VEHICLE);
|
||||||
}
|
}
|
||||||
|
@ -981,7 +987,7 @@ void RestoreVehicleOrders(const Vehicle* v, const BackuppedOrders* bak)
|
||||||
* order number is one more than the current amount of orders, and because
|
* order number is one more than the current amount of orders, and because
|
||||||
* in network the commands are queued before send, the second insert always
|
* in network the commands are queued before send, the second insert always
|
||||||
* fails in test mode. By bypassing the test-mode, that no longer is a problem. */
|
* fails in test mode. By bypassing the test-mode, that no longer is a problem. */
|
||||||
for (i = 0; bak->order[i].IsValid(); i++) {
|
for (uint i = 0; bak->order[i].IsValid(); i++) {
|
||||||
if (!DoCommandP(0, v->index + (i << 16), PackOrder(&bak->order[i]), NULL, CMD_INSERT_ORDER | CMD_NO_TEST_IF_IN_NETWORK))
|
if (!DoCommandP(0, v->index + (i << 16), PackOrder(&bak->order[i]), NULL, CMD_INSERT_ORDER | CMD_NO_TEST_IF_IN_NETWORK))
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -128,7 +128,7 @@ void CcBuildRoadVeh(bool success, TileIndex tile, uint32 p1, uint32 p2)
|
||||||
v = GetVehicle(_new_vehicle_id);
|
v = GetVehicle(_new_vehicle_id);
|
||||||
if (v->tile == _backup_orders_tile) {
|
if (v->tile == _backup_orders_tile) {
|
||||||
_backup_orders_tile = 0;
|
_backup_orders_tile = 0;
|
||||||
RestoreVehicleOrders(v, _backup_orders_data);
|
RestoreVehicleOrders(v);
|
||||||
}
|
}
|
||||||
ShowVehicleViewWindow(v);
|
ShowVehicleViewWindow(v);
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,7 +35,7 @@ void CcBuildShip(bool success, TileIndex tile, uint32 p1, uint32 p2)
|
||||||
v = GetVehicle(_new_vehicle_id);
|
v = GetVehicle(_new_vehicle_id);
|
||||||
if (v->tile == _backup_orders_tile) {
|
if (v->tile == _backup_orders_tile) {
|
||||||
_backup_orders_tile = 0;
|
_backup_orders_tile = 0;
|
||||||
RestoreVehicleOrders(v, _backup_orders_data);
|
RestoreVehicleOrders(v);
|
||||||
}
|
}
|
||||||
ShowVehicleViewWindow(v);
|
ShowVehicleViewWindow(v);
|
||||||
}
|
}
|
||||||
|
|
|
@ -54,7 +54,7 @@ void CcBuildLoco(bool success, TileIndex tile, uint32 p1, uint32 p2)
|
||||||
v = GetVehicle(_new_vehicle_id);
|
v = GetVehicle(_new_vehicle_id);
|
||||||
if (tile == _backup_orders_tile) {
|
if (tile == _backup_orders_tile) {
|
||||||
_backup_orders_tile = 0;
|
_backup_orders_tile = 0;
|
||||||
RestoreVehicleOrders(v, _backup_orders_data);
|
RestoreVehicleOrders(v);
|
||||||
}
|
}
|
||||||
ShowVehicleViewWindow(v);
|
ShowVehicleViewWindow(v);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue