11#include "../void_map.h"
12#include "../signs_base.h"
13#include "../depot_base.h"
15#include "../gamelog_internal.h"
16#include "../network/network.h"
17#include "../network/network_func.h"
18#include "../gfxinit.h"
19#include "../viewport_func.h"
20#include "../viewport_kdtree.h"
21#include "../industry.h"
22#include "../clear_map.h"
23#include "../vehicle_func.h"
24#include "../string_func.h"
25#include "../roadveh.h"
26#include "../roadveh_cmd.h"
28#include "../station_base.h"
29#include "../waypoint_base.h"
30#include "../roadstop_base.h"
31#include "../tunnelbridge_map.h"
32#include "../pathfinder/yapf/yapf_cache.h"
33#include "../elrail_func.h"
34#include "../signs_func.h"
35#include "../aircraft.h"
36#include "../object_map.h"
37#include "../object_base.h"
38#include "../tree_map.h"
39#include "../company_func.h"
40#include "../road_cmd.h"
41#include "../ai/ai.hpp"
42#include "../script/script_gui.h"
43#include "../game/game.hpp"
45#include "../economy_base.h"
46#include "../animated_tile_map.h"
47#include "../animated_tile_func.h"
48#include "../subsidy_base.h"
49#include "../subsidy_func.h"
51#include "../newgrf_station.h"
52#include "../engine_func.h"
53#include "../rail_gui.h"
54#include "../core/backup_type.hpp"
55#include "../smallmap_gui.h"
56#include "../news_func.h"
57#include "../order_backup.h"
59#include "../disaster_vehicle.h"
62#include "../timer/timer.h"
63#include "../timer/timer_game_calendar.h"
64#include "../timer/timer_game_economy.h"
65#include "../timer/timer_game_tick.h"
71#include "../safeguards.h"
91 if (include_invalid_water_class) {
108 bool has_water =
false;
109 bool has_canal =
false;
110 bool has_river =
false;
119 }
else if (!
IsLock(neighbour)) {
143 if (!has_water && !has_canal && !has_river && include_invalid_water_class) {
148 if (has_river && !has_canal) {
150 }
else if (has_canal || !has_water) {
157static void ConvertTownOwner()
159 for (
auto tile :
Map::Iterate()) {
177static void UpdateExclusiveRights()
193static const uint8_t convert_currency[] = {
202static void UpdateCurrencies()
210static void UpdateVoidTiles()
218 return rt >= min ? (
RailType)(rt + 1): rt;
229 UpdateAllTextEffectVirtCoords();
230 RebuildViewportKdtree();
233void ClearAllCachedNames()
235 ClearAllStationCachedNames();
237 ClearAllIndustryCachedNames();
256 ClearAllCachedNames();
258 ResetViewportAfterLoadGame();
276 if (i->psa !=
nullptr) {
277 i->psa->feature = GSF_INDUSTRIES;
278 i->psa->tile = i->location.tile;
282 if (s->airport.psa !=
nullptr) {
283 s->airport.psa->feature = GSF_AIRPORTS;
284 s->airport.psa->tile = s->airport.tile;
288 for (
auto &it : t->psa_list) {
294 if (rv->IsFrontEngine()) {
317typedef void (CDECL *SignalHandlerPointer)(int);
318static SignalHandlerPointer _prev_segfault =
nullptr;
319static SignalHandlerPointer _prev_abort =
nullptr;
320static SignalHandlerPointer _prev_fpe =
nullptr;
340 signal(SIGSEGV, _prev_segfault);
341 signal(SIGABRT, _prev_abort);
342 signal(SIGFPE, _prev_fpe);
369 message.reserve(1024);
370 message +=
"Loading your savegame caused OpenTTD to crash.\n";
376 "This is most likely caused by a missing NewGRF or a NewGRF that\n"
377 "has been loaded as replacement for a missing NewGRF. OpenTTD\n"
378 "cannot easily determine whether a replacement NewGRF is of a newer\n"
379 "or older version.\n"
380 "It will load a NewGRF with the same GRF ID as the missing NewGRF.\n"
381 "This means that if the author makes incompatible NewGRFs with the\n"
382 "same GRF ID, OpenTTD cannot magically do the right thing. In most\n"
383 "cases, OpenTTD will load the savegame and not crash, but this is an\n"
385 "Please load the savegame with the appropriate NewGRFs installed.\n"
386 "The missing/compatible NewGRFs are:\n";
391 fmt::format_to(std::back_inserter(message),
"NewGRF {:08X} (checksum {}) not found.\n Loaded NewGRF \"{}\" (checksum {}) with same GRF ID instead.\n",
395 fmt::format_to(std::back_inserter(message),
"NewGRF {:08X} ({}) not found; checksum {}.\n",
396 std::byteswap(c->ident.grfid), c->filename,
FormatArrayAsHex(c->ident.md5sum));
401 "This is probably caused by a corruption in the savegame.\n"
402 "Please file a bug report and attach this savegame.\n";
407 SignalHandlerPointer call =
nullptr;
409 case SIGSEGV: call = _prev_segfault;
break;
410 case SIGABRT: call = _prev_abort;
break;
411 case SIGFPE: call = _prev_fpe;
break;
412 default: NOT_REACHED();
414 if (call !=
nullptr) call(signum);
463 t.
m3() = (hasroad ? bits : 0);
483 int entry_x = v->
x_pos;
484 int entry_y = v->
y_pos;
488 case DIR_SW: entry_x &= ~TILE_UNIT_MASK;
break;
489 case DIR_SE: entry_y &= ~TILE_UNIT_MASK;
break;
491 default: NOT_REACHED();
501 if (middle_z == entry_z)
return 0;
518 if (v->IsGroundVehicle()) {
570 if (_cur_tileloop_tile == 0) _cur_tileloop_tile =
TileIndex{1};
578 RebuildStationKdtree();
581 RebuildViewportKdtree();
588 Debug(net, 0,
"The loading savegame was paused due to an error state");
589 Debug(net, 0,
" This savegame cannot be used for multiplayer");
612 st->train_station.w = st->train_station.h = 0;
616 if (t.m5() > 7)
continue;
621 assert(dx >= 0 && dy >= 0);
632 t.height() =
GB(t.type(), 0, 4);
633 SB(t.type(), 0, 2,
GB(t.m6(), 0, 2));
636 SB(t.type(), 2, 2,
GB(t.m6(), 6, 2));
639 SB(t.type(), 2, 2, 0);
668 if (!c->name.empty()) c->name_1 = STR_SV_UNNAMED;
676 if (!st->name.empty()) st->string_id = STR_SV_STNAME_FALLBACK;
691 if (st->airport.tile == 0) st->airport.tile =
INVALID_TILE;
692 if (st->train_station.tile == 0) st->train_station.tile =
INVALID_TILE;
839 cp->front->cargo_payment = cp;
840 cp->current_station = cp->front->last_station_visited;
847 static constexpr uint8_t WBL_COAST_FLAG = 0;
852 switch (
GB(t.m5(), 4, 4)) {
879 st = StationType::Rail;
882 st = StationType::Airport;
885 st = StationType::Truck;
888 st = StationType::Bus;
890 }
else if (gfx == 75) {
891 st = StationType::Oilrig;
894 st = StationType::Dock;
896 }
else if (gfx == 82) {
897 st = StationType::Buoy;
900 st = StationType::Airport;
903 st = StationType::Truck;
906 st = StationType::Bus;
938 bst->
rect.BeforeAddTile(t, StationRect::ADD_FORCE);
945 case StationType::Truck:
946 case StationType::Bus:
967 case StationType::Oilrig: {
1007 t.m4() |= (t.m2() << 4);
1035 c->engine_renew_list =
nullptr;
1036 c->settings.engine_renew =
false;
1037 c->settings.engine_renew_months = 6;
1038 c->settings.engine_renew_money = 100000;
1060 uint tmp =
GB(t.m4(), 0, 4);
1061 SB(t.m4(), 0, 4,
GB(t.m2(), 0, 4));
1062 SB(t.m2(), 0, 4, tmp);
1063 }
else if (
HasBit(t.m5(), 2)) {
1073 Swap(t.m3(), t.m4());
1087 SB(t.m5(), 6, 2,
GB(t.m5(), 4, 2));
1091 SB(t.m4(), 0, 4,
GB(t.m5(), 0, 4));
1092 SB(t.m4(), 4, 4, 0);
1093 SB(t.m6(), 2, 4, 0);
1096 SB(t.m4(), 5, 2,
GB(t.m5(), 2, 2));
1100 SB(t.m7(), 6, 2, 1);
1111 SB(t.m7(), 6, 2, 1);
1127 if (fix_roadtypes)
SB(t.m7(), 6, 2, (
RoadTypes)
GB(t.m7(), 5, 3));
1128 SB(t.m7(), 5, 1,
GB(t.m3(), 7, 1));
1132 SB(t.m7(), 0, 4,
GB(t.m3(), 0, 4));
1133 SB(t.m6(), 3, 3,
GB(t.m3(), 4, 3));
1134 SB(t.m3(), 0, 4,
GB(t.m4(), 4, 4));
1135 SB(t.m3(), 4, 4,
GB(t.m5(), 0, 4));
1136 SB(t.m5(), 0, 4,
GB(t.m4(), 0, 4));
1140 SB(t.m7(), 0, 5,
GB(t.m4(), 0, 5));
1141 SB(t.m6(), 3, 3,
GB(t.m3(), 4, 3));
1142 SB(t.m3(), 4, 4,
GB(t.m5(), 0, 4));
1143 SB(t.m5(), 0, 1,
GB(t.m4(), 6, 1));
1144 SB(t.m5(), 5, 1,
GB(t.m4(), 5, 1));
1160 if (fix_roadtypes)
SB(t.m7(), 6, 2, (
RoadTypes)
GB(t.m3(), 0, 3));
1162 SB(t.m3(), 4, 4, t.m1());
1169 if (fix_roadtypes)
SB(t.m7(), 6, 2, (
RoadTypes)
GB(t.m3(), 0, 3));
1172 SB(t.m7(), 0, 5, o);
1175 SB(t.m6(), 2, 4,
GB(t.m2(), 4, 4));
1176 SB(t.m7(), 5, 1,
GB(t.m4(), 7, 1));
1242 SB(t.m6(), 2, 4, 0);
1247 if (
GB(t.m5(), 3, 2) == 0) {
1264 uint north_south =
GB(t.m5(), 5, 1);
1268 t.m5() = 1 << 7 | type << 2 | dir;
1274 if (!v->IsGroundVehicle())
continue;
1281 case DIAGDIR_NE:
if ((v->x_pos & 0xF) != 0)
continue;
break;
1284 case DIAGDIR_NW:
if ((v->y_pos & 0xF) != 0)
continue;
break;
1288 v->UpdatePosition();
1303 bool has_road =
false;
1324 SB(t.m7(), 6, 2, 0);
1406 SB(t.m4(), 4, 4, 0);
1423 rv->vehstatus &= ~0x40;
1444 AfterLoadStations();
1481 for (j = 0; j != 50; j++) PlantRandomFarmField(i);
1512 SB(t.m5(), 3, 2,
GB(t.m3(), 6, 2));
1513 SB(t.m3(), 6, 2, 0);
1558 case GFX_POWERPLANT_SPARKS:
1559 t.m3() =
GB(t.m1(), 2, 5);
1562 case GFX_OILWELL_ANIMATED_1:
1563 case GFX_OILWELL_ANIMATED_2:
1564 case GFX_OILWELL_ANIMATED_3:
1565 t.m3() =
GB(t.m1(), 0, 2);
1568 case GFX_COAL_MINE_TOWER_ANIMATED:
1569 case GFX_COPPER_MINE_TOWER_ANIMATED:
1570 case GFX_GOLD_MINE_TOWER_ANIMATED:
1588 ClrBit(v->vehicle_flags, 2);
1605 v->cur_speed *= 128;
1607 v->acceleration = avi->acceleration;
1628 t->larger_town =
true;
1638 v->current_order.IsType(OT_LOADING)) {
1639 Station::Get(v->last_station_visited)->loading_vehicles.push_back(v);
1650 for (
auto iter = st->loading_vehicles.begin(); iter != st->loading_vehicles.end(); ) {
1653 iter = st->loading_vehicles.erase(iter);
1679 SB(t.m2(), 4, 4, 0);
1681 SB(t.m2(), 4, 3,
GB(t.m2(), 0, 3));
1689 if (rv->state == 250 || rv->state == 251) {
1741 for (uint j = 0; j < std::size(i->produced); j++) {
1742 i->produced[j].cargo = indsp->produced_cargo[j];
1744 for (uint j = 0; j < std::size(i->accepted); j++) {
1777 if (v->orders !=
nullptr && v->orders->GetFirstOrder() !=
nullptr && v->orders->GetFirstOrder()->IsType(OT_NOTHING)) {
1778 v->orders->FreeChain();
1779 v->orders =
nullptr;
1782 v->current_order.ConvertFromOldSavegame();
1783 if (v->type ==
VEH_ROAD && v->IsPrimaryVehicle() && v->FirstShared() == v) {
1805 if (!order->IsType(OT_GOTO_DEPOT))
continue;
1810 if (!v->current_order.IsType(OT_GOTO_DEPOT))
continue;
1811 v->current_order.SetDepotActionType((
OrderDepotActionFlags)(v->current_order.GetDepotActionType() >> 1));
1821 case StationType::Oilrig:
1822 case StationType::Dock:
1823 case StationType::Buoy:
1825 SB(t.m3(), 0, 2, 0);
1836 SB(t.m3(), 0, 2, 0);
1905 for (RoadTramType rtt : _roadtramtypes) {
1922 v->profit_this_year <<= 8;
1923 v->profit_last_year <<= 8;
1924 v->running_ticks = 0;
1932 SB(t.m6(), 2, 6,
GB(t.m6(), 3, 5));
1933 SB(t.m3(), 5, 1, 0);
2014 if (t->First() == t) t->ReserveTrackUnderConsist();
2030 st->indtype = IT_INVALID;
2037 if (!a->IsNormalAircraft()) {
2038 a->engine_type = a->First()->engine_type;
2044 if (c->bankrupt_asked == 0xFF) c->bankrupt_asked = std::numeric_limits<CompanyMask>::max();
2048 if (e->company_avail == 0xFF) e->company_avail = std::numeric_limits<CompanyMask>::max();
2052 if (t->have_ratings == 0xFF) t->have_ratings = std::numeric_limits<CompanyMask>::max();
2064 t.m3() =
GB(t.m5(), 0, 5);
2076 t.m3() = type ==
OBJECT_HQ ?
GB(t.m3(), 1, 1) |
GB(t.m3(), 0, 1) << 4 : 0;
2093 uint offset = t.m3();
2096 t.m3() =
GB(t.m6(), 2, 4);
2097 SB(t.m6(), 2, 4, 0);
2107 SlError(STR_ERROR_TOO_MANY_OBJECTS);
2120 Tile northern_tile = t -
TileXY(
GB(offset, 0, 4),
GB(offset, 4, 4));
2122 t.m2() = northern_tile.
m2();
2150 case 5: layout = 1;
break;
2151 case 0: layout = 2;
break;
2153 t->layout =
static_cast<TownLayout>(layout - 1);
2183 if (v->subtype == 2 && v->state != 0) {
2198 for (
Vehicle *v : st->loading_vehicles) {
2203 if (v->cargo_payment ==
nullptr) v->cargo_payment =
new CargoPayment(v);
2220 remove = *tile == *j;
2259 wp->train_station.tile = wp->xy;
2260 wp->train_station.w = 1;
2261 wp->train_station.h = 1;
2264 wp->train_station.w = 0;
2265 wp->train_station.h = 0;
2273 if (s->remaining < 12) {
2275 s->remaining = 12 - s->remaining;
2302 s->remaining = 24 - s->remaining;
2310 if (ss !=
nullptr && sd !=
nullptr && ss->
owner == sd->
owner &&
2315 s->awarded = ss->
owner;
2353 Debug(sl, 0,
"Removing invalid depot {} at {}, {}", d->index,
TileX(d->xy),
TileY(d->xy));
2358 tile.
m2() = d->index;
2367 if (t->force_proceed !=
TFP_NONE) {
2386 uint density =
GB(t.m2(), 6, 2);
2387 uint ground =
GB(t.m2(), 4, 2);
2388 t.m2() = ground << 6 | density << 4;
2396 a->turn_counter = a->current_order.IsType(OT_LOADING) ? 0 : a->load_unload_ticks;
2400 t->wait_counter = t->current_order.IsType(OT_LOADING) ? 0 : t->load_unload_ticks;
2406 struct AirportTileConversion {
2410 static const AirportTileConversion atcs[] = {
2425 for (
const auto &atc : atcs) {
2426 if (old_gfx < atc.old_start) {
2430 if (old_gfx < atc.old_start + atc.num_frames) {
2435 offset += atc.num_frames - 1;
2444 if (st->airport.tile !=
INVALID_TILE && st->airport.type == 15) {
2453 st->airport.w = st->airport.GetSpec()->size_x;
2454 st->airport.h = st->airport.GetSpec()->size_y;
2484 if (!v->IsNormalAircraft())
continue;
2486 if (st ==
nullptr && v->state !=
FLYING) {
2505 uint per_proc = t.m7();
2506 t.m7() =
GB(t.m6(), 2, 6) | (
GB(t.m3(), 5, 1) << 6);
2507 SB(t.m3(), 5, 1, 0);
2508 SB(t.m6(), 2, 6, std::min(per_proc, 63U));
2552 if (!wp->name.empty()) wp->town_cn = UINT16_MAX;
2569 if (!v->IsGroundVehicle())
continue;
2579 if (
GetSlopePixelZ(v->x_pos, v->y_pos,
true) != v->z_pos)
continue;
2614 default: NOT_REACHED();
2617 v->vehstatus &= ~VS_HIDDEN;
2622 default: NOT_REACHED();
2632 bool loading = rv->current_order.IsType(OT_LOADING) || rv->current_order.IsType(OT_LEAVESTATION);
2637 SB(rv->state,
RVS_ENTERED_STOP, 1, loading || rv->frame > RVC_DRIVE_THROUGH_STOP_FRAME);
2645 if (!
HasBit(t->flags, 5))
continue;
2669 if (v->IsGroundVehicle() &&
TileVirtXY(v->x_pos, v->y_pos) == v->tile) {
2762 if (!v->IsPrimaryVehicle())
continue;
2765 if (v->cur_implicit_order_index >= v->GetNumOrders()) v->cur_implicit_order_index = 0;
2767 v->cur_real_order_index = v->cur_implicit_order_index;
2768 v->UpdateRealOrderIndex();
2799 assert(ind->psa !=
nullptr);
2802 bool is_empty =
true;
2803 for (uint i = 0; i <
sizeof(ind->psa->storage); i++) {
2804 if (ind->psa->GetValue(i) != 0) {
2811 ind->psa->grfid = _industry_mngr.
GetGRFID(ind->type);
2822 assert(st->airport.psa !=
nullptr);
2825 bool is_empty =
true;
2826 for (uint i = 0; i <
sizeof(st->airport.psa->storage); i++) {
2827 if (st->airport.psa->GetValue(i) != 0) {
2834 st->airport.psa->grfid = _airport_mngr.
GetGRFID(st->airport.type);
2836 delete st->airport.psa;
2837 st->airport.psa =
nullptr;
2854 uint fence =
GB(t.m4(), 5, 3);
2858 fence =
GB(t.m4(), 2, 3);
2862 SB(t.m4(), 2, 3, 0);
2863 SB(t.m4(), 5, 3, 0);
2871 case LandscapeType::Arctic:
2875 case LandscapeType::Tropic:
2888 _saved_scrollpos_zoom =
static_cast<ZoomLevel>(_saved_scrollpos_zoom + ZOOM_BASE_SHIFT);
2889 _saved_scrollpos_x *= ZOOM_BASE;
2890 _saved_scrollpos_y *= ZOOM_BASE;
2920 c->months_of_bankruptcy = 3 * c->months_of_bankruptcy;
2929 v->acceleration = avi->acceleration;
2944 extern uint8_t _old_units;
2988 std::vector<uint> skip_frames;
2990 if (!v->IsFrontEngine())
continue;
2991 skip_frames.clear();
2993 uint prev_tile_skip = 0;
2996 if (u->tile != prev_tile) {
2997 prev_tile_skip = cur_skip;
2998 prev_tile = u->tile;
3000 cur_skip = prev_tile_skip;
3003 uint &this_skip = skip_frames.emplace_back(prev_tile_skip);
3009 if (u->frame <= (roadside ? 9 : 5)) this_skip = cur_skip;
3014 if (u->frame <= (roadside ? 5 : 9)) this_skip = cur_skip;
3019 if (u->frame <= (roadside ? 4 : 2)) this_skip = cur_skip;
3026 while (cur_skip > skip_frames[0]) {
3029 for (uint sf : skip_frames) {
3030 if (sf >= cur_skip) IndividualRoadVehicleController(u, prev);
3042 order->SetTravelTimetabled(order->GetTravelTime() > 0);
3043 order->SetWaitTimetabled(order->GetWaitTime() > 0);
3046 orderlist->RecalculateTimetableDuration();
3057#ifndef DEBUG_DUMP_COMMANDS
3072 t->growth_rate = TownTicksToGameTicks(t->growth_rate & ~0x8000);
3084 for (
auto &a : i->accepted) {
3086 a.last_accepted = i->GetAccepted(0).last_accepted;
3101 int x = s->x_pos & 0xF;
3102 int y = s->y_pos & 0xF;
3103 if (x == 8 && y == 8)
continue;
3108 switch (shipdiagdir) {
3109 default: NOT_REACHED();
3119 if ((shipdiagdir == slopediagdir) == second_half) {
3143 st->industry->neutral_station = st;
3176 if (st->ship_station.tile !=
INVALID_TILE) UpdateStationDockingTiles(st);
3200 uint16_t wagon_removal = 0;
3202 if (c->settings.renew_keep_length)
SetBit(wagon_removal, c->index);
3216 v->last_loading_tick = std::max(
TimerGameTick::counter,
static_cast<uint64_t
>(v->current_order_time)) - v->current_order_time;
3229 if (rv->IsArticulatedPart())
continue;
3232 if (rv->cur_speed > 0)
continue;
3244 if (closestDepot.found &&
DistanceManhattan(rv->tile, closestDepot.location) < 512u) {
3247 u->tile = closestDepot.location;
3256 u->UpdatePosition();
3258 RoadVehLeaveDepot(rv,
false);
3264 for (
auto t :
Map::Iterate()) {
3266 SB(t.m2(), 0, 4, 0);
3272 for (
const auto tile :
Map::Iterate()) {
3302 v->date_of_last_service_newgrf = TimerGameCalendar::Date{v->date_of_last_service.base()};
3309 if (s->acceleration == 0) s->acceleration = ShipVehInfo(s->engine_type)->
acceleration;
3315 c->max_loan = COMPANY_MAX_LOAN_DEFAULT;
3320 ScriptObject::InitializeRandomizers();
3338 g->number = c->freegroups.
UseID(g->index);
3340 c->freegroups.
UseID(g->number);
3399 AfterLoadStations();
static void SetSignalHandlers()
Replaces signal handlers of SIGSEGV and SIGABRT and stores pointers to original handlers in memory.
static uint FixVehicleInclination(Vehicle *v, Direction dir)
Fixes inclination of a vehicle.
static void InitializeWindowsAndCaches()
Initialization of the windows and several kinds of caches.
static void CheckGroundVehiclesAtCorrectZ()
Check whether the ground vehicles are at the correct Z-coordinate.
static bool _saveload_crash_with_missing_newgrfs
Was the saveload crash because of missing NewGRFs?
static void FixOwnerOfRailTrack(Tile t)
Tries to change owner of this rail tile to a valid owner.
static void CDECL HandleSavegameLoadCrash(int signum)
Signal handler used to give a user a more useful report for crashes during the savegame loading proce...
static bool MayHaveBridgeAbove(Tile t)
Checks for the possibility that a bridge may be on this tile These are in fact all the tile types on ...
Company * DoStartupNewCompany(bool is_ai, CompanyID company=INVALID_COMPANY)
Create a new company and sets all company variables default values.
void SetWaterClassDependingOnSurroundings(Tile t, bool include_invalid_water_class)
Makes a tile canal or water depending on the surroundings.
static void StartScripts()
Start the scripts.
bool SaveloadCrashWithMissingNewGRFs()
Did loading the savegame cause a crash? If so, were NewGRFs missing?
void UpdateAllVirtCoords()
Update the viewport coordinates of all signs.
bool AfterLoadGame()
Perform a (large) amount of savegame conversion magic in order to load older savegames and to fill th...
void ReloadNewGRFData()
Reload all NewGRF files during a running game.
static void ResetSignalHandlers()
Resets signal handlers back to original handlers.
void GetAircraftFlightLevelBounds(const Vehicle *v, int *min, int *max)
Get the 'flight level' bounds, in pixels from 'z_pos' 0 for a particular vehicle for normal flight si...
void AircraftNextAirportPos_and_Order(Aircraft *v)
set the right pos when heading to other airports after takeoff
Station * GetTargetAirportIfValid(const Aircraft *v)
Returns aircraft's target station if v->target_airport is a valid station with airport.
void SetAircraftPosition(Aircraft *v, int x, int y, int z)
Set aircraft position.
@ AIR_AIRCRAFT
an airplane
void UpdateAircraftCache(Aircraft *v, bool update_range=false)
Update cached values of an aircraft.
@ FLYING
Vehicle is flying in the air.
@ AT_OILRIG
Oilrig airport.
std::vector< TileIndex > _animated_tiles
The table/list with animated tiles.
@ Animated
Tile is animated.
@ None
Tile is not animated.
void SetAnimatedTileState(Tile t, AnimatedTileState state)
Set the animated state of a tile.
debug_inline constexpr bool HasBit(const T x, const uint8_t y)
Checks if a bit in a value is set.
constexpr T AssignBit(T &x, const uint8_t y, bool value)
Assigns a bit in a variable.
constexpr T SB(T &x, const uint8_t s, const uint8_t n, const U d)
Set n bits in x starting at bit s to d.
constexpr T SetBit(T &x, const uint8_t y)
Set a bit in a variable.
debug_inline static constexpr uint GB(const T x, const uint8_t s, const uint8_t n)
Fetch n bits from x, started at bit s.
constexpr T ClrBit(T &x, const uint8_t y)
Clears a bit in a variable.
TileIndex GetNorthernBridgeEnd(TileIndex t)
Finds the northern end of a bridge starting at a middle tile.
void SetBridgeMiddle(Tile t, Axis a)
Set that there is a bridge over the given axis.
bool IsBridgeTile(Tile t)
checks if there is a bridge on this tile
void ClearBridgeMiddle(Tile t)
Removes bridges from the given, that is bridges along the X and Y axis.
bool IsBridge(Tile t)
Checks if this is a bridge, instead of a tunnel.
void AfterLoadCompanyStats()
Rebuilding of company statistics after loading a savegame.
bool IsValidCargoType(CargoType t)
Test whether cargo type is not INVALID_CARGO.
@ Industry
Source/destination is an industry.
@ Town
Source/destination is a town.
static const CargoType CARGO_NO_REFIT
Do not refit cargo of a vehicle (used in vehicle orders and auto-replace/auto-renew).
@ TAE_GOODS
Cargo behaves goods/candy-like.
@ TAE_PASSENGERS
Cargo behaves passenger-like.
@ TAE_MAIL
Cargo behaves mail-like.
@ TAE_FOOD
Cargo behaves food/fizzy-drinks-like.
@ TAE_WATER
Cargo behaves water-like.
static void StartNew(CompanyID company)
Start a new AI company.
TStorage storage
The storage of the timer.
constexpr bool Test(Tenum value) const
Test if the enum value is set.
UnitID UseID(UnitID index)
Use a unit number.
static void StartNew()
Start up a new GameScript.
void TestRevision()
Finds out if current revision is different than last revision stored in the savegame.
const GRFIdentifier & GetOverriddenIdentifier(const GRFConfig &c)
Try to find the overridden GRF identifier of the given GRF.
void PrintDebug(int level)
Prints gamelog to debug output.
void GRFRemove(uint32_t grfid)
Logs removal of a GRF.
void GRFAddList(const GRFConfigList &newg)
Logs adding of list of GRFs.
void GRFCompatible(const GRFIdentifier &newg)
Logs loading compatible GRF (the same ID, but different MD5 hash)
void Oldver()
Logs loading from savegame without gamelog.
void TestMode()
Finds last stored game mode or landscape.
uint32_t GetGRFID(uint16_t entity_id) const
Gives the GRFID of the file the entity belongs to.
static constexpr TimerGameTick::Ticks DAY_TICKS
1 day is 74 ticks; TimerGameCalendar::date_fract used to be uint16_t and incremented by 885.
static constexpr TimerGameTick::Ticks TOWN_GROWTH_TICKS
Cycle duration for towns trying to grow (this originates from the size of the town array in TTD).
Wrapper class to abstract away the way the tiles are stored.
debug_inline uint16_t & m2()
Primarily used for indices to towns, industries and stations.
debug_inline uint8_t & m7()
Primarily used for newgrf support.
debug_inline uint8_t & m6()
General purpose.
debug_inline uint8_t & m3()
General purpose.
debug_inline uint8_t & m5()
General purpose.
A timeout timer will fire once after the interval.
static void SetDate(Date date, DateFract fract)
Set the date.
static Date date
Current date in days (day counter).
static Year year
Current year, starting at 0.
static DateFract date_fract
Fractional part of the day.
static constexpr TimerGame< struct Economy >::Date MIN_DATE
The date on January 1, year 0.
static constexpr TimerGame< struct Calendar >::Year DEF_END_YEAR
The default scoring end year.
static constexpr TimerGame< struct Economy >::Year MIN_YEAR
The absolute minimum year in OTTD.
static constexpr int SECONDS_PER_DAY
approximate seconds per day, not for precise calculations
static constexpr TimerGame< struct Calendar >::Year ORIGINAL_BASE_YEAR
The minimum starting year/base year of the original TTD.
static constexpr TimerGame< struct Calendar >::Date DAYS_TILL_ORIGINAL_BASE_YEAR
The date of the first day of the original base year.
static Date date
Current date in days (day counter).
static Year year
Current year, starting at 0.
static DateFract date_fract
Fractional part of the day.
static void SetDate(Date date, DateFract fract)
Set the date.
static TickCounter counter
Monotonic counter, in ticks, since start of game.
ClearGround GetRawClearGround(Tile t)
Get the type of clear tile but never return CLEAR_SNOW.
bool IsClearGround(Tile t, ClearGround ct)
Set the type of clear tile.
void SetFence(Tile t, DiagDirection side, uint h)
Sets the type of fence (and whether there is one) for the given border.
void MakeClear(Tile t, ClearGround g, uint density)
Make a clear tile.
void SetClearGroundDensity(Tile t, ClearGround type, uint density)
Sets ground type and density in one go, also sets the counter to 0.
uint GetClearDensity(Tile t)
Get the density of a non-field clear tile.
void ResetCompanyLivery(Company *c)
Reset the livery schemes to the company's primary colour.
void UpdateCompanyLiveries(Company *c)
Update liveries for a company.
TimeoutTimer< TimerGameTick > _new_competitor_timeout({ TimerGameTick::Priority::COMPETITOR_TIMEOUT, 0 }, []() { if(_game_mode==GM_MENU||!AI::CanStartNew()) return;if(_networking &&Company::GetNumItems() >=_settings_client.network.max_companies) return;uint8_t n=0;for(const Company *c :Company::Iterate()) { if(c->is_ai) n++;} if(n >=_settings_game.difficulty.max_no_competitors) return;Command< CMD_COMPANY_CTRL >::Post(CCA_NEW_AI, INVALID_COMPANY, CRR_NONE, INVALID_CLIENT_ID);})
Start a new competitor company if possible.
CompanyID GetFirstPlayableCompanyID()
Get the index of the first available company.
CompanyID _current_company
Company currently doing an action.
CompanyManagerFace ConvertFromOldCompanyManagerFace(uint32_t face)
Converts an old company manager's face format to the new company manager's face format.
Owner
Enum for all companies/owners.
@ INVALID_COMPANY
An invalid company.
@ INVALID_OWNER
An invalid owner.
@ COMPANY_FIRST
First company, same as owner.
@ OWNER_NONE
The tile has no ownership.
@ OWNER_WATER
The tile/execution is done by "water".
@ OWNER_TOWN
A town owns the tile, or a town is expanding.
@ MAX_COMPANIES
Maximum number of companies.
#define Debug(category, level, format_string,...)
Ouptut a line of debugging information.
bool IsDepotTile(Tile tile)
Is the given tile a tile with a depot on it?
Direction DiagDirToDir(DiagDirection dir)
Convert a DiagDirection to a Direction.
DiagDirection ReverseDiagDir(DiagDirection d)
Returns the reverse direction of the given DiagDirection.
Direction ReverseDir(Direction d)
Return the reverse of a direction.
Direction AxisToDirection(Axis a)
Converts an Axis to a Direction.
Axis DiagDirToAxis(DiagDirection d)
Convert a DiagDirection to the axis.
DiagDirection XYNSToDiagDir(Axis xy, uint ns)
Convert an axis and a flag for north/south into a DiagDirection.
DiagDirection DirToDiagDir(Direction dir)
Convert a Direction to a DiagDirection.
Direction
Defines the 8 directions on the map.
@ INVALID_DIR
Flag for an invalid direction.
Axis
Allow incrementing of DiagDirDiff variables.
DiagDirection
Enumeration for diagonal directions.
@ DIAGDIR_NE
Northeast, upper right on your monitor.
@ DIAGDIR_END
Used for iterations.
@ DIAGDIR_BEGIN
Used for iterations.
void RecomputePrices()
Computes all prices, payments and maximum loan.
bool AddInflation(bool check_year)
Add monthly inflation.
static const uint64_t MAX_INFLATION
Maximum inflation (including fractional part) without causing overflows in int64_t price computations...
void StartupEngines()
Start/initialise all our engines.
void CopyTempEngineData()
Copy data from temporary engine array into the real engine pool.
@ RoadIsTram
Road vehicle is a tram/light rail vehicle.
constexpr std::underlying_type_t< enum_type > to_underlying(enum_type e)
Implementation of std::to_underlying (from C++23)
@ WL_CRITICAL
Critical errors, the MessageBox is shown in all cases.
void ShowErrorMessage(StringID summary_msg, int x, int y, CommandCost cc)
Display an error message in a window.
@ FT_SCENARIO
old or new scenario
Gamelog _gamelog
Gamelog instance.
PauseMode _pause_mode
The current pause mode.
void LoadStringWidthTable(bool monospace)
Initialize _stringwidth_table cache.
void GfxLoadSprites()
Initialise and load all the sprites.
@ GVF_GOINGDOWN_BIT
Vehicle is currently going downhill. (Cached track information for acceleration)
@ GVF_GOINGUP_BIT
Vehicle is currently going uphill. (Cached track information for acceleration)
@ ReplaceProtection
If set, the global autoreplace has no effect on the group.
@ ReplaceWagonRemoval
If set, autoreplace will perform wagon removal on vehicles in this group.
void MarkWholeScreenDirty()
This function mark the whole screen as dirty.
void MarkTileDirtyByTile(TileIndex tile, int bridge_level_offset, int tile_height_override)
Mark a tile given by its index dirty for repaint.
static const HouseID NEW_HOUSE_OFFSET
Offset for new houses.
static const uint8_t TOWN_HOUSE_COMPLETED
Simple value that indicates the house has reached the final stage of construction.
IndustryBuildData _industry_builder
In-game manager of industries.
void TrimIndustryAcceptedProduced(Industry *ind)
Remove unused industry accepted/produced slots – entries after the last slot with valid cargo.
const IndustrySpec * GetIndustrySpec(IndustryType thistype)
Accessor for array _industry_specs.
IndustryType GetIndustryType(Tile tile)
Retrieve the type for this industry.
IndustryGfx GetIndustryGfx(Tile t)
Get the industry graphics ID for the given industry tile.
@ INDUSTRYBEH_PLANT_ON_BUILT
Fields are planted around when built (all farms)
@ INDUSTRYBEH_BUILT_ONWATER
is built on water (oil rig)
void AfterLoadLabelMaps()
Perform rail type and road type conversion if necessary.
TrackStatus GetTileTrackStatus(TileIndex tile, TransportType mode, uint sub_mode, DiagDirection side)
Returns information about trackdirs and signal states.
void ChangeTileOwner(TileIndex tile, Owner old_owner, Owner new_owner)
Change the owner of a tile.
int GetSlopePixelZ(int x, int y, bool ground_vehicle)
Return world Z coordinate of a given point of a tile.
@ Random
Randomise borders.
void AfterLoadLinkGraphs()
Spawn the threads for running link graph calculations.
@ DT_MANUAL
Manual distribution. No link graph calculations are run.
void SetupColoursAndInitialWindow()
Initialise the default colours (remaps and the likes), and load the main windows.
uint DistanceManhattan(TileIndex t0, TileIndex t1)
Gets the Manhattan distance between the two given tiles.
TileIndex TileAddXY(TileIndex tile, int x, int y)
Adds a given offset to a tile.
static debug_inline TileIndex TileXY(uint x, uint y)
Returns the TileIndex of a coordinate.
TileIndex TileAddByDiagDir(TileIndex tile, DiagDirection dir)
Adds a DiagDir to a tile.
TileIndexDiff TileDiffXY(int x, int y)
Calculates an offset for the given coordinate(-offset).
static debug_inline uint TileY(TileIndex tile)
Get the Y component of a tile.
static debug_inline uint TileX(TileIndex tile)
Get the X component of a tile.
TileIndexDiff TileOffsByDiagDir(DiagDirection dir)
Convert a DiagDirection to a TileIndexDiff.
static debug_inline TileIndex TileVirtXY(uint x, uint y)
Get a tile from the virtual XY-coordinate.
constexpr bool IsInsideMM(const size_t x, const size_t min, const size_t max) noexcept
Checks if a value is in an interval.
constexpr uint CeilDiv(uint a, uint b)
Computes ceil(a / b) for non-negative a and b.
constexpr T Clamp(const T a, const T min, const T max)
Clamp a value between an interval.
constexpr void Swap(T &a, T &b)
Type safe swap operation.
void GenerateSavegameId()
Generate an unique savegame ID.
bool _networking
are we in networking mode?
bool _network_dedicated
are we a dedicated server?
bool _network_server
network-server is active
@ GSF_FAKE_TOWNS
Fake town GrfSpecFeature for NewGRF debugging (parent scope)
void ShowNewGRFError()
Show the first NewGRF error we can find.
uint8_t StationGfx
Copy from station_map.h.
GRFConfigList _grfconfig
First item in list of current GRF set up.
GRFListCompatibility IsGoodGRFConfigList(GRFConfigList &grfconfig)
Check if all GRFs in the GRF config from a savegame can be loaded.
GRFListCompatibility
Status of post-gameload GRF compatibility check.
@ GLC_COMPATIBLE
Compatible (eg. the same ID, but different checksum) GRF found in at least one case.
@ GLC_ALL_GOOD
All GRF needed by game are present.
@ GLC_NOT_FOUND
At least one GRF couldn't be found (higher priority than GLC_COMPATIBLE)
@ GCS_NOT_FOUND
GRF file was not found in the local cache.
@ Compatible
GRF file does not exactly match the requested GRF (different MD5SUM), but grfid matches)
void DeleteInvalidEngineNews()
Remove engine announcements for invalid engines.
uint16_t ObjectType
Types of objects.
static const ObjectType OBJECT_STATUE
Statue in towns.
static const ObjectType OBJECT_HQ
HeadQuarter of a player.
@ PM_UNPAUSED
A normal unpaused game.
@ PM_PAUSED_ERROR
A game paused because a (critical) error.
@ PM_PAUSED_NORMAL
A game normally paused.
@ OSL_PLATFORM_FAR_END
Stop at the far end of the platform.
@ OUFB_TRANSFER
Transfer all cargo onto the platform.
@ OUFB_UNLOAD
Force unloading all cargo onto the platform, possibly not getting paid.
OrderDepotActionFlags
Actions that can be performed when the vehicle enters the depot.
@ OLFB_NO_LOAD
Do not load anything.
@ ONSF_NO_STOP_AT_INTERMEDIATE_STATIONS
The vehicle will not stop at any stations it passes except the destination.
RailTypes GetCompanyRailTypes(CompanyID company, bool introduces)
Get the rail types the given company can build.
void InitializeRailGUI()
Resets the rail GUI - sets default railtype to build and resets the signal GUI.
RailType GetRailType(Tile t)
Gets the rail type of the given tile.
static debug_inline bool IsRailDepotTile(Tile t)
Is this tile rail tile and a rail depot?
void SetTrackReservation(Tile t, TrackBits b)
Sets the reserved track bits of the tile.
@ RAIL_GROUND_WATER
Grass with a fence and shore or water on the free halftile.
static debug_inline bool IsRailDepot(Tile t)
Is this rail tile a rail depot?
void SetDepotReservation(Tile t, bool b)
Set the reservation state of the depot.
static debug_inline bool IsPlainRail(Tile t)
Returns whether this is plain rails, with or without signals.
bool HasSignals(Tile t)
Checks if a rail tile has signals.
static debug_inline bool IsPlainRailTile(Tile t)
Checks whether the tile is a rail tile or rail tile with signals.
void SetSignalStates(Tile tile, uint state)
Set the states of the signals (Along/AgainstTrackDir)
void SetRailType(Tile t, RailType r)
Sets the rail type of the given tile.
RailType
Enumeration for all possible railtypes.
@ RAILTYPE_ELECTRIC
Electric rails.
@ RAILTYPE_RAIL
Standard non-electric rails.
RoadTypes GetCompanyRoadTypes(CompanyID company, bool introduces)
Get the road types the given company can build.
void UpdateNearestTownForRoadTiles(bool invalidate)
Updates cached nearest town for all road tiles.
void UpdateLevelCrossing(TileIndex tile, bool sound=true, bool force_bar=false)
Update a level crossing to barred or open (crossing may include multiple adjacent tiles).
void SetRoadOwner(Tile t, RoadTramType rtt, Owner o)
Set the owner of a specific road type.
bool HasTownOwnedRoad(Tile t)
Checks if given tile has town owned road.
static debug_inline bool IsRoadDepot(Tile t)
Return whether a tile is a road depot.
bool IsLevelCrossingTile(Tile t)
Return whether a tile is a level crossing tile.
void SetRoadTypes(Tile t, RoadType road_rt, RoadType tram_rt)
Set the present road types of a tile.
@ ROAD_TILE_NORMAL
Normal road.
@ ROAD_TILE_DEPOT
Depot (one entrance)
@ ROAD_TILE_CROSSING
Level crossing.
RoadBits GetCrossingRoadBits(Tile tile)
Get the road bits of a level crossing.
Owner GetRoadOwner(Tile t, RoadTramType rtt)
Get the owner of a specific road type.
static debug_inline RoadTileType GetRoadTileType(Tile t)
Get the type of the road tile.
void SetCrossingReservation(Tile t, bool b)
Set the reservation state of the rail crossing.
bool IsLevelCrossing(Tile t)
Return whether a tile is a level crossing.
RoadBits
Enumeration for the road parts on a tile.
@ ROAD_Y
Full road along the y-axis (north-west + south-east)
@ ROAD_X
Full road along the x-axis (south-west + north-east)
RoadTypes
The different roadtypes we support, but then a bitmask of them.
RoadType
The different roadtypes we support.
@ INVALID_ROADTYPE
flag for invalid roadtype
@ ROADTYPE_ROAD
Basic road type.
@ RVS_ENTERED_STOP
Only set when a vehicle has entered the stop.
@ RVSB_IN_ROAD_STOP
The vehicle is in a road stop.
@ RVS_IN_DT_ROAD_STOP
The vehicle is in a drive-through road stop.
@ RVS_IN_ROAD_STOP
The vehicle is in a road stop.
@ RVSB_IN_DEPOT
The vehicle is in a depot.
@ RVSB_WORMHOLE
The vehicle is in a tunnel and/or bridge.
@ RVS_DRIVE_SIDE
Only used when retrieving move data.
const uint8_t _road_stop_stop_frame[]
Table of road stop stop frames, when to stop at a road stop.
void SlError(StringID string, const std::string &extra_msg)
Error handler.
void SetSaveLoadError(StringID str)
Set the error message from outside of the actual loading/saving of the game (AfterLoadGame and friend...
void SlErrorCorrupt(const std::string &msg)
Error handler for corrupt savegames.
FileToSaveLoad _file_to_saveload
File to save or load in the openttd loop.
bool IsSavegameVersionBefore(SaveLoadVersion major, uint8_t minor=0)
Checks whether the savegame is below major.
@ SLV_AI_START_DATE
309 PR#10653 Removal of individual AI start dates and added a generic one.
@ SLV_190
190 26547 Separate order travel and wait times
@ SLV_ECONOMY_MODE_TIMEKEEPING_UNITS
327 PR#11341 Mode to display economy measurements in wallclock units.
@ SLV_COMPANY_INAUGURATED_PERIOD_V2
349 PR#13448 Fix savegame storage for company inaugurated year in wallclock mode.
@ SLV_182
182 25115 FS#5492, r25259, r25296 Goal status
@ SLV_186
186 25833 Objects storage
@ SLV_16
16.0 2817 16.1 3155
@ SLV_SERVE_NEUTRAL_INDUSTRIES
210 PR#7234 Company stations can serve industries with attached neutral stations.
@ SLV_188
188 26169 v1.4 FS#5831 Unify RV travel time
@ SLV_198
198 PR#6763 Switch town growth rate and counter to actual game ticks
@ SLV_EXTEND_RAILTYPES
200 PR#6805 Extend railtypes to 64, adding uint16_t to map array.
@ SLV_17
17.0 3212 17.1 3218
@ SLV_EXTEND_INDUSTRY_CARGO_SLOTS
202 PR#6867 Increase industry cargo slots to 16 in, 16 out
@ SLV_GROUP_REPLACE_WAGON_REMOVAL
291 PR#7441 Per-group wagon removal flag.
@ SLV_VELOCITY_NAUTICAL
305 PR#10594 Separation of land and nautical velocity (knots!)
@ SLV_VEHICLE_ECONOMY_AGE
334 PR#12141 v14.0 Add vehicle age in economy year, for profit stats minimum age
@ SLV_4
4.0 1 4.1 122 0.3.3, 0.3.4 4.2 1222 0.3.5 4.3 1417 4.4 1426
@ SLV_TOWN_CARGOGEN
208 PR#6965 New algorithms for town building cargo generation.
@ SLV_LINKGRAPH_SECONDS
308 PR#10610 Store linkgraph update intervals in seconds instead of days.
@ SLV_SAVEGAME_ID
313 PR#10719 Add an unique ID to every savegame (used to deduplicate surveys).
@ SLV_11
11.0 2033 11.1 2041
@ SLV_ENDING_YEAR
218 PR#7747 v1.10 Configurable ending year.
@ SLV_WATER_TILE_TYPE
342 PR#13030 Simplify water tile type.
@ SLV_ANIMATED_TILE_STATE_IN_MAP
347 PR#13082 Animated tile state saved for improved performance.
@ SLV_MULTITILE_DOCKS
216 PR#7380 Multiple docks per station.
@ SLV_ROAD_TYPES
214 PR#6811 NewGRF road types.
@ SLV_GS_INDUSTRY_CONTROL
287 PR#7912 and PR#8115 GS industry control.
@ SLV_2
2.0 0.3.0 2.1 0.3.1, 0.3.2
@ SLV_INCREASE_HOUSE_LIMIT
348 PR#12288 Increase house limit to 4096.
@ SLV_LAST_LOADING_TICK
301 PR#9693 Store tick of last loading for vehicles.
@ SLV_SCRIPT_RANDOMIZER
333 PR#12063 v14.0-RC1 Save script randomizers.
@ SLV_DEPOT_UNBUNCHING
331 PR#11945 Allow unbunching shared order vehicles at a depot.
@ SLV_SHIP_ACCELERATION
329 PR#10734 Start using Vehicle's acceleration field for ships too.
@ SLV_MULTITRACK_LEVEL_CROSSINGS
302 PR#9931 v13.0 Multi-track level crossings.
@ SLV_192
192 26700 FS#6066 Fix saving of order backups
@ SLV_ECONOMY_DATE
326 PR#10700 Split calendar and economy timers and dates.
@ SLV_GROUP_NUMBERS
336 PR#12297 Add per-company group numbers.
@ SLV_NEWGRF_LAST_SERVICE
317 PR#11124 Added stable date_of_last_service to avoid NewGRF trouble.
@ SLV_184
184 25508 Unit localisation split
@ SLV_INCREASE_STATION_TYPE_FIELD_SIZE
337 PR#12572 Increase size of StationType field in map array
@ SLV_NONFLOODING_WATER_TILES
345 PR#13013 Store water tile non-flooding state.
@ SLV_TREES_WATER_CLASS
213 PR#7405 WaterClass update for tree tiles.
@ SLV_SHIPS_STOP_IN_LOCKS
206 PR#7150 Ship/lock movement changes.
@ SLV_183
183 25363 Cargodist
@ SLV_REPAIR_OBJECT_DOCKING_TILES
299 PR#9594 v12.0 Fixing issue with docking tiles overlapping objects.
@ SLV_CONSISTENT_PARTIAL_Z
306 PR#10570 Conversion from an inconsistent partial Z calculation for slopes, to one that is (more) ...
@ SLV_MAX_LOAN_FOR_COMPANY
330 PR#11224 Separate max loan for each company.
bool IsSavegameVersionBeforeOrAt(SaveLoadVersion major)
Checks whether the savegame is below or at major.
Declaration of functions used in more save/load files.
void AfterLoadVehiclesPhase1(bool part_of_load)
Called after load for phase 1 of vehicle initialisation.
void ResetOldNames()
Free the memory of the old names array.
void FixupTrainLengths()
Fixup old train spacing.
void MoveBuoysToWaypoints()
Perform all steps to upgrade from the old station buoys to the new version that uses waypoints.
void UpdateOldAircraft()
need to be called to load aircraft from old version
void ConvertOldMultiheadToNew()
Converts all trains to the new subtype format introduced in savegame 16.2 It also links multiheaded e...
void ConnectMultiheadedTrains()
Link front and rear multiheaded engines to each other This is done when loading a savegame.
void AfterLoadRoadStops()
(Re)building of road stop caches after loading a savegame.
void MoveWaypointsToBaseStations()
Perform all steps to upgrade from the old waypoints to the new version that uses station.
void AfterLoadVehiclesPhase2(bool part_of_load)
Called after load for phase 2 of vehicle initialisation.
void UpdateHousesAndTowns()
Check and update town and house values.
std::string CopyFromOldName(StringID id)
Copy and convert old custom names to UTF-8.
void AfterLoadStoryBook()
Called after load to trash broken pages.
void ShowScriptDebugWindowIfScriptError()
Open the AI debug window if one of the AI scripts has crashed.
VehicleDefaultSettings _old_vds
Used for loading default vehicles settings from old savegames.
GameSettings _settings_game
Game settings of a running game or the scenario editor.
GameSettings _settings_newgame
Game settings for new games (updated from the intro screen).
ClientSettings _settings_client
The current settings for this game.
@ SIGTYPE_COMBO
presignal inter-block
@ SIG_SEMAPHORE
Old-fashioned semaphore signal.
@ SIG_ELECTRIC
Light signal.
void UpdateAllSignVirtCoords()
Update the coordinates of all signs.
DiagDirection GetInclinedSlopeDirection(Slope s)
Returns the direction of an inclined slope.
void BuildOwnerLegend()
Completes the array for the owned property legend.
void UpdateAllStationVirtCoords()
Update the virtual coords needed to draw the station sign for all stations.
void UpdateAirportsNoise()
Recalculate the noise generated by the airports of each town.
void UpdateStationAcceptance(Station *st, bool show_msg)
Update the acceptance for a station.
StationType GetStationType(Tile t)
Get the station type of this tile.
StationGfx GetStationGfx(Tile t)
Get the station graphics of this tile.
void SetStationGfx(Tile t, StationGfx gfx)
Set the station graphics of this tile.
bool IsAirportTile(Tile t)
Is this tile a station tile and an airport tile?
bool IsBayRoadStopTile(Tile t)
Is tile t a bay (non-drive through) road stop station?
bool IsBuoy(Tile t)
Is tile t a buoy tile?
bool IsDriveThroughStopTile(Tile t)
Is tile t a drive through road stop station or waypoint?
bool HasStationTileRail(Tile t)
Has this station tile a rail? In other words, is this station tile a rail station or rail waypoint?
void SetRailStationReservation(Tile t, bool b)
Set the reservation state of the rail station.
bool IsAnyRoadStop(Tile t)
Is the station at t a road station?
bool IsStationTileBlocked(Tile t)
Is tile t a blocked tile?
bool IsTruckStop(Tile t)
Is the station at t a truck stop?
bool IsStationRoadStop(Tile t)
Is the station at t a road station?
bool HasStationRail(Tile t)
Has this station tile a rail? In other words, is this station tile a rail station or rail waypoint?
static const int GFX_TRUCK_BUS_DRIVETHROUGH_OFFSET
The offset for the drive through parts.
bool IsOilRig(Tile t)
Is tile t part of an oilrig?
bool IsBuoyTile(Tile t)
Is tile t a buoy tile?
bool IsDock(Tile t)
Is tile t a dock tile?
@ FACIL_DOCK
Station with a dock.
@ FACIL_AIRPORT
Station with an airport.
@ FACIL_TRAIN
Station with train station.
StationType
Station types.
std::string FormatArrayAsHex(std::span< const uint8_t > data)
Format a byte array into a continuous hex string.
static const StringID INVALID_STRING_ID
Constant representing an invalid string (16bit in case it is used in savegames)
static constexpr StringID SPECSTR_PRESIDENT_NAME
Special string for the president's name.
static constexpr StringID SPECSTR_TOWNNAME_START
Special strings for town names.
Information about a aircraft vehicle.
Aircraft, helicopters, rotors and their shadows belong to this class.
Class to backup a specific variable and restore it later.
void Restore()
Restore the variable.
Base class for all station-ish types.
TileArea train_station
Tile area the train 'station' part covers.
Owner owner
The owner of this station.
StationRect rect
NOSAVE: Station spread out rectangle maintained by StationRect::xxx() functions.
Town * town
The town this station is associated with.
static BaseStation * GetByTile(TileIndex tile)
Get the base station belonging to a specific tile.
VehicleType type
Type of vehicle.
static void AfterLoad()
Savegame conversion for cargopackets.
Helper class to perform the cargo payment.
Specification of a cargo type.
static CargoSpec * Get(size_t index)
Retrieve cargo details for the given cargo type.
TownAcceptanceEffect town_acceptance_effect
The effect that delivering this cargo type has on towns. Also affects destination of subsidies.
CompanySettings company
default values for per-company settings
Structure to return information about the closest depot location, and whether it could be found.
CompanySettings settings
settings specific for each company
static bool IsValidAiID(size_t index)
Is this company a valid company, controlled by the computer (a NoAI program)?
bool freeform_edges
allow terraforming the tiles at the map edges
uint16_t max_bridge_length
maximum length of bridges
uint16_t terraform_frame_burst
how many tile heights may, over a short period, be terraformed?
uint16_t max_tunnel_length
maximum length of tunnels
uint16_t tree_frame_burst
how many trees may, over a short period, be planted?
uint8_t map_height_limit
the maximum allowed heightlevel
uint16_t clear_frame_burst
how many tiles may, over a short period, be cleared?
uint8_t number_towns
the amount of towns
uint32_t max_loan
the maximum initial loan
uint16_t competitors_interval
the interval (in minutes) between adding competitors
uint8_t industry_density
The industry density.
Disasters, like submarines, skyrangers and their shadows, belong to this class.
TownLayout town_layout
select town layout,
TimekeepingUnits timekeeping_units
time units to use for the game economy, either calendar or wallclock
bool allow_town_level_crossings
towns are allowed to build level crossings
bool allow_town_roads
towns are allowed to build roads (always allowed when generating world / in SE)
bool station_noise_level
build new airports when the town noise level is still within accepted limits
bool infrastructure_maintenance
enable monthly maintenance fee for owner infrastructure
uint8_t feeder_payment_share
percentage of leg payment to virtually pay in feeder systems
TownCargoGenMode town_cargogen_mode
algorithm for generating cargo from houses,
uint8_t larger_towns
the number of cities to build. These start off larger and grow twice as fast
uint64_t inflation_payment
Cumulated inflation of cargo payment since game start; 16 bit fractional part.
uint64_t inflation_prices
Cumulated inflation of prices since game start; 16 bit fractional part.
Money old_max_loan_unround
Old: Unrounded max loan.
uint16_t old_max_loan_unround_fract
Old: Fraction of the unrounded max loan.
EngineMiscFlags misc_flags
Miscellaneous flags.
AbstractFileType abstract_ftype
Abstract type of file (scenario, heightmap, etc).
Basic data to distinguish a GRF.
MD5Hash md5sum
MD5 checksum of file to distinguish files with the same GRF ID (eg. newer version of GRF)
TimerGameCalendar::Year ending_year
scoring end date
LandscapeType landscape
the landscape we're currently in
uint8_t snow_line_height
the configured snow line height (deduced from "snow_coverage")
uint8_t town_name
the town name generator used for town names
TimerGameCalendar::Year starting_year
starting date
LocaleSettings locale
settings related to used currency/unit system in the current game
PathfinderSettings pf
settings for all pathfinders
EconomySettings economy
settings to change the economy
ConstructionSettings construction
construction of things in-game
DifficultySettings difficulty
settings related to the difficulty
GameCreationSettings game_creation
settings used during the creation of a game (map)
StationSettings station
settings related to station management
VehicleSettings vehicle
options for vehicles
LinkGraphSettings linkgraph
settings for link graph calculations
Stores station stats for a single cargo.
@ GES_RATING
This indicates whether a cargo has a rating at the station.
static void UpdateAfterLoad()
Update all caches after loading a game, changing NewGRF, etc.
void Reset()
Completely reset the industry build data.
Defines the data structure for constructing industry.
std::array< CargoType, INDUSTRY_NUM_INPUTS > accepts_cargo
16 accepted cargoes.
IndustryBehaviour behaviour
How this industry will behave, and how others entities can use it.
Defines the internal data of a functional industry.
static Industry * GetByTile(TileIndex tile)
Get the industry of the given tile.
uint16_t recalc_time
time (in days) for recalculating each link graph component.
DistributionType distribution_mail
distribution type for mail
DistributionType distribution_default
distribution type for all other goods
DistributionType distribution_pax
distribution type for passengers
DistributionType distribution_armoured
distribution type for armoured cargo class
uint16_t recalc_interval
time (in days) between subsequent checks for link graphs to be calculated.
uint8_t units_velocity_nautical
unit system for velocity of ships and aircraft
uint8_t currency
currency we currently use
uint8_t units_velocity
unit system for velocity of trains and road vehicles
uint8_t units_power
unit system for power
uint8_t units_height
unit system for height
uint8_t units_force
unit system for force
uint8_t units_volume
unit system for volume
uint8_t units_weight
unit system for weight
Size related data of the map.
static uint SizeY()
Get the size of the map along the Y.
static IterateWrapper Iterate()
Returns an iterable ensemble of all Tiles.
static debug_inline uint SizeX()
Get the size of the map along the X.
static uint MaxY()
Gets the maximum Y coordinate within the map, including MP_VOID.
static debug_inline uint MaxX()
Gets the maximum X coordinate within the map, including MP_VOID.
An object, such as transmitter, on the map.
ObjectType type
Type of the object.
Town * town
Town the object is built in.
static void IncTypeCount(ObjectType type)
Increment the count of objects for this type.
TimerGameCalendar::Date build_date
Date of construction.
TileArea location
Location of the object.
Data for backing up an order of a vehicle so it can be restored after a vehicle is rebuilt in the sam...
Shared order list linking together the linked list of orders and the list of vehicles sharing this or...
bool IsType(OrderType type) const
Check whether this order is of the given type.
uint16_t w
The width of the area.
TileIndex tile
The base tile of the area.
uint16_t h
The height of the area.
uint8_t wait_for_pbs_path
how long to wait for a path reservation.
uint8_t wait_oneway_signal
waitingtime in days before a oneway signal
bool reverse_at_signals
whether to reverse at signals at all
bool forbid_90_deg
forbid trains to make 90 deg turns
uint8_t wait_twoway_signal
waitingtime in days before a twoway signal
Tindex index
Index of this pool item.
static size_t GetNumItems()
Returns number of valid items in the pool.
static bool IsValidID(size_t index)
Tests whether given index can be used to get valid (non-nullptr) Titem.
static Pool::IterateWrapper< Titem > Iterate(size_t from=0)
Returns an iterable ensemble of all valid Titem.
static Titem * GetIfValid(size_t index)
Returns Titem with given index.
static bool CanAllocateItem(size_t n=1)
Helper functions so we can use PoolItem::Function() instead of _poolitem_pool.Function()
static Titem * Get(size_t index)
Returns Titem with given index.
static constexpr size_t MAX_SIZE
Make template parameter accessible from outside.
RailType railtype
Railtype, mangled if elrail is disabled.
A Stop for a Road Vehicle.
Buses, trucks and trams belong to this class.
RoadType roadtype
NOSAVE: Roadtype of this vehicle.
uint8_t acceleration
Acceleration (1 unit = 1/3.2 mph per tick = 0.5 km-ish/h per tick)
All ships have this type.
static bool IsExpected(const BaseStation *st)
Helper for checking whether the given station is of this type.
static Pool::IterateWrapper< Station > Iterate(size_t from=0)
Returns an iterable ensemble of all valid stations of type T.
static Station * Get(size_t index)
Gets station with given index.
static Station * GetIfValid(size_t index)
Returns station if the index is a valid index for this station type.
static Station * From(BaseStation *st)
Converts a BaseStation to SpecializedStation with type checking.
T * Next() const
Get next vehicle in the chain.
static Pool::IterateWrapper< T > Iterate(size_t from=0)
Returns an iterable ensemble of all valid vehicles of type T.
static T * From(Vehicle *v)
Converts a Vehicle to SpecializedVehicle with type checking.
bool modified_catchment
different-size catchment areas
bool serve_neutral_industries
company stations can serve industries with attached neutral stations
RoadStop * bus_stops
All the road stops.
static void RecomputeCatchmentForAll()
Recomputes catchment of all stations.
RoadStop * truck_stops
All the truck stops.
Struct about subsidies, offered and awarded.
'Train' is either a loco or a wagon.
Default settings for vehicles.
uint8_t plane_crashes
number of plane crashes, 0 = none, 1 = reduced, 2 = normal
uint8_t roadveh_acceleration_model
realistic acceleration for road vehicles
uint8_t roadveh_slope_steepness
Steepness of hills for road vehicles when using realistic acceleration.
uint8_t train_acceleration_model
realistic acceleration for trains
uint8_t train_slope_steepness
Steepness of hills for trains when using realistic acceleration.
uint8_t road_side
the side of the road vehicles drive on
bool dynamic_engines
enable dynamic allocation of engine data
uint8_t max_train_length
maximum length for trains
uint8_t plane_speed
divisor for speed of aircraft
bool disable_elrails
when true, the elrails are disabled
Direction direction
facing
Order current_order
The current order (+ status, like: loading)
int32_t y_pos
y coordinate.
int32_t x_pos
x coordinate.
TileIndex tile
Current tile index.
Owner owner
Which company owns the vehicle?
Representation of a waypoint.
void RebuildSubsidisedSourceAndDestinationCache()
Perform a full rebuild of the subsidies cache.
bool MayAnimateTile(TileIndex tile)
Test if a tile may be animated.
bool IsTileFlat(TileIndex tile, int *h)
Check if a given tile is flat.
int GetTileMaxZ(TileIndex t)
Get top height of the tile inside the map.
int GetTileZ(TileIndex tile)
Get bottom height of the tile.
uint TileHash(uint x, uint y)
Calculate a hash value from a tile position.
bool IsTileOwner(Tile tile, Owner owner)
Checks if a tile belongs to the given owner.
void SetTileType(Tile tile, TileType type)
Set the type of a tile.
Owner GetTileOwner(Tile tile)
Returns the owner of a tile.
void SetTileOwner(Tile tile, Owner owner)
Sets the owner of a tile.
int GetTileMaxPixelZ(TileIndex tile)
Get top height of the tile.
static debug_inline TileType GetTileType(Tile tile)
Get the tiletype of a given tile.
void SetAnimationFrame(Tile t, uint8_t frame)
Set a new animation frame.
static debug_inline bool IsTileType(Tile tile, TileType type)
Checks if a tile is a given tiletype.
Slope GetTileSlope(TileIndex tile)
Return the slope of a given tile inside the map.
void SetTropicZone(Tile tile, TropicZone type)
Set the tropic zone.
static debug_inline uint TileHeight(Tile tile)
Returns the height of a tile.
static const uint TILE_HEIGHT
Height of a height level in world coordinate AND in pixels in ZOOM_BASE.
static const uint MIN_SNOWLINE_HEIGHT
Minimum snowline height.
static const uint TILE_SIZE
Tile size in world coordinates.
static const uint TILE_UNIT_MASK
For masking in/out the inner-tile world coordinate units.
@ TROPICZONE_NORMAL
Normal tropiczone.
constexpr TileIndex INVALID_TILE
The very nice invalid tile marker.
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.
@ MP_TREES
Tile got trees.
@ MP_ROAD
A tile with road (or tram tracks)
@ MP_STATION
A tile of a station.
@ MP_TUNNELBRIDGE
Tunnel entry/exit and bridge heads.
@ MP_CLEAR
A tile without any structures, i.e. grass, rocks, farm fields etc.
@ MP_HOUSE
A house by a town.
@ MP_INDUSTRY
Part of an industry.
@ MP_VOID
Invisible tiles at the SW and SE border.
@ MP_OBJECT
Contains objects such as transmitters and owned land.
static const uint TOWN_GROWTH_WINTER
The town only needs this cargo in the winter (any amount)
const CargoSpec * FindFirstCargoWithTownAcceptanceEffect(TownAcceptanceEffect effect)
Determines the first cargo with a certain town effect.
Town * ClosestTownFromTile(TileIndex tile, uint threshold)
Return the town closest (in distance or ownership) to a given tile, within a given threshold.
static const uint TOWN_GROWTH_DESERT
The town needs the cargo for growth when on desert (any amount)
@ TOWN_CUSTOM_GROWTH
Growth rate is controlled by GS.
void UpdateTownMaxPass(Town *t)
Update the maximum amount of montly passengers and mail for a town, based on its population.
void ClearAllTownCachedNames()
Clear the cached_name of all towns.
Town * CalcClosestTownFromTile(TileIndex tile, uint threshold=UINT_MAX)
Return the town closest to the given tile within threshold.
static const uint16_t TOWN_GROWTH_RATE_NONE
Special value for Town::growth_rate to disable town growth.
void MakeDefaultName(T *obj)
Set the default name for a depot/waypoint.
void UpdateAllTownVirtCoords()
Update the virtual coords needed to draw the town sign for all towns.
HouseID GetHouseType(Tile t)
Get the type of this house, which is an index into the house spec array.
void SetHouseType(Tile t, HouseID house_id)
Set the house type.
void SetLiftPosition(Tile t, uint8_t pos)
Set the position of the lift on this animated house.
void SetHouseCompleted(Tile t, bool status)
Mark this house as been completed.
void SetTownIndex(Tile t, TownID index)
Set the town index for a road or house tile.
bool IsHouseCompleted(Tile t)
Get the completion of this house.
static constexpr int RATING_INITIAL
initial rating
@ TCGM_ORIGINAL
Original algorithm (quadratic cargo by population)
@ TL_RANDOM
Random town layout.
@ TL_BETTER_ROADS
Extended original algorithm (min. 2 distance between roads)
TrackBits DiagDirToDiagTrackBits(DiagDirection diagdir)
Maps a (4-way) direction to the diagonal track bits incidating with that diagdir.
Trackdir DiagDirToDiagTrackdir(DiagDirection diagdir)
Maps a (4-way) direction to the diagonal trackdir that runs in that direction.
TrackBits TrackStatusToTrackBits(TrackStatus ts)
Returns the present-track-information of a TrackStatus.
TrackBits
Allow incrementing of Track variables.
@ TRACK_BIT_WORMHOLE
Bitflag for a wormhole (used for tunnels)
@ TRACK_BIT_Y
Y-axis track.
@ TRACK_BIT_NONE
No track.
@ TRACK_BIT_X
X-axis track.
@ INVALID_TRACK
Flag for an invalid track.
@ TRACK_LOWER
Track in the lower corner of the tile (south)
@ TRACK_UPPER
Track in the upper corner of the tile (north)
void CheckTrainsLengths()
Checks if lengths of all rail vehicles are valid.
@ TFP_NONE
Normal operation.
@ TFP_STUCK
Proceed till next signal, but ignore being stuck till then. This includes force leaving depots.
TransportType
Available types of transport.
@ TRANSPORT_RAIL
Transport by train.
@ TRANSPORT_ROAD
Transport by road vehicle.
TreeGround GetTreeGround(Tile t)
Returns the groundtype for tree tiles.
TreeGround
Enumeration for ground types of tiles with trees.
@ TREE_GROUND_SNOW_DESERT
a desert or snow tile, depend on landscape
bool IsTunnelTile(Tile t)
Is this a tunnel (entrance)?
const uint8_t _tunnel_visibility_frame[DIAGDIR_END]
Frame when a vehicle should be hidden in a tunnel with a certain direction.
DiagDirection GetTunnelBridgeDirection(Tile t)
Get the direction pointing to the other end.
TransportType GetTunnelBridgeTransportType(Tile t)
Tunnel: Get the transport type of the tunnel (road or rail) Bridge: Get the transport type of the bri...
TileIndex GetOtherTunnelBridgeEnd(Tile t)
Determines type of the wormhole and returns its other end.
void SetTunnelBridgeReservation(Tile t, bool b)
Set the reservation state of the rail tunnel/bridge.
@ VS_STOPPED
Vehicle is stopped by the player.
@ VS_HIDDEN
Vehicle is not visible.
@ VS_CRASHED
Vehicle is crashed.
@ VF_PATHFINDER_LOST
Vehicle's pathfinder is lost.
@ VF_LOADING_FINISHED
Vehicle has finished loading.
@ VEH_INVALID
Non-existing type of vehicle.
@ VEH_ROAD
Road vehicle type.
@ VEH_SHIP
Ship vehicle type.
@ VEH_TRAIN
Train vehicle type.
void MakeVoid(Tile t)
Make a nice void tile ;)
void MakeShore(Tile t)
Helper function to make a coast tile.
void SetWaterClass(Tile t, WaterClass wc)
Set the water class at a tile.
bool IsShipDepot(Tile t)
Is it a water tile with a ship depot on it?
WaterClass
classes of water (for WATER_TILE_CLEAR water tile type).
@ WATER_CLASS_CANAL
Canal.
@ WATER_CLASS_INVALID
Used for industry tiles on land (also for oilrig if newgrf says so).
@ WATER_CLASS_RIVER
River.
bool IsShipDepotTile(Tile t)
Is it a ship depot tile?
bool IsCoast(Tile t)
Is it a coast tile?
WaterTileType GetWaterTileType(Tile t)
Get the water tile type of a tile.
void SetNonFloodingWaterTile(Tile t, bool b)
Set the non-flooding water tile state of a tile.
void SetWaterTileType(Tile t, WaterTileType type)
Set the water tile type of a tile.
WaterClass GetWaterClass(Tile t)
Get the water class at a tile.
void MakeCanal(Tile t, Owner o, uint8_t random_bits)
Make a canal tile.
uint8_t GetLockPart(Tile t)
Get the part of a lock.
TileIndex GetOtherShipDepotTile(Tile t)
Get the other tile of the ship depot.
@ WATER_TILE_LOCK
Water lock.
@ WATER_TILE_DEPOT
Water Depot.
@ WATER_TILE_CLEAR
Plain water.
void SetDockingTile(Tile t, bool b)
Set the docking tile state of a tile.
@ LOCK_PART_MIDDLE
Middle part of a lock.
bool IsWater(Tile t)
Is it a plain water tile?
bool IsLock(Tile t)
Is there a lock on a given water tile?
void MakeSea(Tile t)
Make a sea tile.
void ResetWindowSystem()
Reset the windowing system, by means of shutting it down followed by re-initialization.
void InvalidateWindowData(WindowClass cls, WindowNumber number, int data, bool gui_scope)
Mark window data of the window of a given class and specific window number as invalid (in need of re-...
void InvalidateWindowClassesData(WindowClass cls, int data, bool gui_scope)
Mark window data of all windows of a given class as invalid (in need of re-computing) Note that by de...
Window functions not directly related to making/drawing windows.
@ WC_COMPANY_INFRASTRUCTURE
Company infrastructure overview; Window numbers:
@ WC_COMPANY_COLOUR
Company colour selection; Window numbers:
@ WC_BUILD_TOOLBAR
Build toolbar; Window numbers:
void YapfNotifyTrackLayoutChange(TileIndex tile, Track track)
Use this function to notify YAPF that track layout (or signal configuration) has change.
ZoomLevel
All zoom levels we know.