|
@@ -26,12 +26,27 @@ struct TempStorage {
|
|
|
static const SaveLoad _cargomonitor_pair_desc[] = {
|
|
|
SLE_VAR(TempStorage, number, SLE_UINT32),
|
|
|
SLE_VAR(TempStorage, amount, SLE_UINT32),
|
|
|
SLE_END()
|
|
|
};
|
|
|
|
|
|
static CargoMonitorID FixupCargoMonitor(CargoMonitorID number)
|
|
|
{
|
|
|
/* Between SLV_EXTEND_CARGOTYPES and SLV_FIX_CARGO_MONITOR, the
|
|
|
* CargoMonitorID structure had insufficient packing for more
|
|
|
* than 32 cargo types. Here we have to shuffle bits to account
|
|
|
* for the change.
|
|
|
* Company moved from bits 24-31 to 25-28.
|
|
|
* Cargo type increased from bits 19-23 to 19-24.
|
|
|
*/
|
|
|
SB(number, 25, 4, GB(number, 24, 4));
|
|
|
SB(number, 29, 3, 0);
|
|
|
ClrBit(number, 24);
|
|
|
return number;
|
|
|
}
|
|
|
|
|
|
/** Save the #_cargo_deliveries monitoring map. */
|
|
|
static void SaveDelivery()
|
|
|
{
|
|
|
TempStorage storage;
|
|
|
|
|
|
int i = 0;
|
|
@@ -49,18 +64,21 @@ static void SaveDelivery()
|
|
|
}
|
|
|
|
|
|
/** Load the #_cargo_deliveries monitoring map. */
|
|
|
static void LoadDelivery()
|
|
|
{
|
|
|
TempStorage storage;
|
|
|
bool fix = IsSavegameVersionBefore(SLV_FIX_CARGO_MONITOR);
|
|
|
|
|
|
ClearCargoDeliveryMonitoring();
|
|
|
for (;;) {
|
|
|
if (SlIterateArray() < 0) break;
|
|
|
SlObject(&storage, _cargomonitor_pair_desc);
|
|
|
|
|
|
if (fix) storage.number = FixupCargoMonitor(storage.number);
|
|
|
|
|
|
std::pair<CargoMonitorID, uint32> p(storage.number, storage.amount);
|
|
|
_cargo_deliveries.insert(p);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
@@ -84,18 +102,21 @@ static void SavePickup()
|
|
|
}
|
|
|
|
|
|
/** Load the #_cargo_pickups monitoring map. */
|
|
|
static void LoadPickup()
|
|
|
{
|
|
|
TempStorage storage;
|
|
|
bool fix = IsSavegameVersionBefore(SLV_FIX_CARGO_MONITOR);
|
|
|
|
|
|
ClearCargoPickupMonitoring();
|
|
|
for (;;) {
|
|
|
if (SlIterateArray() < 0) break;
|
|
|
SlObject(&storage, _cargomonitor_pair_desc);
|
|
|
|
|
|
if (fix) storage.number = FixupCargoMonitor(storage.number);
|
|
|
|
|
|
std::pair<CargoMonitorID, uint32> p(storage.number, storage.amount);
|
|
|
_cargo_pickups.insert(p);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
/** Chunk definition of the cargomonitoring maps. */
|