OpenTTD Source 20241224-master-gee860a5c8e
|
Handling of the engine groups. More...
#include "stdafx.h"
#include "command_func.h"
#include "train.h"
#include "vehiclelist.h"
#include "vehicle_func.h"
#include "autoreplace_base.h"
#include "autoreplace_func.h"
#include "string_func.h"
#include "company_func.h"
#include "core/pool_func.hpp"
#include "order_backup.h"
#include "group_cmd.h"
#include "table/strings.h"
#include "safeguards.h"
Go to the source code of this file.
Functions | |
static void | UpdateNumEngineGroup (const Vehicle *v, GroupID old_g, GroupID new_g) |
Update the num engines of a groupID. | |
const Livery * | GetParentLivery (const Group *g) |
static void | PropagateChildLivery (const Group *g, bool reset_cache) |
Propagate a livery change to a group's children, and optionally update cached vehicle colourmaps. | |
void | UpdateCompanyGroupLiveries (const Company *c) |
Update group liveries for a company. | |
std::tuple< CommandCost, GroupID > | CmdCreateGroup (DoCommandFlag flags, VehicleType vt, GroupID parent_group) |
Create a new vehicle group. | |
CommandCost | CmdDeleteGroup (DoCommandFlag flags, GroupID group_id) |
Add all vehicles in the given group to the default group and then deletes the group. | |
CommandCost | CmdAlterGroup (DoCommandFlag flags, AlterGroupMode mode, GroupID group_id, GroupID parent_id, const std::string &text) |
Alter a group. | |
static void | AddVehicleToGroup (Vehicle *v, GroupID new_g) |
Do add a vehicle to a group. | |
std::tuple< CommandCost, GroupID > | CmdAddVehicleGroup (DoCommandFlag flags, GroupID group_id, VehicleID veh_id, bool add_shared, const VehicleListIdentifier &vli) |
Add a vehicle to a group. | |
CommandCost | CmdAddSharedVehicleGroup (DoCommandFlag flags, GroupID id_g, VehicleType type) |
Add all shared vehicles of all vehicles from a group. | |
CommandCost | CmdRemoveAllVehiclesGroup (DoCommandFlag flags, GroupID group_id) |
Remove all vehicles from a group. | |
CommandCost | CmdSetGroupLivery (DoCommandFlag flags, GroupID group_id, bool primary, Colours colour) |
Set the livery for a vehicle group. | |
static void | SetGroupFlag (Group *g, GroupFlags flag, bool set, bool children) |
Set group flag for a group and its sub-groups. | |
CommandCost | CmdSetGroupFlag (DoCommandFlag flags, GroupID group_id, GroupFlags flag, bool value, bool recursive) |
(Un)set group flag from a group | |
void | SetTrainGroupID (Train *v, GroupID new_g) |
Affect the groupID of a train to new_g. | |
void | UpdateTrainGroupID (Train *v) |
Recalculates the groupID of a train. | |
uint | GetGroupNumEngines (CompanyID company, GroupID id_g, EngineID id_e) |
Get the number of engines with EngineID id_e in the group with GroupID id_g and its sub-groups. | |
uint | GetGroupNumVehicle (CompanyID company, GroupID id_g, VehicleType type) |
Get the number of vehicles in the group with GroupID id_g and its sub-groups. | |
uint | GetGroupNumVehicleMinAge (CompanyID company, GroupID id_g, VehicleType type) |
Get the number of vehicles above profit minimum age in the group with GroupID id_g and its sub-groups. | |
Money | GetGroupProfitLastYearMinAge (CompanyID company, GroupID id_g, VehicleType type) |
Get last year's profit of vehicles above minimum age for the group with GroupID id_g and its sub-groups. | |
void | RemoveAllGroupsForCompany (const CompanyID company) |
bool | GroupIsInGroup (GroupID search, GroupID group) |
Test if GroupID group is a descendant of (or is) GroupID search. | |
Variables | |
GroupPool | _group_pool ("Group") |
Handling of the engine groups.
Definition in file group_cmd.cpp.
Do add a vehicle to a group.
Definition at line 503 of file group_cmd.cpp.
References GroupStatistics::CountVehicle(), SpecializedVehicle< T, Type >::From(), Vehicle::group_id, Vehicle::IsEngineCountable(), Vehicle::Next(), SetTrainGroupID(), BaseVehicle::type, UpdateNumEngineGroup(), VEH_AIRCRAFT, VEH_ROAD, VEH_SHIP, and VEH_TRAIN.
Referenced by CmdAddVehicleGroup().
CommandCost CmdAddSharedVehicleGroup | ( | DoCommandFlag | flags, |
GroupID | id_g, | ||
VehicleType | type | ||
) |
Add all shared vehicles of all vehicles from a group.
flags | type of operation |
id_g | index of group |
type | type of vehicles |
Definition at line 606 of file group_cmd.cpp.
References _current_company, CMD_ERROR, DC_EXEC, Vehicle::FirstShared(), GetWindowClassForVehicleType(), InvalidateWindowData(), IsCompanyBuildableVehicleType(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::IsValidID(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_vehicle_pool >::Iterate(), and Vehicle::NextShared().
std::tuple< CommandCost, GroupID > CmdAddVehicleGroup | ( | DoCommandFlag | flags, |
GroupID | group_id, | ||
VehicleID | veh_id, | ||
bool | add_shared, | ||
const VehicleListIdentifier & | vli | ||
) |
Add a vehicle to a group.
flags | type of operation |
group_id | index of group |
veh_id | vehicle to add to a group |
add_shared | Add shared vehicles as well. |
Definition at line 537 of file group_cmd.cpp.
References _current_company, AddVehicleToGroup(), CMD_ERROR, CmdCreateGroup(), DC_EXEC, Vehicle::FirstShared(), GenerateVehicleSortList(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_vehicle_pool >::Get(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::Get(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_vehicle_pool >::GetIfValid(), GetWindowClassForVehicleType(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, INVALID_GROUP, INVALID_VEHICLE, InvalidateWindowData(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::IsValidID(), NEW_GROUP, Group::owner, SetWindowDirty(), Vehicle::tile, GroupStatistics::UpdateAutoreplace(), Group::vehicle_type, WC_REPLACE_VEHICLE, WC_VEHICLE_DEPOT, WC_VEHICLE_DETAILS, and WC_VEHICLE_VIEW.
CommandCost CmdAlterGroup | ( | DoCommandFlag | flags, |
AlterGroupMode | mode, | ||
GroupID | group_id, | ||
GroupID | parent_id, | ||
const std::string & | text | ||
) |
Alter a group.
flags | type of operation |
mode | Operation to perform. |
group_id | GroupID |
parent_id | parent group index |
text | the new name or an empty string when resetting to the default |
Definition at line 434 of file group_cmd.cpp.
References _current_company, CMD_ERROR, Livery::colour1, Livery::colour2, DC_EXEC, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::GetIfValid(), GetWindowClassForVehicleType(), GroupIsInGroup(), HasBit(), Livery::in_use, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, INVALID_GROUP, InvalidateWindowClassesData(), InvalidateWindowData(), Group::livery, MarkWholeScreenDirty(), MAX_LENGTH_GROUP_NAME_CHARS, Group::name, Group::owner, VehicleListIdentifier::Pack(), Group::parent, PropagateChildLivery(), Rename, SetParent, GroupStatistics::UpdateAutoreplace(), Utf8StringLength(), Group::vehicle_type, WC_COMPANY_COLOUR, WC_REPLACE_VEHICLE, WC_VEHICLE_DETAILS, and WC_VEHICLE_VIEW.
std::tuple< CommandCost, GroupID > CmdCreateGroup | ( | DoCommandFlag | flags, |
VehicleType | vt, | ||
GroupID | parent_group | ||
) |
Create a new vehicle group.
flags | type of operation |
vt | vehicle type |
parent_group | parent groupid |
Definition at line 336 of file group_cmd.cpp.
References _current_company, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::CanAllocateItem(), CMD_ERROR, Livery::colour1, Livery::colour2, DC_EXEC, Group::flags, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_company_pool >::Get(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::GetIfValid(), GetWindowClassForVehicleType(), GF_REPLACE_WAGON_REMOVAL, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, INVALID_GROUP, InvalidateWindowData(), IsCompanyBuildableVehicleType(), Group::livery, FreeUnitIDGenerator::NextID(), Group::number, Group::owner, Group::parent, CompanySettings::renew_keep_length, SetBit(), CompanyProperties::settings, FreeUnitIDGenerator::UseID(), Group::vehicle_type, and WC_COMPANY_COLOUR.
Referenced by CmdAddVehicleGroup().
CommandCost CmdDeleteGroup | ( | DoCommandFlag | flags, |
GroupID | group_id | ||
) |
Add all vehicles in the given group to the default group and then deletes the group.
flags | type of operation |
group_id | index of group |
Definition at line 382 of file group_cmd.cpp.
References _current_company, OrderBackup::ClearGroup(), CloseWindowById(), CMD_ERROR, DC_EXEC, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_company_pool >::Get(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::GetIfValid(), GetWindowClassForVehicleType(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, InvalidateWindowData(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::Iterate(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_enginerenew_pool >::Iterate(), MAX_COMPANIES, Group::number, Group::owner, FreeUnitIDGenerator::ReleaseID(), RemoveEngineReplacementForCompany(), Group::vehicle_type, WC_COMPANY_COLOUR, and WC_REPLACE_VEHICLE.
CommandCost CmdRemoveAllVehiclesGroup | ( | DoCommandFlag | flags, |
GroupID | group_id | ||
) |
Remove all vehicles from a group.
flags | type of operation |
group_id | index of group |
Definition at line 637 of file group_cmd.cpp.
References _current_company, CMD_ERROR, DC_EXEC, DEFAULT_GROUP, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::GetIfValid(), GetWindowClassForVehicleType(), InvalidateWindowData(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_vehicle_pool >::Iterate(), Group::owner, VehicleListIdentifier::Pack(), and Group::vehicle_type.
CommandCost CmdSetGroupFlag | ( | DoCommandFlag | flags, |
GroupID | group_id, | ||
GroupFlags | flag, | ||
bool | value, | ||
bool | recursive | ||
) |
(Un)set group flag from a group
flags | type of operation |
group_id | index of group array |
flag | flag to set, by value not bit. |
value | value to set the flag to. |
recursive | to apply to sub-groups. |
Definition at line 722 of file group_cmd.cpp.
References _current_company, CMD_ERROR, DC_EXEC, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::GetIfValid(), GetWindowClassForVehicleType(), InvalidateWindowData(), Group::owner, VehicleListIdentifier::Pack(), SetGroupFlag(), SetWindowDirty(), Group::vehicle_type, and WC_REPLACE_VEHICLE.
CommandCost CmdSetGroupLivery | ( | DoCommandFlag | flags, |
GroupID | group_id, | ||
bool | primary, | ||
Colours | colour | ||
) |
Set the livery for a vehicle group.
flags | Command flags. |
group_id | Group ID. |
primary | Set primary instead of secondary colour |
colour | Colour. |
Definition at line 667 of file group_cmd.cpp.
References _current_company, AssignBit(), CMD_ERROR, Livery::colour1, Livery::colour2, DC_EXEC, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::GetIfValid(), Livery::in_use, Group::livery, MarkWholeScreenDirty(), Group::owner, and PropagateChildLivery().
Get the number of engines with EngineID id_e in the group with GroupID id_g and its sub-groups.
company | The company the group belongs to |
id_g | The GroupID of the group used |
id_e | The EngineID of the engine to count |
Definition at line 799 of file group_cmd.cpp.
References GroupStatistics::Get(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_engine_pool >::Get(), GetGroupNumEngines(), GroupStatistics::GetNumEngines(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::Iterate(), Group::parent, and Engine::type.
Referenced by DrawEngineList(), ReplaceVehicleWindow::GenerateReplaceVehList(), GetGroupNumEngines(), InvalidateAutoreplaceWindow(), ReplaceVehicleWindow::OnClick(), and GroupStatistics::UpdateAutoreplace().
uint GetGroupNumVehicle | ( | CompanyID | company, |
GroupID | id_g, | ||
VehicleType | type | ||
) |
Get the number of vehicles in the group with GroupID id_g and its sub-groups.
company | The company the group belongs to |
id_g | The GroupID of the group used |
type | The vehicle type of the group |
Definition at line 817 of file group_cmd.cpp.
References GroupStatistics::Get(), GetGroupNumVehicle(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::Iterate(), GroupStatistics::num_vehicle, and Group::parent.
Referenced by VehicleGroupWindow::ComputeGroupInfoSize(), VehicleGroupWindow::DrawGroupInfo(), GetGroupNumVehicle(), and VehicleGroupWindow::SetStringParameters().
uint GetGroupNumVehicleMinAge | ( | CompanyID | company, |
GroupID | id_g, | ||
VehicleType | type | ||
) |
Get the number of vehicles above profit minimum age in the group with GroupID id_g and its sub-groups.
company | The company the group belongs to |
id_g | The GroupID of the group used |
type | The vehicle type of the group |
Definition at line 834 of file group_cmd.cpp.
References GroupStatistics::Get(), GetGroupNumVehicleMinAge(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::Iterate(), GroupStatistics::num_vehicle_min_age, and Group::parent.
Referenced by VehicleGroupWindow::DrawGroupInfo(), and GetGroupNumVehicleMinAge().
Money GetGroupProfitLastYearMinAge | ( | CompanyID | company, |
GroupID | id_g, | ||
VehicleType | type | ||
) |
Get last year's profit of vehicles above minimum age for the group with GroupID id_g and its sub-groups.
company | The company the group belongs to |
id_g | The GroupID of the group used |
type | The vehicle type of the group |
Definition at line 851 of file group_cmd.cpp.
References GroupStatistics::Get(), GetGroupProfitLastYearMinAge(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::Iterate(), Group::parent, and GroupStatistics::profit_last_year_min_age.
Referenced by VehicleGroupWindow::DrawGroupInfo(), and GetGroupProfitLastYearMinAge().
Definition at line 266 of file group_cmd.cpp.
Test if GroupID group is a descendant of (or is) GroupID search.
search | The GroupID to search in |
group | The GroupID to search for |
Definition at line 874 of file group_cmd.cpp.
References Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::Get(), INVALID_GROUP, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::IsValidID(), and Group::parent.
Referenced by CmdAlterGroup(), GenerateVehicleSortList(), and GetEngineReplacement().
|
static |
Propagate a livery change to a group's children, and optionally update cached vehicle colourmaps.
g | Group to propagate colours to children. |
reset_cache | Reset colourmap of vehicles in this group. |
Definition at line 283 of file group_cmd.cpp.
References Livery::colour1, Livery::colour2, HasBit(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::Iterate(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_vehicle_pool >::Iterate(), Group::livery, Vehicle::Next(), and PropagateChildLivery().
Referenced by CmdAlterGroup(), CmdSetGroupLivery(), PropagateChildLivery(), and UpdateCompanyGroupLiveries().
void RemoveAllGroupsForCompany | ( | const CompanyID | company | ) |
Definition at line 860 of file group_cmd.cpp.
|
static |
Set group flag for a group and its sub-groups.
g | initial group. |
set | 1 to set or 0 to clear protection. |
Definition at line 698 of file group_cmd.cpp.
References ClrBit(), Group::flags, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::Iterate(), SetBit(), and SetGroupFlag().
Referenced by CmdSetGroupFlag(), and SetGroupFlag().
Affect the groupID of a train to new_g.
v | First vehicle of the chain. |
new_g | index of array group |
Definition at line 745 of file group_cmd.cpp.
References Vehicle::IsFrontEngine(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::IsValidID(), SpecializedVehicle< T, Type >::Next(), Vehicle::owner, SetWindowDirty(), GroupStatistics::UpdateAutoreplace(), UpdateNumEngineGroup(), VEH_TRAIN, and WC_REPLACE_VEHICLE.
Referenced by AddVehicleToGroup(), and CmdMoveRailVehicle().
void UpdateCompanyGroupLiveries | ( | const Company * | c | ) |
Update group liveries for a company.
This is called when the LS_DEFAULT scheme is changed, to update groups with colours set to default.
c | Company to update. |
Definition at line 311 of file group_cmd.cpp.
References Livery::colour1, Livery::colour2, HasBit(), Livery::in_use, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, INVALID_GROUP, Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_group_pool >::Iterate(), Group::livery, Group::owner, Group::parent, and PropagateChildLivery().
Referenced by UpdateCompanyLiveries().
Update the num engines of a groupID.
Decrease the old one and increase the new one
v | Vehicle we have to update |
old_g | index of the old group |
new_g | index of the new group |
Definition at line 254 of file group_cmd.cpp.
References Vehicle::engine_type, GroupStatistics::Get(), GroupStatistics::num_engines, Vehicle::owner, and BaseVehicle::type.
Referenced by AddVehicleToGroup(), SetTrainGroupID(), and UpdateTrainGroupID().
void UpdateTrainGroupID | ( | Train * | v | ) |
Recalculates the groupID of a train.
Should be called each time a vehicle is added to/removed from the chain,.
v | First vehicle of the chain. |
Definition at line 773 of file group_cmd.cpp.
References DEFAULT_GROUP, Vehicle::group_id, GroundVehicle< T, Type >::IsFreeWagon(), Vehicle::IsFrontEngine(), SpecializedVehicle< T, Type >::Next(), Vehicle::owner, SetWindowDirty(), GroupStatistics::UpdateAutoreplace(), UpdateNumEngineGroup(), VEH_TRAIN, and WC_REPLACE_VEHICLE.
Referenced by CmdBuildRailVehicle(), CmdBuildRailWagon(), and NormaliseTrainHead().