OpenTTD Source 20260206-master-g4d4e37dbf1
order_backup.h
Go to the documentation of this file.
1/*
2 * This file is part of OpenTTD.
3 * 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.
4 * 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.
5 * 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 <https://www.gnu.org/licenses/old-licenses/gpl-2.0>.
6 */
7
9
10#ifndef ORDER_BACKUP_H
11#define ORDER_BACKUP_H
12
13#include "core/pool_type.hpp"
14#include "group_type.h"
15#include "tile_type.h"
16#include "vehicle_type.h"
17#include "base_consist.h"
18#include "saveload/saveload.h"
19
22struct OrderBackup;
23
27extern OrderBackupPool _order_backup_pool;
29using OrderBackupPoolItem = OrderBackupPool::PoolItem<&_order_backup_pool>;
30
36private:
38 friend struct BKORChunkHandler;
39 template <typename T>
40 friend class SlOrders;
41
42 uint32_t user = 0;
44 GroupID group = GroupID::Invalid();
45
46 const Vehicle *clone = nullptr;
47 std::vector<Order> orders;
48 uint32_t old_order_index = 0;
49
50 void DoRestore(Vehicle *v);
51
54 OrderBackup(OrderBackupID index, const Vehicle *v, uint32_t user);
55
56public:
58
59 static void Backup(const Vehicle *v, uint32_t user);
60 static void Restore(Vehicle *v, uint32_t user);
61
62 static void ResetOfUser(TileIndex tile, uint32_t user);
63 static void ResetUser(uint32_t user);
64 static void Reset(TileIndex tile = INVALID_TILE, bool from_gui = true);
65
66 static void ClearGroup(GroupID group);
67 static void ClearVehicle(const Vehicle *v);
68 static void RemoveOrder(OrderType type, DestinationID destination, bool hangar);
69};
70
71#endif /* ORDER_BACKUP_H */
Properties for front vehicles/consists.
Types of a group.
Pool< OrderBackup, OrderBackupID, 1 > OrderBackupPool
The pool type for order backups.
OrderBackupPool::PoolItem<&_order_backup_pool > OrderBackupPoolItem
An item in the OrderBackupPool.
PoolID< uint8_t, struct OrderBackupIDTag, 255, 0xFF > OrderBackupID
Unique identifier for an order backup.
OrderType
Order types.
Definition order_type.h:50
Definition of Pool, structure used to access PoolItems, and PoolItem, base structure for Vehicle,...
Functions/types related to saving and loading games.
std::span< const struct SaveLoad > SaveLoadTable
A table of SaveLoad entries.
Definition saveload.h:532
Various front vehicle properties that are preserved when autoreplacing, using order-backup or switchi...
Data for backing up an order of a vehicle so it can be restored after a vehicle is rebuilt in the sam...
static void Reset(TileIndex tile=INVALID_TILE, bool from_gui=true)
Reset the OrderBackups from GUI/game logic.
static void Restore(Vehicle *v, uint32_t user)
Restore the data of this order to the given vehicle.
void DoRestore(Vehicle *v)
Restore the data of this order to the given vehicle.
static void Backup(const Vehicle *v, uint32_t user)
Create an order backup for the given vehicle.
static void ClearVehicle(const Vehicle *v)
Clear/update the (clone) vehicle from an order backup.
OrderBackup(OrderBackupID index)
Create an order backup for savegame loading.
const Vehicle * clone
Vehicle this vehicle was a clone of.
friend SaveLoadTable GetOrderBackupDescription()
Saving and loading of order backups.
Definition order_sl.cpp:296
TileIndex tile
Tile of the depot where the order was changed.
uint32_t user
The user that requested the backup.
static void ClearGroup(GroupID group)
Clear the group of all backups having this group ID.
GroupID group
The group the vehicle was part of.
friend struct BKORChunkHandler
Creating empty orders upon savegame loading.
static void ResetOfUser(TileIndex tile, uint32_t user)
Reset an OrderBackup given a tile and user.
friend OrderBackupPoolItem
Loading of order backups.
static void ResetUser(uint32_t user)
Reset an user's OrderBackup if needed.
std::vector< Order > orders
The actual orders if the vehicle was not a clone.
static void RemoveOrder(OrderType type, DestinationID destination, bool hangar)
Removes an order from all vehicles.
Templated helper to make a PoolID a single POD value.
Definition pool_type.hpp:47
Base class for all pools.
Vehicle data structure.
Types related to tiles.
StrongType::Typedef< uint32_t, struct TileIndexTag, StrongType::Compare, StrongType::Integer, StrongType::Compatible< int32_t >, StrongType::Compatible< int64_t > > TileIndex
The index/ID of a Tile.
Definition tile_type.h:92
constexpr TileIndex INVALID_TILE
The very nice invalid tile marker.
Definition tile_type.h:100
Types related to vehicles.