TBTR: Allow cloning virtual/template trains with unavailable engines
This commit is contained in:
@@ -5221,22 +5221,14 @@ Train* CmdBuildVirtualRailWagon(const Engine *e)
|
||||
return v;
|
||||
}
|
||||
|
||||
Train* CmdBuildVirtualRailVehicle(EngineID eid, bool lax_engine_check, StringID &error)
|
||||
Train* CmdBuildVirtualRailVehicle(EngineID eid, StringID &error)
|
||||
{
|
||||
if (lax_engine_check) {
|
||||
const Engine *e = Engine::GetIfValid(eid);
|
||||
if (e == nullptr || e->type != VEH_TRAIN) {
|
||||
error = STR_ERROR_RAIL_VEHICLE_NOT_AVAILABLE + VEH_TRAIN;
|
||||
return nullptr;
|
||||
}
|
||||
} else {
|
||||
if (!IsEngineBuildable(eid, VEH_TRAIN, _current_company)) {
|
||||
error = STR_ERROR_RAIL_VEHICLE_NOT_AVAILABLE + VEH_TRAIN;
|
||||
return nullptr;
|
||||
}
|
||||
const Engine *e = Engine::GetIfValid(eid);
|
||||
if (e == nullptr || e->type != VEH_TRAIN) {
|
||||
error = STR_ERROR_RAIL_VEHICLE_NOT_AVAILABLE + VEH_TRAIN;
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
const Engine* e = Engine::Get(eid);
|
||||
const RailVehicleInfo *rvi = &e->u.rail;
|
||||
|
||||
int num_vehicles = (e->u.rail.railveh_type == RAILVEH_MULTIHEAD ? 2 : 1) + CountArticulatedParts(eid, false);
|
||||
@@ -5331,7 +5323,7 @@ CommandCost CmdBuildVirtualRailVehicle(TileIndex tile, DoCommandFlag flags, uint
|
||||
|
||||
if (should_execute) {
|
||||
StringID err = INVALID_STRING_ID;
|
||||
Train* train = CmdBuildVirtualRailVehicle(eid, false, err);
|
||||
Train* train = CmdBuildVirtualRailVehicle(eid, err);
|
||||
|
||||
if (train == nullptr) {
|
||||
return_cmd_error(err);
|
||||
|
Reference in New Issue
Block a user