Property: Make use of override where applicable

Makes the API strongly enforced. This also fixes a bug in CBoolProperty,
where ValueAsString() had an incorrect signature (was missing a const).
This commit is contained in:
Lioncash 2020-06-10 09:19:09 -04:00
parent 0096b28294
commit 96876b70e0
20 changed files with 162 additions and 157 deletions

View File

@ -8,19 +8,19 @@ class CAnimationProperty : public TSerializeableTypedProperty< uint32, EProperty
friend class IProperty;
protected:
CAnimationProperty(EGame Game)
explicit CAnimationProperty(EGame Game)
: TSerializeableTypedProperty(Game)
{}
public:
virtual void SerializeValue(void* pData, IArchive& rArc) const
void SerializeValue(void* pData, IArchive& rArc) const override
{
rArc.SerializePrimitive((uint32&)ValueRef(pData), SH_HexDisplay);
}
virtual TString ValueAsString(void* pData) const
TString ValueAsString(void* pData) const override
{
return TString::HexString( (uint32) Value(pData) );
return TString::HexString(static_cast<uint32>(Value(pData)));
}
};

View File

@ -9,24 +9,24 @@ class CAnimationSetProperty : public TSerializeableTypedProperty< CAnimationPara
friend class IProperty;
protected:
CAnimationSetProperty(EGame Game)
explicit CAnimationSetProperty(EGame Game)
: TSerializeableTypedProperty(Game)
{
mDefaultValue.SetGame(Game);
}
public:
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
ValueRef(pData).Serialize(Arc);
}
virtual const char* HashableTypeName() const
const char* HashableTypeName() const override
{
return (Game() <= EGame::Echoes ? "AnimationSet" : "CharacterAnimationSet");
return Game() <= EGame::Echoes ? "AnimationSet" : "CharacterAnimationSet";
}
virtual CAnimationParameters GetSerializationDefaultValue()
CAnimationParameters GetSerializationDefaultValue() override
{
return CAnimationParameters(Game());
}

View File

@ -5,16 +5,19 @@
struct SScriptArray
{
int Count;
int Count = 0;
std::vector<char> Array;
SScriptArray()
: Count(0)
{}
SScriptArray() = default;
inline bool operator==(const SScriptArray& rkOther) const
bool operator==(const SScriptArray& other) const
{
return( Count == rkOther.Count && Array == rkOther.Array );
return Count == other.Count && Array == other.Array;
}
bool operator!=(const SScriptArray& other) const
{
return !operator==(other);
}
};
@ -29,7 +32,7 @@ class CArrayProperty : public TTypedProperty<uint32, EPropertyType::Array>
* value and we respond by updating the allocated space, handling item destruction
* and construction, etc.
*/
IProperty* mpItemArchetype;
IProperty* mpItemArchetype = nullptr;
/** Internal functions */
SScriptArray& _GetInternalArray(void* pData) const
@ -44,75 +47,74 @@ class CArrayProperty : public TTypedProperty<uint32, EPropertyType::Array>
}
protected:
CArrayProperty(EGame Game)
explicit CArrayProperty(EGame Game)
: TTypedProperty(Game)
, mpItemArchetype(nullptr)
{}
public:
virtual ~CArrayProperty() { delete mpItemArchetype; }
~CArrayProperty() override { delete mpItemArchetype; }
virtual uint32 DataSize() const
uint32 DataSize() const override
{
return sizeof(SScriptArray);
}
virtual uint32 DataAlignment() const
uint32 DataAlignment() const override
{
return alignof(SScriptArray);
}
virtual void Construct(void* pData) const
void Construct(void* pData) const override
{
new(ValuePtr(pData)) SScriptArray;
}
virtual void Destruct(void* pData) const
void Destruct(void* pData) const override
{
RevertToDefault(pData);
_GetInternalArray(pData).~SScriptArray();
}
virtual bool MatchesDefault(void* pData) const
bool MatchesDefault(void* pData) const override
{
return ArrayCount(pData) == 0;
}
virtual void RevertToDefault(void* pData) const
void RevertToDefault(void* pData) const override
{
Resize(pData, 0);
ValueRef(pData) = 0;
}
virtual bool CanHaveDefault() const
bool CanHaveDefault() const override
{
return true;
}
virtual bool IsPointerType() const
bool IsPointerType() const override
{
return true;
}
virtual void* GetChildDataPointer(void* pPropertyData) const
void* GetChildDataPointer(void* pPropertyData) const override
{
return _GetInternalArray(pPropertyData).Array.data();
}
virtual void PropertyValueChanged(void* pPropertyData)
void PropertyValueChanged(void* pPropertyData) override
{
SScriptArray& rArray = _GetInternalArray(pPropertyData);
rArray.Count = Math::Max(rArray.Count, 0);
Resize(pPropertyData, rArray.Count);
}
virtual void Serialize(IArchive& rArc)
void Serialize(IArchive& rArc) override
{
TTypedProperty::Serialize(rArc);
rArc << SerialParameter("ItemArchetype", mpItemArchetype);
}
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
uint32 Count = ArrayCount(pData);
Arc.SerializeArraySize(Count);
@ -131,14 +133,14 @@ public:
}
}
virtual void InitFromArchetype(IProperty* pOther)
void InitFromArchetype(IProperty* pOther) override
{
TTypedProperty::InitFromArchetype(pOther);
CArrayProperty* pOtherArray = static_cast<CArrayProperty*>(pOther);
mpItemArchetype = IProperty::CreateCopy(pOtherArray->mpItemArchetype);
}
virtual void PostInitialize()
void PostInitialize() override
{
TTypedProperty::PostInitialize();
mpItemArchetype->Initialize(this, mpScriptTemplate, 0);

View File

@ -11,44 +11,44 @@ class CAssetProperty : public TSerializeableTypedProperty<CAssetID, EPropertyTyp
CResTypeFilter mTypeFilter;
protected:
CAssetProperty(EGame Game)
explicit CAssetProperty(EGame Game)
: TSerializeableTypedProperty(Game)
{
mDefaultValue = CAssetID::InvalidID( mGame );
}
public:
virtual void Serialize(IArchive& rArc)
void Serialize(IArchive& rArc) override
{
TSerializeableTypedProperty::Serialize(rArc);
CAssetProperty* pArchetype = static_cast<CAssetProperty*>(mpArchetype);
rArc << SerialParameter("TypeFilter", mTypeFilter, pArchetype ? SH_Optional : 0, pArchetype ? pArchetype->mTypeFilter : CResTypeFilter());
}
virtual bool ShouldSerialize() const
bool ShouldSerialize() const override
{
CAssetProperty* pArchetype = static_cast<CAssetProperty*>(mpArchetype);
return TSerializeableTypedProperty::ShouldSerialize() ||
mTypeFilter != pArchetype->mTypeFilter;
}
virtual void InitFromArchetype(IProperty* pOther)
void InitFromArchetype(IProperty* pOther) override
{
TTypedProperty::InitFromArchetype(pOther);
mTypeFilter = static_cast<CAssetProperty*>(pOther)->mTypeFilter;
}
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
Arc.SerializePrimitive( ValueRef(pData), 0 );
}
virtual TString ValueAsString(void* pData) const
TString ValueAsString(void* pData) const override
{
return Value(pData).ToString();
}
virtual CAssetID GetSerializationDefaultValue()
CAssetID GetSerializationDefaultValue() override
{
return CAssetID::InvalidID(Game());
}

View File

@ -8,17 +8,17 @@ class CBoolProperty : public TSerializeableTypedProperty< bool, EPropertyType::B
friend class IProperty;
protected:
CBoolProperty(EGame Game)
explicit CBoolProperty(EGame Game)
: TSerializeableTypedProperty(Game)
{}
public:
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
Arc.SerializePrimitive(ValueRef(pData), 0);
}
virtual TString ValueAsString(void* pData)
TString ValueAsString(void* pData) const override
{
return Value(pData) ? "true" : "false";
}

View File

@ -8,17 +8,17 @@ class CByteProperty : public TNumericalProperty< int8, EPropertyType::Byte >
friend class IProperty;
protected:
CByteProperty(EGame Game)
explicit CByteProperty(EGame Game)
: TNumericalProperty(Game)
{}
public:
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
Arc.SerializePrimitive((int8&)ValueRef(pData), 0);
}
virtual TString ValueAsString(void* pData) const
TString ValueAsString(void* pData) const override
{
return TString::FromInt32((int32)Value(pData), 0, 10);
}

View File

@ -9,12 +9,12 @@ class CColorProperty : public TSerializeableTypedProperty< CColor, EPropertyType
friend class IProperty;
protected:
CColorProperty(EGame Game)
explicit CColorProperty(EGame Game)
: TSerializeableTypedProperty(Game)
{}
public:
virtual void PostInitialize()
void PostInitialize() override
{
CreateIntrinsic(EPropertyType::Float, this, mOffset + 0, "R");
CreateIntrinsic(EPropertyType::Float, this, mOffset + 4, "G");
@ -23,7 +23,7 @@ public:
TPropCast<CFloatProperty>( mChildren.back() )->SetDefaultValue(1.0f);
}
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
ValueRef(pData).Serialize(Arc);
}

View File

@ -19,19 +19,21 @@ class TEnumPropertyBase : public TSerializeableTypedProperty<int32, TypeEnum>
struct SEnumValue
{
TString Name;
uint32 ID;
SEnumValue()
: ID(0)
{}
uint32 ID = 0;
SEnumValue() = default;
SEnumValue(const TString& rkInName, uint32 InID)
: Name(rkInName), ID(InID) {}
inline bool operator==(const SEnumValue& rkOther) const
bool operator==(const SEnumValue& other) const
{
return( Name == rkOther.Name && ID == rkOther.ID );
return Name == other.Name && ID == other.ID;
}
bool operator!=(const SEnumValue& other) const
{
return !operator==(other);
}
void Serialize(IArchive& rArc)
@ -47,13 +49,13 @@ class TEnumPropertyBase : public TSerializeableTypedProperty<int32, TypeEnum>
protected:
/** Constructor */
TEnumPropertyBase(EGame Game)
explicit TEnumPropertyBase(EGame Game)
: base(Game)
, mOverrideTypeName(false)
{}
public:
virtual const char* HashableTypeName() const
const char* HashableTypeName() const override
{
if (base::mpArchetype)
return base::mpArchetype->HashableTypeName();
@ -65,7 +67,7 @@ public:
return "choice";
}
virtual void Serialize(IArchive& rArc)
void Serialize(IArchive& rArc) override
{
// Skip TSerializeableTypedProperty, serialize default value ourselves so we can set SH_HexDisplay
TTypedProperty<int32, TypeEnum>::Serialize(rArc);
@ -87,19 +89,19 @@ public:
}
}
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
Arc.SerializePrimitive((uint32&)base::ValueRef(pData), 0);
}
virtual void InitFromArchetype(IProperty* pOther)
void InitFromArchetype(IProperty* pOther) override
{
TTypedProperty<int32, TypeEnum>::InitFromArchetype(pOther);
TEnumPropertyBase* pOtherEnum = static_cast<TEnumPropertyBase*>(pOther);
mValues = pOtherEnum->mValues;
}
virtual TString ValueAsString(void* pData) const
TString ValueAsString(void* pData) const override
{
return TString::FromInt32(base::Value(pData), 0, 10);
}
@ -109,7 +111,7 @@ public:
mValues.push_back( SEnumValue(ValueName, ValueID) );
}
inline uint32 NumPossibleValues() const { return mValues.size(); }
uint32 NumPossibleValues() const { return mValues.size(); }
uint32 ValueIndex(uint32 ID) const
{
@ -166,8 +168,8 @@ public:
}
};
typedef TEnumPropertyBase<EPropertyType::Choice> CChoiceProperty;
typedef TEnumPropertyBase<EPropertyType::Enum> CEnumProperty;
using CChoiceProperty = TEnumPropertyBase<EPropertyType::Choice>;
using CEnumProperty = TEnumPropertyBase<EPropertyType::Enum>;
// Specialization of TPropCast to allow interchangeable casting, as both types are the same thing
template<>

View File

@ -10,19 +10,21 @@ class CFlagsProperty : public TSerializeableTypedProperty<uint32, EPropertyType:
struct SBitFlag
{
TString Name;
uint32 Mask;
SBitFlag()
: Mask(0)
{}
uint32 Mask = 0;
SBitFlag() = default;
SBitFlag(const TString& rkInName, uint32 InMask)
: Name(rkInName), Mask(InMask)
{}
bool operator==(const SBitFlag& rkOther) const
bool operator==(const SBitFlag& other) const
{
return( Name == rkOther.Name && Mask == rkOther.Mask );
return Name == other.Name && Mask == other.Mask;
}
bool operator!=(const SBitFlag& other) const
{
return !operator==(other);
}
void Serialize(IArchive& rArc)
@ -32,36 +34,35 @@ class CFlagsProperty : public TSerializeableTypedProperty<uint32, EPropertyType:
}
};
std::vector<SBitFlag> mBitFlags;
uint32 mAllFlags;
uint32 mAllFlags = 0;
CFlagsProperty(EGame Game)
explicit CFlagsProperty(EGame Game)
: TSerializeableTypedProperty(Game)
, mAllFlags(0)
{}
public:
inline uint32 NumFlags() const
uint32 NumFlags() const
{
return mBitFlags.size();
}
inline TString FlagName(uint32 Idx) const
TString FlagName(uint32 Idx) const
{
ASSERT(Idx >= 0 && Idx < mBitFlags.size());
return mBitFlags[Idx].Name;
}
inline uint32 FlagMask(uint32 Idx) const
uint32 FlagMask(uint32 Idx) const
{
ASSERT(Idx >= 0 && Idx < mBitFlags.size());
return mBitFlags[Idx].Mask;
}
virtual void Serialize(IArchive& rArc);
virtual void PostInitialize();
virtual void SerializeValue(void* pData, IArchive& rArc) const;
virtual void InitFromArchetype(IProperty* pOther);
virtual TString ValueAsString(void* pData) const;
void Serialize(IArchive& rArc) override;
void PostInitialize() override;
void SerializeValue(void* pData, IArchive& rArc) const override;
void InitFromArchetype(IProperty* pOther) override;
TString ValueAsString(void* pData) const override;
/**
* Checks whether there are any unrecognized bits toggled on in the property value.

View File

@ -8,17 +8,17 @@ class CFloatProperty : public TNumericalProperty< float, EPropertyType::Float >
friend class IProperty;
protected:
CFloatProperty(EGame Game)
explicit CFloatProperty(EGame Game)
: TNumericalProperty(Game)
{}
public:
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
Arc.SerializePrimitive((float&)ValueRef(pData), 0);
}
virtual TString ValueAsString(void* pData) const
TString ValueAsString(void* pData) const override
{
return TString::FromFloat(Value(pData));
}

View File

@ -8,12 +8,12 @@ class CGuidProperty : public TTypedProperty< std::vector<char>, EPropertyType::G
friend class IProperty;
protected:
CGuidProperty(EGame Game)
explicit CGuidProperty(EGame Game)
: TTypedProperty(Game)
{}
public:
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
Arc << SerialParameter("Data", ValueRef(pData));
}

View File

@ -8,17 +8,17 @@ class CIntProperty : public TNumericalProperty< int32, EPropertyType::Int >
friend class IProperty;
protected:
CIntProperty(EGame Game)
explicit CIntProperty(EGame Game)
: TNumericalProperty(Game)
{}
public:
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
Arc.SerializePrimitive(ValueRef(pData), 0);
}
virtual TString ValueAsString(void* pData) const
TString ValueAsString(void* pData) const override
{
return TString::FromInt32(Value(pData), 0, 10);
}

View File

@ -7,22 +7,22 @@ class CPointerProperty : public TTypedProperty<void*, EPropertyType::Pointer>
{
friend class IProperty;
CPointerProperty(EGame Game)
explicit CPointerProperty(EGame Game)
: TTypedProperty(Game)
{}
public:
virtual bool IsPointerType() const
bool IsPointerType() const override
{
return true;
}
virtual void* GetChildDataPointer(void* pPropertyData) const
void* GetChildDataPointer(void* pPropertyData) const override
{
return ValueRef(pPropertyData);
}
virtual void SerializeValue(void* pData, IArchive& rArc) const
void SerializeValue(void* pData, IArchive& rArc) const override
{
// pointers are not serializable, this shouldn't happen
ASSERT(false);

View File

@ -8,11 +8,11 @@ class CSequenceProperty : public TTypedProperty< int32, EPropertyType::Sequence
friend class IProperty;
protected:
CSequenceProperty(EGame Game)
explicit CSequenceProperty(EGame Game)
: TTypedProperty(Game)
{}
virtual void SerializeValue(void* pData, IArchive& rArc) const
void SerializeValue(void* pData, IArchive& rArc) const override
{}
};

View File

@ -8,17 +8,17 @@ class CShortProperty : public TNumericalProperty< int16, EPropertyType::Short >
friend class IProperty;
protected:
CShortProperty(EGame Game)
explicit CShortProperty(EGame Game)
: TNumericalProperty(Game)
{}
public:
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
Arc.SerializePrimitive(ValueRef(pData), 0);
}
virtual TString ValueAsString(void* pData) const
TString ValueAsString(void* pData) const override
{
return TString::FromInt32((int32)Value(pData), 0, 10);
}

View File

@ -8,17 +8,17 @@ class CSoundProperty : public TSerializeableTypedProperty< int32, EPropertyType:
friend class IProperty;
protected:
CSoundProperty(EGame Game)
explicit CSoundProperty(EGame Game)
: TSerializeableTypedProperty(Game)
{}
public:
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
Arc.SerializePrimitive(ValueRef(pData), 0);
}
virtual TString ValueAsString(void* pData) const
TString ValueAsString(void* pData) const override
{
return TString::FromInt32(Value(pData), 0, 10);
}

View File

@ -8,12 +8,12 @@ class CSplineProperty : public TTypedProperty< std::vector<char>, EPropertyType:
friend class IProperty;
protected:
CSplineProperty(EGame Game)
explicit CSplineProperty(EGame Game)
: TTypedProperty(Game)
{}
public:
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
Arc << SerialParameter("Data", ValueRef(pData));
}

View File

@ -8,17 +8,17 @@ class CStringProperty : public TSerializeableTypedProperty< TString, EPropertyTy
friend class IProperty;
protected:
CStringProperty(EGame Game)
explicit CStringProperty(EGame Game)
: TSerializeableTypedProperty(Game)
{}
public:
virtual void SerializeValue(void* pData, IArchive& Arc) const
void SerializeValue(void* pData, IArchive& Arc) const override
{
Arc.SerializePrimitive(ValueRef(pData), 0);
}
virtual TString ValueAsString(void* pData) const
TString ValueAsString(void* pData) const override
{
return Value(pData);
}

View File

@ -9,30 +9,30 @@ class CStructProperty : public IProperty
public:
// Must be a valid type for TPropertyRef
typedef void* ValueType;
using ValueType = void*;
protected:
CStructProperty(EGame Game)
explicit CStructProperty(EGame Game)
: IProperty(Game)
{}
public:
virtual EPropertyType Type() const;
virtual void PostInitialize();
virtual uint32 DataSize() const;
virtual uint32 DataAlignment() const;
virtual void Construct(void* pData) const;
virtual void Destruct(void* pData) const;
virtual bool MatchesDefault(void* pData) const;
virtual void RevertToDefault(void* pData) const;
virtual void SetDefaultFromData(void* pData);
virtual const char* HashableTypeName() const;
virtual void Serialize(IArchive& rArc);
virtual void SerializeValue(void* pData, IArchive& Arc) const;
virtual void InitFromArchetype(IProperty* pOther);
virtual bool ShouldSerialize() const;
EPropertyType Type() const override;
void PostInitialize() override;
uint32 DataSize() const override;
uint32 DataAlignment() const override;
void Construct(void* pData) const override;
void Destruct(void* pData) const override;
bool MatchesDefault(void* pData) const override;
void RevertToDefault(void* pData) const override;
void SetDefaultFromData(void* pData) override;
const char* HashableTypeName() const override;
void Serialize(IArchive& rArc) override;
void SerializeValue(void* pData, IArchive& Arc) const override;
void InitFromArchetype(IProperty* pOther) override;
bool ShouldSerialize() const override;
inline static EPropertyType StaticType() { return EPropertyType::Struct; }
static EPropertyType StaticType() { return EPropertyType::Struct; }
};
#endif

View File

@ -8,24 +8,24 @@ class CVectorProperty : public TSerializeableTypedProperty< CVector3f, EProperty
friend class IProperty;
protected:
CVectorProperty(EGame Game)
explicit CVectorProperty(EGame Game)
: TSerializeableTypedProperty(Game)
{}
public:
virtual void PostInitialize() override
void PostInitialize() override
{
CreateIntrinsic(EPropertyType::Float, this, mOffset + 0, "X");
CreateIntrinsic(EPropertyType::Float, this, mOffset + 4, "Y");
CreateIntrinsic(EPropertyType::Float, this, mOffset + 8, "Z");
}
virtual void SerializeValue(void* pData, IArchive& Arc) const override
void SerializeValue(void* pData, IArchive& Arc) const override
{
ValueRef(pData).Serialize(Arc);
}
virtual TString ValueAsString(void* pData) const override
TString ValueAsString(void* pData) const override
{
return Value(pData).ToString();
}