diff --git a/src/action/action_die.cpp b/src/action/action_die.cpp index 93092b8372..2141162e74 100644 --- a/src/action/action_die.cpp +++ b/src/action/action_die.cpp @@ -125,7 +125,7 @@ void COrder_Die::Execute(CUnit &unit) /* override */ unit.Remove(nullptr); unit.Type = &corpseType; - unit.Stats = &corpseType.Stats[unit.Player->Index]; + unit.Stats = const_cast(&corpseType.Stats[unit.Player->Index]); UpdateUnitSightRange(unit); unit.Place(unit.tilePos); diff --git a/src/action/action_upgradeto.cpp b/src/action/action_upgradeto.cpp index bb348771d8..2416bc1b1f 100644 --- a/src/action/action_upgradeto.cpp +++ b/src/action/action_upgradeto.cpp @@ -156,7 +156,7 @@ static int TransformUnitIntoType(CUnit &unit, const CUnitType &newtype) } unit.Type = const_cast(&newtype); - unit.Stats = &unit.Type->Stats[player.Index]; + unit.Stats = const_cast(&unit.Type->Stats[player.Index]); if (!newtype.CanCastSpell.empty() && !unit.AutoCastSpell) { unit.AutoCastSpell = new char[SpellTypeTable.size()]; diff --git a/src/include/unit.h b/src/include/unit.h index 6592b68931..923079627d 100644 --- a/src/include/unit.h +++ b/src/include/unit.h @@ -342,7 +342,7 @@ class CUnit const CUnitType *Type = nullptr; /// Pointer to unit-type (peon,...) CPlayer *Player = nullptr; /// Owner of this unit - const CUnitStats *Stats = nullptr; /// Current unit stats + CUnitStats *Stats = nullptr; /// Current unit stats int CurrentSightRange; /// Unit's Current Sight Range // Pathfinding stuff: diff --git a/src/include/upgrade_structs.h b/src/include/upgrade_structs.h index 47edfc8392..a245441014 100644 --- a/src/include/upgrade_structs.h +++ b/src/include/upgrade_structs.h @@ -110,14 +110,14 @@ class CUnitStats { public: CUnitStats() = default; - ~CUnitStats(); + ~CUnitStats() = default; CUnitStats &operator=(const CUnitStats &rhs); bool operator == (const CUnitStats &rhs) const; bool operator != (const CUnitStats &rhs) const; public: - CVariable *Variables = nullptr; /// user defined variable. + std::vector Variables; /// user defined variable. int Costs[MaxCosts]{}; /// current costs of the unit int Storing[MaxCosts]{}; /// storage increasing int ImproveIncomes[MaxCosts]{}; /// Gives player an improved income diff --git a/src/unit/script_unittype.cpp b/src/unit/script_unittype.cpp index e9c2c5651d..e96af2eb60 100644 --- a/src/unit/script_unittype.cpp +++ b/src/unit/script_unittype.cpp @@ -1405,8 +1405,8 @@ static int CclDefineUnitStats(lua_State *l) Assert(playerId < PlayerMax); CUnitStats *stats = &type.Stats[playerId]; - if (!stats->Variables) { - stats->Variables = new CVariable[UnitTypeVar.GetNumberVariable()]; + if (stats->Variables.empty()) { + stats->Variables.resize(UnitTypeVar.GetNumberVariable()); } // Parse the list: (still everything could be changed!) diff --git a/src/unit/unit.cpp b/src/unit/unit.cpp index cab6758e58..aa71356fce 100644 --- a/src/unit/unit.cpp +++ b/src/unit/unit.cpp @@ -621,7 +621,7 @@ void CUnit::Init(const CUnitType &type) Assert(!Variable); const unsigned int size = UnitTypeVar.GetNumberVariable(); Variable = new CVariable[size]; - std::copy(type.MapDefaultStat.Variables, type.MapDefaultStat.Variables + size, Variable); + std::copy(type.MapDefaultStat.Variables.begin(), type.MapDefaultStat.Variables.end(), Variable); } else { Variable = nullptr; } @@ -746,12 +746,12 @@ void CUnit::AssignToPlayer(CPlayer &player) } } Player = &player; - Stats = &type.Stats[Player->Index]; + Stats = const_cast(&type.Stats[Player->Index]); if (!SaveGameLoading) { if (UnitTypeVar.GetNumberVariable()) { Assert(Variable); - Assert(Stats->Variables); - memcpy(Variable, Stats->Variables, UnitTypeVar.GetNumberVariable() * sizeof(*Variable)); + Assert(Stats->Variables.size() == UnitTypeVar.GetNumberVariable()); + std::copy(Stats->Variables.begin(), Stats->Variables.end(), Variable); } } } @@ -1870,7 +1870,7 @@ void CUnit::ChangeOwner(CPlayer &newplayer) MapUnmarkUnitSight(*this); newplayer.AddUnit(*this); - Stats = &Type->Stats[newplayer.Index]; + Stats = const_cast(&Type->Stats[newplayer.Index]); UpdateUnitSightRange(*this); MapMarkUnitSight(*this); diff --git a/src/unit/unittype.cpp b/src/unit/unittype.cpp index f622060452..3cf9a3b535 100644 --- a/src/unit/unittype.cpp +++ b/src/unit/unittype.cpp @@ -824,10 +824,8 @@ std::pair NewUnitTypeSlot(std::string_view ident) type->Ident = ident; type->BoolFlag.resize(new_bool_size); - type->DefaultStat.Variables = new CVariable[UnitTypeVar.GetNumberVariable()]; - for (unsigned int i = 0; i < UnitTypeVar.GetNumberVariable(); ++i) { - type->DefaultStat.Variables[i] = UnitTypeVar.Variable[i]; - } + type->DefaultStat.Variables = UnitTypeVar.Variable; + UnitTypes.push_back(type); UnitTypeMap[type->Ident] = type; return {type, false}; diff --git a/src/unit/upgrade.cpp b/src/unit/upgrade.cpp index 878ef9f178..6d17a9981c 100644 --- a/src/unit/upgrade.cpp +++ b/src/unit/upgrade.cpp @@ -78,12 +78,6 @@ static std::map> Upgrades; -- Functions ----------------------------------------------------------------------------*/ - -CUnitStats::~CUnitStats() -{ - delete [] this->Variables; -} - CUnitStats &CUnitStats::operator = (const CUnitStats &rhs) { for (unsigned int i = 0; i < MaxCosts; ++i) { @@ -91,11 +85,7 @@ CUnitStats &CUnitStats::operator = (const CUnitStats &rhs) this->Storing[i] = rhs.Storing[i]; this->ImproveIncomes[i] = rhs.ImproveIncomes[i]; } - delete [] this->Variables; - const unsigned int size = UnitTypeVar.GetNumberVariable(); - this->Variables = new CVariable[size]; - - std::copy(rhs.Variables, rhs.Variables + size, this->Variables); + this->Variables = rhs.Variables; return *this; } @@ -248,7 +238,7 @@ static int CclDefineModifier(lua_State *l) memset(um->ChangeUpgrades, '?', sizeof(um->ChangeUpgrades)); memset(um->ApplyTo, '?', sizeof(um->ApplyTo)); - um->Modifier.Variables = new CVariable[UnitTypeVar.GetNumberVariable()]; + um->Modifier.Variables.resize(UnitTypeVar.GetNumberVariable()); um->ModifyPercent.resize(UnitTypeVar.GetNumberVariable()); std::string_view upgrade_ident = LuaToString(l, 1);