Base class for all vehicles. More...
#include "track_type.h"#include "command_type.h"#include "order_base.h"#include "cargopacket.h"#include "texteff.hpp"#include "engine_type.h"#include "order_func.h"#include "transport_type.h"#include "group_type.h"Go to the source code of this file.
| Data Structures | |
| struct | NewGRFCache | 
| Cached often queried (NewGRF) values.  More... | |
| struct | VehicleCache | 
| Cached often queried values common to all vehicles.  More... | |
| struct | Vehicle | 
| Vehicle data structure.  More... | |
| struct | SpecializedVehicle< T, Type > | 
| Class defining several overloaded accessors so we don't have to cast vehicle types that often.  More... | |
| struct | DisasterVehicle | 
| Disasters, like submarines, skyrangers and their shadows, belong to this class.  More... | |
| struct | FreeUnitIDGenerator | 
| Generates sequence of free UnitID numbers.  More... | |
| Defines | |
| #define | FOR_ALL_VEHICLES_FROM(var, start) FOR_ALL_ITEMS_FROM(Vehicle, vehicle_index, var, start) | 
| Iterate over all vehicles from a given point. | |
| #define | FOR_ALL_VEHICLES(var) FOR_ALL_VEHICLES_FROM(var, 0) | 
| Iterate over all vehicles. | |
| #define | FOR_ALL_VEHICLES_OF_TYPE(name, var) FOR_ALL_ITEMS_FROM(name, vehicle_index, var, 0) if (var->type == name::EXPECTED_TYPE) | 
| Iterate over all vehicles of a particular type. | |
| #define | FOR_ALL_DISASTERVEHICLES(var) FOR_ALL_VEHICLES_OF_TYPE(DisasterVehicle, var) | 
| Iterate over disaster vehicles. | |
| Typedefs | |
| typedef Pool< Vehicle, VehicleID, 512, 0xFF000 > | VehiclePool | 
| A vehicle pool for a little over 1 million vehicles. | |
| Enumerations | |
| enum | VehStatus { VS_HIDDEN = 0x01, VS_STOPPED = 0x02, VS_UNCLICKABLE = 0x04, VS_DEFPAL = 0x08, VS_TRAIN_SLOWING = 0x10, VS_SHADOW = 0x20, VS_AIRCRAFT_BROKEN = 0x40, VS_CRASHED = 0x80 } | 
| Vehicle status bits in Vehicle::vehstatus.More... | |
| enum | VehicleFlags { VF_LOADING_FINISHED, VF_CARGO_UNLOADING, VF_BUILT_AS_PROTOTYPE, VF_TIMETABLE_STARTED, VF_AUTOFILL_TIMETABLE, VF_AUTOFILL_PRES_WAIT_TIME, VF_STOP_LOADING, VF_PATHFINDER_LOST } | 
| Bit numbers in Vehicle::vehicle_flags.More... | |
| enum | NewGRFCacheValidValues { NCVV_POSITION_CONSIST_LENGTH = 0, NCVV_POSITION_SAME_ID_LENGTH = 1, NCVV_CONSIST_CARGO_INFORMATION = 2, NCVV_COMPANY_INFORMATION = 3, NCVV_END } | 
| Bit numbers used to indicate which of the NewGRFCache values are valid.More... | |
| enum | VisualEffect { VE_OFFSET_START = 0, VE_OFFSET_COUNT = 4, VE_OFFSET_CENTRE = 8, VE_TYPE_START = 4, VE_TYPE_COUNT = 2, VE_TYPE_DEFAULT = 0, VE_TYPE_STEAM = 1, VE_TYPE_DIESEL = 2, VE_TYPE_ELECTRIC = 3, VE_DISABLE_EFFECT = 6, VE_DISABLE_WAGON_POWER = 7, VE_DEFAULT = 0xFF } | 
| Meaning of the various bits of the visual effect.More... | |
| enum | GroundVehicleSubtypeFlags { GVSF_FRONT = 0, GVSF_ARTICULATED_PART = 1, GVSF_WAGON = 2, GVSF_ENGINE = 3, GVSF_FREE_WAGON = 4, GVSF_MULTIHEADED = 5 } | 
| Enum to handle ground vehicle subtypes.More... | |
| Functions | |
| const SaveLoad * | GetVehicleDescription (VehicleType vt) | 
| Make it possible to make the saveload tables "friends" of other classes. | |
| bool | LoadOldVehicle (LoadgameState *ls, int num) | 
| Load the vehicles of an old style savegame. | |
| void | FixOldVehicles () | 
| Convert the old style vehicles into something that resembles the old new style savegames. | |
| Variables | |
| VehiclePool | _vehicle_pool | 
| The pool with all our precious vehicles. | |
| static const int32 | INVALID_COORD = 0x7fffffff | 
| Sentinel for an invalid coordinate. | |
Base class for all vehicles.
Definition in file vehicle_base.h.
| #define FOR_ALL_DISASTERVEHICLES | ( | var | ) | FOR_ALL_VEHICLES_OF_TYPE(DisasterVehicle, var) | 
Iterate over disaster vehicles.
| var | The variable used to iterate over. | 
Definition at line 1032 of file vehicle_base.h.
Referenced by AfterLoadGame(), ReleaseDisastersTargetingIndustry(), and ReleaseDisastersTargetingVehicle().
| #define FOR_ALL_VEHICLES | ( | var | ) | FOR_ALL_VEHICLES_FROM(var, 0) | 
Iterate over all vehicles.
| var | The variable used to iterate over. | 
Definition at line 846 of file vehicle_base.h.
Referenced by CargoPacket::AfterLoad(), AfterLoadGame(), AfterLoadVehicles(), BuildDepotVehicleList(), CalculateCompanyValue(), CanBuildVehicleInfrastructure(), ChangeOwnershipOfCompanyItems(), CheckCaches(), CheckClickOnVehicle(), CheckValidVehicles(), CmdAddSharedVehicleGroup(), CmdRemoveAllVehiclesGroup(), CmdSetCompanyColour(), DisasterTick_Big_Ufo(), SmallMapWindow::DrawVehicles(), FixOldVehicles(), FixTTOEngines(), FixupTrainLengths(), FreeUnitIDGenerator::FreeUnitIDGenerator(), GenerateVehicleSortList(), HasStationInUse(), IsUniqueVehicleName(), MoveBuoysToWaypoints(), MoveWaypointsToBaseStations(), NetworkAutoCleanCompanies(), NetworkPopulateCompanyStats(), NewVehicleAvailable(), OnNewYear(), RemoveOrderFromAllVehicles(), EngineOverrideManager::ResetToCurrentNewGRFConfig(), Save_VEHS(), GroupStatistics::UpdateAfterLoad(), UpdateCompanyRatingAndValue(), GroupStatistics::UpdateProfits(), WhoCanServiceIndustry(), and Station::~Station().
| #define FOR_ALL_VEHICLES_FROM | ( | var, | ||
| start | ||||
| ) | FOR_ALL_ITEMS_FROM(Vehicle, vehicle_index, var, start) | 
Iterate over all vehicles from a given point.
| var | The variable used to iterate over. | |
| start | The vehicle to start the iteration at. | 
Definition at line 840 of file vehicle_base.h.
| #define FOR_ALL_VEHICLES_OF_TYPE | ( | name, | ||
| var | ||||
| ) | FOR_ALL_ITEMS_FROM(name, vehicle_index, var, 0) if (var->type == name::EXPECTED_TYPE) | 
Iterate over all vehicles of a particular type.
| name | The type of vehicle to iterate over. | |
| var | The variable used to iterate over. | 
Definition at line 1010 of file vehicle_base.h.
A vehicle pool for a little over 1 million vehicles.
Definition at line 110 of file vehicle_base.h.
Enum to handle ground vehicle subtypes.
This is defined here instead of at GroundVehicle because some common function require access to these flags. Do not access it directly unless you have to. Use the subtype access functions.
| GVSF_FRONT | Leading engine of a consist. | 
| GVSF_ARTICULATED_PART | Articulated part of an engine. | 
| GVSF_WAGON | Wagon (not used for road vehicles). | 
| GVSF_ENGINE | Engine that can be front engine, but might be placed behind another engine (not used for road vehicles). | 
| GVSF_FREE_WAGON | First in a wagon chain (in depot) (not used for road vehicles). | 
| GVSF_MULTIHEADED | Engine is multiheaded (not used for road vehicles). | 
Definition at line 92 of file vehicle_base.h.
Bit numbers used to indicate which of the NewGRFCache values are valid.
Definition at line 50 of file vehicle_base.h.
| enum VehicleFlags | 
Bit numbers in Vehicle::vehicle_flags.
| VF_LOADING_FINISHED | Vehicle has finished loading. | 
| VF_CARGO_UNLOADING | Vehicle is unloading cargo. | 
| VF_BUILT_AS_PROTOTYPE | Vehicle is a prototype (accepted as exclusive preview). | 
| VF_TIMETABLE_STARTED | Whether the vehicle has started running on the timetable yet. | 
| VF_AUTOFILL_TIMETABLE | Whether the vehicle should fill in the timetable automatically. | 
| VF_AUTOFILL_PRES_WAIT_TIME | Whether non-destructive auto-fill should preserve waiting times. | 
| VF_STOP_LOADING | Don't load anymore during the next load cycle. | 
| VF_PATHFINDER_LOST | Vehicle's pathfinder is lost. | 
Definition at line 38 of file vehicle_base.h.
| enum VehStatus | 
Vehicle status bits in Vehicle::vehstatus.
| VS_HIDDEN | Vehicle is not visible. | 
| VS_STOPPED | Vehicle is stopped by the player. | 
| VS_UNCLICKABLE | Vehicle is not clickable by the user (shadow vehicles). | 
| VS_DEFPAL | Use default vehicle palette. 
 | 
| VS_TRAIN_SLOWING | Train is slowing down. | 
| VS_SHADOW | Vehicle is a shadow vehicle. | 
| VS_AIRCRAFT_BROKEN | Aircraft is broken down. | 
| VS_CRASHED | Vehicle is crashed. | 
Definition at line 26 of file vehicle_base.h.
| enum VisualEffect | 
Meaning of the various bits of the visual effect.
Definition at line 69 of file vehicle_base.h.
| void FixOldVehicles | ( | ) | 
Convert the old style vehicles into something that resembles the old new style savegames.
Then AfterLoadGame can handle the rest of the conversion.
Definition at line 171 of file oldloader_sl.cpp.
References _m, ClrBit(), CopyFromOldName(), Vehicle::current_order, FOR_ALL_VEHICLES, SpecializedVehicle< RoadVehicle, Type >::From(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_vehicle_pool >::GetIfValid(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, IsCompanyBuildableVehicleType(), Vehicle::IsPrimaryVehicle(), IsTileType(), Order::IsType(), Tile::m5, Order::MakeDummy(), MP_STATION, Vehicle::name, Vehicle::next, RVS_IN_DT_ROAD_STOP, RVSB_IN_DEPOT, RVSB_WORMHOLE, SetBit(), Vehicle::spritenum, RoadVehicle::state, Vehicle::subtype, Vehicle::tile, BaseVehicle::type, VEH_EFFECT, VEH_ROAD, and VEH_SHIP.
| const SaveLoad* GetVehicleDescription | ( | VehicleType | vt | ) | 
Make it possible to make the saveload tables "friends" of other classes.
| vt | the vehicle type. Can be VEH_END for the common vehicle description data | 
So we can use private/protected variables in the saveload code.
Saving and loading the current order of vehicles.
The vehicles have a cargo list (and we want that saved).
| vt | the vehicle type. Can be VEH_END for the common vehicle description data | 
Save and load of vehicles
Save and load of vehicles
Definition at line 553 of file vehicle_sl.cpp.
References REF_CARGO_PACKET, REF_ORDER, REF_ORDERLIST, REF_VEHICLE, REF_VEHICLE_OLD, SL_MAX_VERSION, SLE_CONDLST, SLE_CONDNULL, SLE_CONDREF, SLE_CONDSTR, SLE_CONDVAR, SLE_END, SLE_REF, SLE_STR, SLE_VAR, SLE_WRITEBYTE, SLEG_CONDVAR, SLF_ALLOW_CONTROL, VEH_AIRCRAFT, VEH_DISASTER, VEH_EFFECT, VEH_ROAD, VEH_SHIP, and VEH_TRAIN.
Referenced by Load_VEHS(), and Save_VEHS().
| bool LoadOldVehicle | ( | LoadgameState * | ls, | |
| int | num | |||
| ) | 
Load the vehicles of an old style savegame.
| ls | State (buffer) of the currently loaded game. | |
| num | The number of vehicles to load. | 
So we can set the proper next pointer while loading.
| ls | State (buffer) of the currently loaded game. | |
| num | The number of vehicles to load. | 
Definition at line 1228 of file oldloader_sl.cpp.
References _old_vehicle_multiplier, CargoList< Tinst >::Append(), Order::AssignOrder(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_cargopacket_pool >::CanAllocateItem(), Vehicle::cargo, Vehicle::cargo_type, Vehicle::cur_image, Vehicle::current_order, DEBUG, SpecializedVehicle< Train, Type >::From(), SpecializedStation< Station, false >::Get(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_order_pool >::Get(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, IsInsideMM(), lengthof, LoadChunk(), max(), Vehicle::next, Vehicle::old, Vehicle::orders, ReadByte(), RemapOldStringID(), SGT_TTO, SlErrorCorrupt(), Vehicle::spritenum, BaseVehicle::type, UnpackOldOrder(), VEH_ROAD, VEH_SHIP, VEH_TRAIN, and BaseStation::xy.
The pool with all our precious vehicles.
| const int32 INVALID_COORD = 0x7fffffff  [static] | 
Sentinel for an invalid coordinate.
Definition at line 1048 of file vehicle_base.h.
Referenced by AfterLoadVehicles(), Vehicle::Vehicle(), and Vehicle::~Vehicle().
 1.7.1
 1.7.1