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:
parent
0096b28294
commit
96876b70e0
|
@ -8,19 +8,19 @@ class CAnimationProperty : public TSerializeableTypedProperty< uint32, EProperty
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CAnimationProperty(EGame Game)
|
explicit CAnimationProperty(EGame Game)
|
||||||
: TSerializeableTypedProperty(Game)
|
: TSerializeableTypedProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void SerializeValue(void* pData, IArchive& rArc) const
|
void SerializeValue(void* pData, IArchive& rArc) const override
|
||||||
{
|
{
|
||||||
rArc.SerializePrimitive((uint32&)ValueRef(pData), SH_HexDisplay);
|
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)));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -9,24 +9,24 @@ class CAnimationSetProperty : public TSerializeableTypedProperty< CAnimationPara
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CAnimationSetProperty(EGame Game)
|
explicit CAnimationSetProperty(EGame Game)
|
||||||
: TSerializeableTypedProperty(Game)
|
: TSerializeableTypedProperty(Game)
|
||||||
{
|
{
|
||||||
mDefaultValue.SetGame(Game);
|
mDefaultValue.SetGame(Game);
|
||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void SerializeValue(void* pData, IArchive& Arc) const
|
void SerializeValue(void* pData, IArchive& Arc) const override
|
||||||
{
|
{
|
||||||
ValueRef(pData).Serialize(Arc);
|
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());
|
return CAnimationParameters(Game());
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,16 +5,19 @@
|
||||||
|
|
||||||
struct SScriptArray
|
struct SScriptArray
|
||||||
{
|
{
|
||||||
int Count;
|
int Count = 0;
|
||||||
std::vector<char> Array;
|
std::vector<char> Array;
|
||||||
|
|
||||||
SScriptArray()
|
SScriptArray() = default;
|
||||||
: Count(0)
|
|
||||||
{}
|
|
||||||
|
|
||||||
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
|
* value and we respond by updating the allocated space, handling item destruction
|
||||||
* and construction, etc.
|
* and construction, etc.
|
||||||
*/
|
*/
|
||||||
IProperty* mpItemArchetype;
|
IProperty* mpItemArchetype = nullptr;
|
||||||
|
|
||||||
/** Internal functions */
|
/** Internal functions */
|
||||||
SScriptArray& _GetInternalArray(void* pData) const
|
SScriptArray& _GetInternalArray(void* pData) const
|
||||||
|
@ -44,75 +47,74 @@ class CArrayProperty : public TTypedProperty<uint32, EPropertyType::Array>
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CArrayProperty(EGame Game)
|
explicit CArrayProperty(EGame Game)
|
||||||
: TTypedProperty(Game)
|
: TTypedProperty(Game)
|
||||||
, mpItemArchetype(nullptr)
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual ~CArrayProperty() { delete mpItemArchetype; }
|
~CArrayProperty() override { delete mpItemArchetype; }
|
||||||
|
|
||||||
virtual uint32 DataSize() const
|
uint32 DataSize() const override
|
||||||
{
|
{
|
||||||
return sizeof(SScriptArray);
|
return sizeof(SScriptArray);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual uint32 DataAlignment() const
|
uint32 DataAlignment() const override
|
||||||
{
|
{
|
||||||
return alignof(SScriptArray);
|
return alignof(SScriptArray);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void Construct(void* pData) const
|
void Construct(void* pData) const override
|
||||||
{
|
{
|
||||||
new(ValuePtr(pData)) SScriptArray;
|
new(ValuePtr(pData)) SScriptArray;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void Destruct(void* pData) const
|
void Destruct(void* pData) const override
|
||||||
{
|
{
|
||||||
RevertToDefault(pData);
|
RevertToDefault(pData);
|
||||||
_GetInternalArray(pData).~SScriptArray();
|
_GetInternalArray(pData).~SScriptArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual bool MatchesDefault(void* pData) const
|
bool MatchesDefault(void* pData) const override
|
||||||
{
|
{
|
||||||
return ArrayCount(pData) == 0;
|
return ArrayCount(pData) == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void RevertToDefault(void* pData) const
|
void RevertToDefault(void* pData) const override
|
||||||
{
|
{
|
||||||
Resize(pData, 0);
|
Resize(pData, 0);
|
||||||
ValueRef(pData) = 0;
|
ValueRef(pData) = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual bool CanHaveDefault() const
|
bool CanHaveDefault() const override
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual bool IsPointerType() const
|
bool IsPointerType() const override
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void* GetChildDataPointer(void* pPropertyData) const
|
void* GetChildDataPointer(void* pPropertyData) const override
|
||||||
{
|
{
|
||||||
return _GetInternalArray(pPropertyData).Array.data();
|
return _GetInternalArray(pPropertyData).Array.data();
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void PropertyValueChanged(void* pPropertyData)
|
void PropertyValueChanged(void* pPropertyData) override
|
||||||
{
|
{
|
||||||
SScriptArray& rArray = _GetInternalArray(pPropertyData);
|
SScriptArray& rArray = _GetInternalArray(pPropertyData);
|
||||||
rArray.Count = Math::Max(rArray.Count, 0);
|
rArray.Count = Math::Max(rArray.Count, 0);
|
||||||
Resize(pPropertyData, rArray.Count);
|
Resize(pPropertyData, rArray.Count);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void Serialize(IArchive& rArc)
|
void Serialize(IArchive& rArc) override
|
||||||
{
|
{
|
||||||
TTypedProperty::Serialize(rArc);
|
TTypedProperty::Serialize(rArc);
|
||||||
rArc << SerialParameter("ItemArchetype", mpItemArchetype);
|
rArc << SerialParameter("ItemArchetype", mpItemArchetype);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void SerializeValue(void* pData, IArchive& Arc) const
|
void SerializeValue(void* pData, IArchive& Arc) const override
|
||||||
{
|
{
|
||||||
uint32 Count = ArrayCount(pData);
|
uint32 Count = ArrayCount(pData);
|
||||||
Arc.SerializeArraySize(Count);
|
Arc.SerializeArraySize(Count);
|
||||||
|
@ -131,14 +133,14 @@ public:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void InitFromArchetype(IProperty* pOther)
|
void InitFromArchetype(IProperty* pOther) override
|
||||||
{
|
{
|
||||||
TTypedProperty::InitFromArchetype(pOther);
|
TTypedProperty::InitFromArchetype(pOther);
|
||||||
CArrayProperty* pOtherArray = static_cast<CArrayProperty*>(pOther);
|
CArrayProperty* pOtherArray = static_cast<CArrayProperty*>(pOther);
|
||||||
mpItemArchetype = IProperty::CreateCopy(pOtherArray->mpItemArchetype);
|
mpItemArchetype = IProperty::CreateCopy(pOtherArray->mpItemArchetype);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void PostInitialize()
|
void PostInitialize() override
|
||||||
{
|
{
|
||||||
TTypedProperty::PostInitialize();
|
TTypedProperty::PostInitialize();
|
||||||
mpItemArchetype->Initialize(this, mpScriptTemplate, 0);
|
mpItemArchetype->Initialize(this, mpScriptTemplate, 0);
|
||||||
|
|
|
@ -11,44 +11,44 @@ class CAssetProperty : public TSerializeableTypedProperty<CAssetID, EPropertyTyp
|
||||||
CResTypeFilter mTypeFilter;
|
CResTypeFilter mTypeFilter;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CAssetProperty(EGame Game)
|
explicit CAssetProperty(EGame Game)
|
||||||
: TSerializeableTypedProperty(Game)
|
: TSerializeableTypedProperty(Game)
|
||||||
{
|
{
|
||||||
mDefaultValue = CAssetID::InvalidID( mGame );
|
mDefaultValue = CAssetID::InvalidID( mGame );
|
||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void Serialize(IArchive& rArc)
|
void Serialize(IArchive& rArc) override
|
||||||
{
|
{
|
||||||
TSerializeableTypedProperty::Serialize(rArc);
|
TSerializeableTypedProperty::Serialize(rArc);
|
||||||
CAssetProperty* pArchetype = static_cast<CAssetProperty*>(mpArchetype);
|
CAssetProperty* pArchetype = static_cast<CAssetProperty*>(mpArchetype);
|
||||||
rArc << SerialParameter("TypeFilter", mTypeFilter, pArchetype ? SH_Optional : 0, pArchetype ? pArchetype->mTypeFilter : CResTypeFilter());
|
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);
|
CAssetProperty* pArchetype = static_cast<CAssetProperty*>(mpArchetype);
|
||||||
return TSerializeableTypedProperty::ShouldSerialize() ||
|
return TSerializeableTypedProperty::ShouldSerialize() ||
|
||||||
mTypeFilter != pArchetype->mTypeFilter;
|
mTypeFilter != pArchetype->mTypeFilter;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void InitFromArchetype(IProperty* pOther)
|
void InitFromArchetype(IProperty* pOther) override
|
||||||
{
|
{
|
||||||
TTypedProperty::InitFromArchetype(pOther);
|
TTypedProperty::InitFromArchetype(pOther);
|
||||||
mTypeFilter = static_cast<CAssetProperty*>(pOther)->mTypeFilter;
|
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 );
|
Arc.SerializePrimitive( ValueRef(pData), 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual TString ValueAsString(void* pData) const
|
TString ValueAsString(void* pData) const override
|
||||||
{
|
{
|
||||||
return Value(pData).ToString();
|
return Value(pData).ToString();
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual CAssetID GetSerializationDefaultValue()
|
CAssetID GetSerializationDefaultValue() override
|
||||||
{
|
{
|
||||||
return CAssetID::InvalidID(Game());
|
return CAssetID::InvalidID(Game());
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,17 +8,17 @@ class CBoolProperty : public TSerializeableTypedProperty< bool, EPropertyType::B
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CBoolProperty(EGame Game)
|
explicit CBoolProperty(EGame Game)
|
||||||
: TSerializeableTypedProperty(Game)
|
: TSerializeableTypedProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void SerializeValue(void* pData, IArchive& Arc) const
|
void SerializeValue(void* pData, IArchive& Arc) const override
|
||||||
{
|
{
|
||||||
Arc.SerializePrimitive(ValueRef(pData), 0);
|
Arc.SerializePrimitive(ValueRef(pData), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual TString ValueAsString(void* pData)
|
TString ValueAsString(void* pData) const override
|
||||||
{
|
{
|
||||||
return Value(pData) ? "true" : "false";
|
return Value(pData) ? "true" : "false";
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,17 +8,17 @@ class CByteProperty : public TNumericalProperty< int8, EPropertyType::Byte >
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CByteProperty(EGame Game)
|
explicit CByteProperty(EGame Game)
|
||||||
: TNumericalProperty(Game)
|
: TNumericalProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void SerializeValue(void* pData, IArchive& Arc) const
|
void SerializeValue(void* pData, IArchive& Arc) const override
|
||||||
{
|
{
|
||||||
Arc.SerializePrimitive((int8&)ValueRef(pData), 0);
|
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);
|
return TString::FromInt32((int32)Value(pData), 0, 10);
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,12 +9,12 @@ class CColorProperty : public TSerializeableTypedProperty< CColor, EPropertyType
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CColorProperty(EGame Game)
|
explicit CColorProperty(EGame Game)
|
||||||
: TSerializeableTypedProperty(Game)
|
: TSerializeableTypedProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void PostInitialize()
|
void PostInitialize() override
|
||||||
{
|
{
|
||||||
CreateIntrinsic(EPropertyType::Float, this, mOffset + 0, "R");
|
CreateIntrinsic(EPropertyType::Float, this, mOffset + 0, "R");
|
||||||
CreateIntrinsic(EPropertyType::Float, this, mOffset + 4, "G");
|
CreateIntrinsic(EPropertyType::Float, this, mOffset + 4, "G");
|
||||||
|
@ -23,7 +23,7 @@ public:
|
||||||
TPropCast<CFloatProperty>( mChildren.back() )->SetDefaultValue(1.0f);
|
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);
|
ValueRef(pData).Serialize(Arc);
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,19 +19,21 @@ class TEnumPropertyBase : public TSerializeableTypedProperty<int32, TypeEnum>
|
||||||
struct SEnumValue
|
struct SEnumValue
|
||||||
{
|
{
|
||||||
TString Name;
|
TString Name;
|
||||||
uint32 ID;
|
uint32 ID = 0;
|
||||||
|
|
||||||
SEnumValue()
|
|
||||||
: ID(0)
|
|
||||||
{}
|
|
||||||
|
|
||||||
|
SEnumValue() = default;
|
||||||
SEnumValue(const TString& rkInName, uint32 InID)
|
SEnumValue(const TString& rkInName, uint32 InID)
|
||||||
: Name(rkInName), ID(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)
|
void Serialize(IArchive& rArc)
|
||||||
|
@ -47,13 +49,13 @@ class TEnumPropertyBase : public TSerializeableTypedProperty<int32, TypeEnum>
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
/** Constructor */
|
/** Constructor */
|
||||||
TEnumPropertyBase(EGame Game)
|
explicit TEnumPropertyBase(EGame Game)
|
||||||
: base(Game)
|
: base(Game)
|
||||||
, mOverrideTypeName(false)
|
, mOverrideTypeName(false)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual const char* HashableTypeName() const
|
const char* HashableTypeName() const override
|
||||||
{
|
{
|
||||||
if (base::mpArchetype)
|
if (base::mpArchetype)
|
||||||
return base::mpArchetype->HashableTypeName();
|
return base::mpArchetype->HashableTypeName();
|
||||||
|
@ -65,7 +67,7 @@ public:
|
||||||
return "choice";
|
return "choice";
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void Serialize(IArchive& rArc)
|
void Serialize(IArchive& rArc) override
|
||||||
{
|
{
|
||||||
// Skip TSerializeableTypedProperty, serialize default value ourselves so we can set SH_HexDisplay
|
// Skip TSerializeableTypedProperty, serialize default value ourselves so we can set SH_HexDisplay
|
||||||
TTypedProperty<int32, TypeEnum>::Serialize(rArc);
|
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);
|
Arc.SerializePrimitive((uint32&)base::ValueRef(pData), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void InitFromArchetype(IProperty* pOther)
|
void InitFromArchetype(IProperty* pOther) override
|
||||||
{
|
{
|
||||||
TTypedProperty<int32, TypeEnum>::InitFromArchetype(pOther);
|
TTypedProperty<int32, TypeEnum>::InitFromArchetype(pOther);
|
||||||
TEnumPropertyBase* pOtherEnum = static_cast<TEnumPropertyBase*>(pOther);
|
TEnumPropertyBase* pOtherEnum = static_cast<TEnumPropertyBase*>(pOther);
|
||||||
mValues = pOtherEnum->mValues;
|
mValues = pOtherEnum->mValues;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual TString ValueAsString(void* pData) const
|
TString ValueAsString(void* pData) const override
|
||||||
{
|
{
|
||||||
return TString::FromInt32(base::Value(pData), 0, 10);
|
return TString::FromInt32(base::Value(pData), 0, 10);
|
||||||
}
|
}
|
||||||
|
@ -109,7 +111,7 @@ public:
|
||||||
mValues.push_back( SEnumValue(ValueName, ValueID) );
|
mValues.push_back( SEnumValue(ValueName, ValueID) );
|
||||||
}
|
}
|
||||||
|
|
||||||
inline uint32 NumPossibleValues() const { return mValues.size(); }
|
uint32 NumPossibleValues() const { return mValues.size(); }
|
||||||
|
|
||||||
uint32 ValueIndex(uint32 ID) const
|
uint32 ValueIndex(uint32 ID) const
|
||||||
{
|
{
|
||||||
|
@ -166,8 +168,8 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef TEnumPropertyBase<EPropertyType::Choice> CChoiceProperty;
|
using CChoiceProperty = TEnumPropertyBase<EPropertyType::Choice>;
|
||||||
typedef TEnumPropertyBase<EPropertyType::Enum> CEnumProperty;
|
using CEnumProperty = TEnumPropertyBase<EPropertyType::Enum>;
|
||||||
|
|
||||||
// Specialization of TPropCast to allow interchangeable casting, as both types are the same thing
|
// Specialization of TPropCast to allow interchangeable casting, as both types are the same thing
|
||||||
template<>
|
template<>
|
||||||
|
|
|
@ -10,19 +10,21 @@ class CFlagsProperty : public TSerializeableTypedProperty<uint32, EPropertyType:
|
||||||
struct SBitFlag
|
struct SBitFlag
|
||||||
{
|
{
|
||||||
TString Name;
|
TString Name;
|
||||||
uint32 Mask;
|
uint32 Mask = 0;
|
||||||
|
|
||||||
SBitFlag()
|
|
||||||
: Mask(0)
|
|
||||||
{}
|
|
||||||
|
|
||||||
|
SBitFlag() = default;
|
||||||
SBitFlag(const TString& rkInName, uint32 InMask)
|
SBitFlag(const TString& rkInName, uint32 InMask)
|
||||||
: Name(rkInName), Mask(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)
|
void Serialize(IArchive& rArc)
|
||||||
|
@ -32,36 +34,35 @@ class CFlagsProperty : public TSerializeableTypedProperty<uint32, EPropertyType:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
std::vector<SBitFlag> mBitFlags;
|
std::vector<SBitFlag> mBitFlags;
|
||||||
uint32 mAllFlags;
|
uint32 mAllFlags = 0;
|
||||||
|
|
||||||
CFlagsProperty(EGame Game)
|
explicit CFlagsProperty(EGame Game)
|
||||||
: TSerializeableTypedProperty(Game)
|
: TSerializeableTypedProperty(Game)
|
||||||
, mAllFlags(0)
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
inline uint32 NumFlags() const
|
uint32 NumFlags() const
|
||||||
{
|
{
|
||||||
return mBitFlags.size();
|
return mBitFlags.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline TString FlagName(uint32 Idx) const
|
TString FlagName(uint32 Idx) const
|
||||||
{
|
{
|
||||||
ASSERT(Idx >= 0 && Idx < mBitFlags.size());
|
ASSERT(Idx >= 0 && Idx < mBitFlags.size());
|
||||||
return mBitFlags[Idx].Name;
|
return mBitFlags[Idx].Name;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline uint32 FlagMask(uint32 Idx) const
|
uint32 FlagMask(uint32 Idx) const
|
||||||
{
|
{
|
||||||
ASSERT(Idx >= 0 && Idx < mBitFlags.size());
|
ASSERT(Idx >= 0 && Idx < mBitFlags.size());
|
||||||
return mBitFlags[Idx].Mask;
|
return mBitFlags[Idx].Mask;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void Serialize(IArchive& rArc);
|
void Serialize(IArchive& rArc) override;
|
||||||
virtual void PostInitialize();
|
void PostInitialize() override;
|
||||||
virtual void SerializeValue(void* pData, IArchive& rArc) const;
|
void SerializeValue(void* pData, IArchive& rArc) const override;
|
||||||
virtual void InitFromArchetype(IProperty* pOther);
|
void InitFromArchetype(IProperty* pOther) override;
|
||||||
virtual TString ValueAsString(void* pData) const;
|
TString ValueAsString(void* pData) const override;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks whether there are any unrecognized bits toggled on in the property value.
|
* Checks whether there are any unrecognized bits toggled on in the property value.
|
||||||
|
|
|
@ -8,17 +8,17 @@ class CFloatProperty : public TNumericalProperty< float, EPropertyType::Float >
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CFloatProperty(EGame Game)
|
explicit CFloatProperty(EGame Game)
|
||||||
: TNumericalProperty(Game)
|
: TNumericalProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void SerializeValue(void* pData, IArchive& Arc) const
|
void SerializeValue(void* pData, IArchive& Arc) const override
|
||||||
{
|
{
|
||||||
Arc.SerializePrimitive((float&)ValueRef(pData), 0);
|
Arc.SerializePrimitive((float&)ValueRef(pData), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual TString ValueAsString(void* pData) const
|
TString ValueAsString(void* pData) const override
|
||||||
{
|
{
|
||||||
return TString::FromFloat(Value(pData));
|
return TString::FromFloat(Value(pData));
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,12 +8,12 @@ class CGuidProperty : public TTypedProperty< std::vector<char>, EPropertyType::G
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CGuidProperty(EGame Game)
|
explicit CGuidProperty(EGame Game)
|
||||||
: TTypedProperty(Game)
|
: TTypedProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void SerializeValue(void* pData, IArchive& Arc) const
|
void SerializeValue(void* pData, IArchive& Arc) const override
|
||||||
{
|
{
|
||||||
Arc << SerialParameter("Data", ValueRef(pData));
|
Arc << SerialParameter("Data", ValueRef(pData));
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,17 +8,17 @@ class CIntProperty : public TNumericalProperty< int32, EPropertyType::Int >
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CIntProperty(EGame Game)
|
explicit CIntProperty(EGame Game)
|
||||||
: TNumericalProperty(Game)
|
: TNumericalProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void SerializeValue(void* pData, IArchive& Arc) const
|
void SerializeValue(void* pData, IArchive& Arc) const override
|
||||||
{
|
{
|
||||||
Arc.SerializePrimitive(ValueRef(pData), 0);
|
Arc.SerializePrimitive(ValueRef(pData), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual TString ValueAsString(void* pData) const
|
TString ValueAsString(void* pData) const override
|
||||||
{
|
{
|
||||||
return TString::FromInt32(Value(pData), 0, 10);
|
return TString::FromInt32(Value(pData), 0, 10);
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,22 +7,22 @@ class CPointerProperty : public TTypedProperty<void*, EPropertyType::Pointer>
|
||||||
{
|
{
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
CPointerProperty(EGame Game)
|
explicit CPointerProperty(EGame Game)
|
||||||
: TTypedProperty(Game)
|
: TTypedProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual bool IsPointerType() const
|
bool IsPointerType() const override
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void* GetChildDataPointer(void* pPropertyData) const
|
void* GetChildDataPointer(void* pPropertyData) const override
|
||||||
{
|
{
|
||||||
return ValueRef(pPropertyData);
|
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
|
// pointers are not serializable, this shouldn't happen
|
||||||
ASSERT(false);
|
ASSERT(false);
|
||||||
|
|
|
@ -8,11 +8,11 @@ class CSequenceProperty : public TTypedProperty< int32, EPropertyType::Sequence
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CSequenceProperty(EGame Game)
|
explicit CSequenceProperty(EGame Game)
|
||||||
: TTypedProperty(Game)
|
: TTypedProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
virtual void SerializeValue(void* pData, IArchive& rArc) const
|
void SerializeValue(void* pData, IArchive& rArc) const override
|
||||||
{}
|
{}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -8,17 +8,17 @@ class CShortProperty : public TNumericalProperty< int16, EPropertyType::Short >
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CShortProperty(EGame Game)
|
explicit CShortProperty(EGame Game)
|
||||||
: TNumericalProperty(Game)
|
: TNumericalProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void SerializeValue(void* pData, IArchive& Arc) const
|
void SerializeValue(void* pData, IArchive& Arc) const override
|
||||||
{
|
{
|
||||||
Arc.SerializePrimitive(ValueRef(pData), 0);
|
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);
|
return TString::FromInt32((int32)Value(pData), 0, 10);
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,17 +8,17 @@ class CSoundProperty : public TSerializeableTypedProperty< int32, EPropertyType:
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CSoundProperty(EGame Game)
|
explicit CSoundProperty(EGame Game)
|
||||||
: TSerializeableTypedProperty(Game)
|
: TSerializeableTypedProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void SerializeValue(void* pData, IArchive& Arc) const
|
void SerializeValue(void* pData, IArchive& Arc) const override
|
||||||
{
|
{
|
||||||
Arc.SerializePrimitive(ValueRef(pData), 0);
|
Arc.SerializePrimitive(ValueRef(pData), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual TString ValueAsString(void* pData) const
|
TString ValueAsString(void* pData) const override
|
||||||
{
|
{
|
||||||
return TString::FromInt32(Value(pData), 0, 10);
|
return TString::FromInt32(Value(pData), 0, 10);
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,12 +8,12 @@ class CSplineProperty : public TTypedProperty< std::vector<char>, EPropertyType:
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CSplineProperty(EGame Game)
|
explicit CSplineProperty(EGame Game)
|
||||||
: TTypedProperty(Game)
|
: TTypedProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void SerializeValue(void* pData, IArchive& Arc) const
|
void SerializeValue(void* pData, IArchive& Arc) const override
|
||||||
{
|
{
|
||||||
Arc << SerialParameter("Data", ValueRef(pData));
|
Arc << SerialParameter("Data", ValueRef(pData));
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,17 +8,17 @@ class CStringProperty : public TSerializeableTypedProperty< TString, EPropertyTy
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CStringProperty(EGame Game)
|
explicit CStringProperty(EGame Game)
|
||||||
: TSerializeableTypedProperty(Game)
|
: TSerializeableTypedProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void SerializeValue(void* pData, IArchive& Arc) const
|
void SerializeValue(void* pData, IArchive& Arc) const override
|
||||||
{
|
{
|
||||||
Arc.SerializePrimitive(ValueRef(pData), 0);
|
Arc.SerializePrimitive(ValueRef(pData), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual TString ValueAsString(void* pData) const
|
TString ValueAsString(void* pData) const override
|
||||||
{
|
{
|
||||||
return Value(pData);
|
return Value(pData);
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,30 +9,30 @@ class CStructProperty : public IProperty
|
||||||
|
|
||||||
public:
|
public:
|
||||||
// Must be a valid type for TPropertyRef
|
// Must be a valid type for TPropertyRef
|
||||||
typedef void* ValueType;
|
using ValueType = void*;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CStructProperty(EGame Game)
|
explicit CStructProperty(EGame Game)
|
||||||
: IProperty(Game)
|
: IProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual EPropertyType Type() const;
|
EPropertyType Type() const override;
|
||||||
virtual void PostInitialize();
|
void PostInitialize() override;
|
||||||
virtual uint32 DataSize() const;
|
uint32 DataSize() const override;
|
||||||
virtual uint32 DataAlignment() const;
|
uint32 DataAlignment() const override;
|
||||||
virtual void Construct(void* pData) const;
|
void Construct(void* pData) const override;
|
||||||
virtual void Destruct(void* pData) const;
|
void Destruct(void* pData) const override;
|
||||||
virtual bool MatchesDefault(void* pData) const;
|
bool MatchesDefault(void* pData) const override;
|
||||||
virtual void RevertToDefault(void* pData) const;
|
void RevertToDefault(void* pData) const override;
|
||||||
virtual void SetDefaultFromData(void* pData);
|
void SetDefaultFromData(void* pData) override;
|
||||||
virtual const char* HashableTypeName() const;
|
const char* HashableTypeName() const override;
|
||||||
virtual void Serialize(IArchive& rArc);
|
void Serialize(IArchive& rArc) override;
|
||||||
virtual void SerializeValue(void* pData, IArchive& Arc) const;
|
void SerializeValue(void* pData, IArchive& Arc) const override;
|
||||||
virtual void InitFromArchetype(IProperty* pOther);
|
void InitFromArchetype(IProperty* pOther) override;
|
||||||
virtual bool ShouldSerialize() const;
|
bool ShouldSerialize() const override;
|
||||||
|
|
||||||
inline static EPropertyType StaticType() { return EPropertyType::Struct; }
|
static EPropertyType StaticType() { return EPropertyType::Struct; }
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -8,24 +8,24 @@ class CVectorProperty : public TSerializeableTypedProperty< CVector3f, EProperty
|
||||||
friend class IProperty;
|
friend class IProperty;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
CVectorProperty(EGame Game)
|
explicit CVectorProperty(EGame Game)
|
||||||
: TSerializeableTypedProperty(Game)
|
: TSerializeableTypedProperty(Game)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void PostInitialize() override
|
void PostInitialize() override
|
||||||
{
|
{
|
||||||
CreateIntrinsic(EPropertyType::Float, this, mOffset + 0, "X");
|
CreateIntrinsic(EPropertyType::Float, this, mOffset + 0, "X");
|
||||||
CreateIntrinsic(EPropertyType::Float, this, mOffset + 4, "Y");
|
CreateIntrinsic(EPropertyType::Float, this, mOffset + 4, "Y");
|
||||||
CreateIntrinsic(EPropertyType::Float, this, mOffset + 8, "Z");
|
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);
|
ValueRef(pData).Serialize(Arc);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual TString ValueAsString(void* pData) const override
|
TString ValueAsString(void* pData) const override
|
||||||
{
|
{
|
||||||
return Value(pData).ToString();
|
return Value(pData).ToString();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue