diff --git a/modules/fakemeta/msvc12/fakemeta.vcxproj b/modules/fakemeta/msvc12/fakemeta.vcxproj
index d2d7df5c..5acfc961 100644
--- a/modules/fakemeta/msvc12/fakemeta.vcxproj
+++ b/modules/fakemeta/msvc12/fakemeta.vcxproj
@@ -122,6 +122,7 @@
+
diff --git a/modules/fakemeta/msvc12/fakemeta.vcxproj.filters b/modules/fakemeta/msvc12/fakemeta.vcxproj.filters
index b48aead2..ebd2ff7d 100644
--- a/modules/fakemeta/msvc12/fakemeta.vcxproj.filters
+++ b/modules/fakemeta/msvc12/fakemeta.vcxproj.filters
@@ -118,6 +118,9 @@
Memtools
+
+ Header Files
+
diff --git a/modules/fakemeta/pdata_gc.cpp b/modules/fakemeta/pdata_gc.cpp
index ba25086e..832aa09d 100644
--- a/modules/fakemeta/pdata_gc.cpp
+++ b/modules/fakemeta/pdata_gc.cpp
@@ -12,69 +12,7 @@
//
#include "fakemeta_amxx.h"
-#include
-
-enum class BaseFieldType
-{
- None,
- Integer,
- Float,
- Vector,
- Entity,
- String,
-};
-
-static const char *BaseFieldTypeName[] =
-{
- "none",
- "integer",
- "float",
- "vector",
- "entity",
- "string",
-};
-
-static BaseFieldType GetBaseDataType(TypeDescription &data)
-{
- switch (data.fieldType)
- {
- case FieldType::FIELD_INTEGER:
- case FieldType::FIELD_STRINGINT:
- case FieldType::FIELD_SHORT:
- case FieldType::FIELD_CHARACTER:
- case FieldType::FIELD_CLASS:
- case FieldType::FIELD_STRUCTURE:
- case FieldType::FIELD_POINTER:
- case FieldType::FIELD_FUNCTION:
- case FieldType::FIELD_BOOLEAN:
- {
- return BaseFieldType::Integer;
- }
- case FieldType::FIELD_FLOAT:
- {
- return BaseFieldType::Float;
- }
- case FieldType::FIELD_VECTOR:
- {
- return BaseFieldType::Vector;
- }
- case FieldType::FIELD_CLASSPTR:
- case FieldType::FIELD_ENTVARS:
- case FieldType::FIELD_EDICT:
- case FieldType::FIELD_EHANDLE:
- {
- return BaseFieldType::Entity;
- }
- case FieldType::FIELD_STRINGPTR:
- case FieldType::FIELD_STRING:
- {
- return BaseFieldType::String;
- }
- }
-
- return BaseFieldType::None;
-}
-
+#include "pdata_shared.h"
#define GET_TYPE_DESCRIPTION(position, data, baseType, list) \
GET_TYPE_DESCRIPTION_START(position, data, baseType) \
@@ -140,231 +78,6 @@ static BaseFieldType GetBaseDataType(TypeDescription &data)
}
-cell GetData(void *pObject, TypeDescription &data, int element)
-{
- switch (data.fieldType)
- {
- case FieldType::FIELD_INTEGER:
- case FieldType::FIELD_STRINGINT:
- {
- return get_pdata(pObject, data.fieldOffset, element);
- }
- case FieldType::FIELD_CLASS:
- case FieldType::FIELD_STRUCTURE:
- {
- return get_pdata_direct(pObject, data.fieldOffset);
- }
- case FieldType::FIELD_POINTER:
- case FieldType::FIELD_FUNCTION:
- {
- return reinterpret_cast(get_pdata(pObject, data.fieldOffset, element));
- }
- case FieldType::FIELD_SHORT:
- {
- if (data.fieldUnsigned)
- {
- return get_pdata(pObject, data.fieldOffset, element);
- }
- else
- {
- return get_pdata(pObject, data.fieldOffset, element);
- }
- }
- case FieldType::FIELD_CHARACTER:
- {
- if (data.fieldUnsigned)
- {
- return get_pdata(pObject, data.fieldOffset, element);
- }
- else
- {
- return get_pdata(pObject, data.fieldOffset, element);
- }
- }
- case FieldType::FIELD_BOOLEAN:
- {
- return get_pdata(pObject, data.fieldOffset, element) ? 1 : 0;
- }
- }
-
- return 0;
-}
-
-void SetData(void *pObject, TypeDescription &data, cell value, int element)
-{
- switch (data.fieldType)
- {
- case FieldType::FIELD_INTEGER:
- case FieldType::FIELD_STRINGINT:
- {
- set_pdata(pObject, data.fieldOffset, static_cast(value), element);
- break;
- }
- case FieldType::FIELD_POINTER:
- case FieldType::FIELD_FUNCTION:
- {
- set_pdata(pObject, data.fieldOffset, reinterpret_cast(value), element);
- break;
- }
- case FieldType::FIELD_SHORT:
- {
- if (data.fieldUnsigned)
- {
- set_pdata(pObject, data.fieldOffset, static_cast(value), element);
- }
- else
- {
- set_pdata(pObject, data.fieldOffset, static_cast(value), element);
- }
- break;
- }
- case FieldType::FIELD_CHARACTER:
- {
- if (data.fieldUnsigned)
- {
- set_pdata(pObject, data.fieldOffset, static_cast(value), element);
- }
- else
- {
- set_pdata(pObject, data.fieldOffset, static_cast(value), element);
- }
- break;
- }
- case FieldType::FIELD_BOOLEAN:
- {
- set_pdata(pObject, data.fieldOffset, value != 0, element);
- break;
- }
- }
-}
-
-cell GetDataFloat(void *pObject, TypeDescription &data, int element)
-{
- return amx_ftoc(get_pdata(pObject, data.fieldOffset, element));
-}
-
-void SetDataFloat(void *pObject, TypeDescription &data, float value, int element)
-{
- set_pdata(pObject, data.fieldOffset, value, element);
-}
-
-void GetDataVector(void *pObject, TypeDescription &data, cell *pVector, int element)
-{
- auto vector = get_pdata(pObject, data.fieldOffset, element);
-
- pVector[0] = amx_ftoc(vector.x);
- pVector[1] = amx_ftoc(vector.y);
- pVector[2] = amx_ftoc(vector.z);
-}
-
-void SetDataVector(void *pObject, TypeDescription &data, cell *pVector, int element)
-{
- Vector vector(amx_ctof(pVector[0]), amx_ctof(pVector[1]), amx_ctof(pVector[2]));
-
- set_pdata(pObject, data.fieldOffset, vector, element);
-}
-
-cell GetDataEntity(void *pObject, TypeDescription &data, int element)
-{
- switch (data.fieldType)
- {
- case FieldType::FIELD_CLASSPTR:
- {
- return TypeConversion.cbase_to_id(get_pdata(pObject, data.fieldOffset, element));
- }
- case FieldType::FIELD_ENTVARS:
- {
- return TypeConversion.entvars_to_id(get_pdata(pObject, data.fieldOffset, element));
- }
- case FieldType::FIELD_EDICT:
- {
- return TypeConversion.edict_to_id(get_pdata(pObject, data.fieldOffset, element));
- }
- case FieldType::FIELD_EHANDLE:
- {
- return TypeConversion.edict_to_id(get_pdata(pObject, data.fieldOffset, element).Get());
- }
- }
-
- return 0;
-}
-
-void SetDataEntity(void *pObject, TypeDescription &data, int value, int element)
-{
- switch (data.fieldType)
- {
- case FieldType::FIELD_CLASSPTR:
- {
- set_pdata(pObject, data.fieldOffset, value != -1 ? TypeConversion.id_to_cbase(value) : nullptr, element);
- break;
- }
- case FieldType::FIELD_ENTVARS:
- {
- set_pdata(pObject, data.fieldOffset, value != -1 ? TypeConversion.id_to_entvars(value) : nullptr, element);
- break;
- }
- case FieldType::FIELD_EDICT:
- {
- set_pdata(pObject, data.fieldOffset, value != -1 ? TypeConversion.id_to_edict(value) : nullptr, element);
- break;
- }
- case FieldType::FIELD_EHANDLE:
- {
- get_pdata(pObject, data.fieldOffset, element).Set(value != -1 ? TypeConversion.id_to_edict(value) : nullptr);
- break;
- }
- }
-}
-
-char* GetDataString(void *pObject, TypeDescription &data, int element)
-{
- switch (data.fieldType)
- {
- case FieldType::FIELD_STRING:
- {
- return get_pdata_direct(pObject, data.fieldOffset, element, data.fieldSize);
- }
- case FieldType::FIELD_STRINGPTR:
- {
- return get_pdata(pObject, data.fieldOffset, element);
- }
- }
-
- return nullptr;
-}
-
-cell SetDataString(void *pObject, TypeDescription &data, const char *value, int maxlen, int element)
-{
- switch (data.fieldType)
- {
- case FieldType::FIELD_STRING:
- {
- auto buffer = get_pdata_direct(pObject, data.fieldOffset);
- return strncopy(buffer, value, ke::Min(maxlen + 1, data.fieldSize));
- }
- case FieldType::FIELD_STRINGPTR:
- {
- auto buffer = get_pdata(pObject, data.fieldOffset, element);
-
- if (!buffer || maxlen > static_cast(strlen(buffer)))
- {
- if (buffer)
- {
- free(buffer);
- }
-
- buffer = reinterpret_cast(malloc(maxlen + 1));
- set_pdata(pObject, data.fieldOffset, buffer, element);
- }
-
- return strncopy(buffer, value, maxlen + 1);
- }
- }
-
- return 0;
-}
-
-
// native any:get_ent_data(entity, const class[], const member[], element = 0);
static cell AMX_NATIVE_CALL get_ent_data(AMX *amx, cell *params)
{
@@ -377,7 +90,7 @@ static cell AMX_NATIVE_CALL get_ent_data(AMX *amx, cell *params)
int element = params[4];
CHECK_ELEMENT(element);
- return GetData(TypeConversion.id_to_edict(entity)->pvPrivateData, data, element);
+ return PvData::GetInt(entity, data, element);
}
// native set_ent_data(entity, const class[], const member[], any:value, element = 0);
@@ -398,7 +111,7 @@ static cell AMX_NATIVE_CALL set_ent_data(AMX *amx, cell *params)
return 0;
}
- SetData(TypeConversion.id_to_edict(entity)->pvPrivateData, data, params[4], element);
+ PvData::SetInt(entity, data, params[4], element);
return 1;
}
@@ -416,7 +129,7 @@ static cell AMX_NATIVE_CALL get_ent_data_float(AMX *amx, cell *params)
int element = params[4];
CHECK_ELEMENT(element);
- return GetDataFloat(TypeConversion.id_to_edict(entity)->pvPrivateData, data, element);
+ return PvData::GetFloat(entity, data, element);
}
// native set_ent_data_float(entity, const classname[], const member[], Float:value, element = 0);
@@ -431,7 +144,7 @@ static cell AMX_NATIVE_CALL set_ent_data_float(AMX *amx, cell *params)
int element = params[5];
CHECK_ELEMENT(element);
- SetDataFloat(TypeConversion.id_to_edict(entity)->pvPrivateData, data, amx_ctof(params[4]), element);
+ PvData::SetFloat(entity, data, amx_ctof(params[4]), element);
return 1;
}
@@ -449,7 +162,7 @@ static cell AMX_NATIVE_CALL get_ent_data_vector(AMX *amx, cell *params)
int element = params[5];
CHECK_ELEMENT(element);
- GetDataVector(TypeConversion.id_to_edict(entity)->pvPrivateData, data, MF_GetAmxAddr(amx, params[4]), element);
+ PvData::GetVector(entity, data, MF_GetAmxAddr(amx, params[4]), element);
return 1;
}
@@ -466,7 +179,7 @@ static cell AMX_NATIVE_CALL set_ent_data_vector(AMX *amx, cell *params)
int element = params[5];
CHECK_ELEMENT(element);
- SetDataVector(TypeConversion.id_to_edict(entity)->pvPrivateData, data, MF_GetAmxAddr(amx, params[4]), element);
+ PvData::SetVector(entity, data, MF_GetAmxAddr(amx, params[4]), element);
return 1;
}
@@ -484,7 +197,7 @@ static cell AMX_NATIVE_CALL get_ent_data_entity(AMX *amx, cell *params)
int element = params[4];
CHECK_ELEMENT(element);
- return GetDataEntity(TypeConversion.id_to_edict(entity)->pvPrivateData, data, element);
+ return PvData::GetEntity(entity, data, element);
}
// native set_ent_data_entity(entity, const class[], const member[], value, element = 0);
@@ -506,7 +219,7 @@ static cell AMX_NATIVE_CALL set_ent_data_entity(AMX *amx, cell *params)
int element = params[5];
CHECK_ELEMENT(element);
- SetDataEntity(TypeConversion.id_to_edict(entity)->pvPrivateData, data, value, element);
+ PvData::SetEntity(entity, data, value, element);
return 1;
}
@@ -527,7 +240,7 @@ static cell AMX_NATIVE_CALL get_ent_data_string(AMX *amx, cell *params)
auto buffer = params[4];
auto maxlen = params[5];
- auto string = GetDataString(TypeConversion.id_to_edict(entity)->pvPrivateData, data, element);
+ auto string = PvData::GetString(entity, data, element);
if (data.fieldSize)
{
@@ -552,7 +265,7 @@ static cell AMX_NATIVE_CALL set_ent_data_string(AMX *amx, cell *params)
int length;
const char *value = MF_GetAmxString(amx, params[4], 0, &length);
- return SetDataString(TypeConversion.id_to_edict(entity)->pvPrivateData, data, value, length, element);
+ return PvData::SetString(entity, data, value, length, element);
}
@@ -568,7 +281,7 @@ static cell AMX_NATIVE_CALL get_gamerules_int(AMX *amx, cell *params)
int element = params[3];
CHECK_ELEMENT(element);
- return GetData(GameRulesAddress, data, element);
+ return PvData::GetInt(GameRulesAddress, data, element);
}
// native set_gamerules_int(const class[], const member[], any:value, element = 0);
@@ -588,7 +301,7 @@ static cell AMX_NATIVE_CALL set_gamerules_int(AMX *amx, cell *params)
return 0;
}
- SetData(GameRulesAddress, data, params[3], element);
+ PvData::SetInt(GameRulesAddress, data, params[3], element);
return 0;
}
@@ -605,7 +318,7 @@ static cell AMX_NATIVE_CALL get_gamerules_float(AMX *amx, cell *params)
int element = params[3];
CHECK_ELEMENT(element);
- return GetDataFloat(GameRulesAddress, data, element);
+ return PvData::GetFloat(GameRulesAddress, data, element);
}
// native set_gamerules_float(const class[], const member[], Float:value, element = 0);
@@ -619,7 +332,7 @@ static cell AMX_NATIVE_CALL set_gamerules_float(AMX *amx, cell *params)
int element = params[4];
CHECK_ELEMENT(element);
- SetDataFloat(GameRulesAddress, data, amx_ctof(params[3]), element);
+ PvData::SetFloat(GameRulesAddress, data, amx_ctof(params[3]), element);
return 1;
}
@@ -636,7 +349,7 @@ static cell AMX_NATIVE_CALL get_gamerules_vector(AMX *amx, cell *params)
int element = params[4];
CHECK_ELEMENT(element);
- GetDataVector(GameRulesAddress, data, MF_GetAmxAddr(amx, params[3]), element);
+ PvData::GetVector(GameRulesAddress, data, MF_GetAmxAddr(amx, params[3]), element);
return 1;
}
@@ -652,7 +365,7 @@ static cell AMX_NATIVE_CALL set_gamerules_vector(AMX *amx, cell *params)
int element = params[4];
CHECK_ELEMENT(element);
- GetDataVector(GameRulesAddress, data, MF_GetAmxAddr(amx, params[3]), element);
+ PvData::GetVector(GameRulesAddress, data, MF_GetAmxAddr(amx, params[3]), element);
return 1;
}
@@ -669,7 +382,7 @@ static cell AMX_NATIVE_CALL get_gamerules_entity(AMX *amx, cell *params)
int element = params[3];
CHECK_ELEMENT(element);
- return GetDataEntity(GameRulesAddress, data, element);
+ return PvData::GetEntity(GameRulesAddress, data, element);
}
// native set_gamerules_entity(const class[], const member[], value, element = 0);
@@ -690,7 +403,7 @@ static cell AMX_NATIVE_CALL set_gamerules_entity(AMX *amx, cell *params)
int element = params[4];
CHECK_ELEMENT(element);
- SetDataEntity(GameRulesAddress, data, params[3], element);
+ PvData::SetEntity(GameRulesAddress, data, params[3], element);
return 0;
}
@@ -710,7 +423,7 @@ static cell AMX_NATIVE_CALL get_gamerules_string(AMX *amx, cell *params)
auto buffer = params[3];
auto maxlen = params[4];
- auto string = GetDataString(GameRulesAddress, data, element);
+ auto string = PvData::GetString(GameRulesAddress, data, element);
if (data.fieldSize)
{
@@ -734,7 +447,7 @@ static cell AMX_NATIVE_CALL set_gamerules_string(AMX *amx, cell *params)
int length;
const char *value = MF_GetAmxString(amx, params[3], 0, &length);
- return SetDataString(GameRulesAddress, data, value, length, element);
+ return PvData::SetString(GameRulesAddress, data, value, length, element);
}
diff --git a/modules/fakemeta/pdata_shared.h b/modules/fakemeta/pdata_shared.h
new file mode 100644
index 00000000..983cc9e1
--- /dev/null
+++ b/modules/fakemeta/pdata_shared.h
@@ -0,0 +1,375 @@
+//
+// AMX Mod X, based on AMX Mod by Aleksander Naszko ("OLO").
+// Copyright (C) The AMX Mod X Development Team.
+//
+// This software is licensed under the GNU General Public License, version 3 or higher.
+// Additional exceptions apply. For full license details, see LICENSE.txt or visit:
+// https://alliedmods.net/amxmodx-license
+
+#ifndef _PDATA_SHARED_H_
+#define _PDATA_SHARED_H_
+
+#include
+#include
+#include
+#include
+
+extern HLTypeConversion TypeConversion;
+
+enum class BaseFieldType
+{
+ None,
+ Integer,
+ Float,
+ Vector,
+ Entity,
+ String,
+};
+
+class PvData
+{
+public:
+
+ static cell GetInt(int index, TypeDescription &data, int element)
+ {
+ return GetInt(TypeConversion.id_to_edict(index)->pvPrivateData, data, element);
+ }
+
+ static cell GetInt(void *pObject, TypeDescription &data, int element)
+ {
+ switch (data.fieldType)
+ {
+ case FieldType::FIELD_INTEGER:
+ case FieldType::FIELD_STRINGINT:
+ {
+ return get_pdata(pObject, data.fieldOffset, element);
+ }
+ case FieldType::FIELD_CLASS:
+ case FieldType::FIELD_STRUCTURE:
+ {
+ return get_pdata_direct(pObject, data.fieldOffset);
+ }
+ case FieldType::FIELD_POINTER:
+ case FieldType::FIELD_FUNCTION:
+ {
+ return reinterpret_cast(get_pdata(pObject, data.fieldOffset, element));
+ }
+ case FieldType::FIELD_SHORT:
+ {
+ if (data.fieldUnsigned)
+ {
+ return get_pdata(pObject, data.fieldOffset, element);
+ }
+ else
+ {
+ return get_pdata(pObject, data.fieldOffset, element);
+ }
+ }
+ case FieldType::FIELD_CHARACTER:
+ {
+ if (data.fieldUnsigned)
+ {
+ return get_pdata(pObject, data.fieldOffset, element);
+ }
+ else
+ {
+ return get_pdata(pObject, data.fieldOffset, element);
+ }
+ }
+ case FieldType::FIELD_BOOLEAN:
+ {
+ return get_pdata(pObject, data.fieldOffset, element) ? 1 : 0;
+ }
+ }
+
+ return 0;
+ }
+
+
+ static void SetInt(int index, TypeDescription &data, cell value, int element)
+ {
+ SetInt(TypeConversion.id_to_edict(index)->pvPrivateData, data, value, element);
+ }
+
+ static void SetInt(void *pObject, TypeDescription &data, cell value, int element)
+ {
+ switch (data.fieldType)
+ {
+ case FieldType::FIELD_INTEGER:
+ case FieldType::FIELD_STRINGINT:
+ {
+ set_pdata(pObject, data.fieldOffset, static_cast(value), element);
+ break;
+ }
+ case FieldType::FIELD_POINTER:
+ case FieldType::FIELD_FUNCTION:
+ {
+ set_pdata(pObject, data.fieldOffset, reinterpret_cast(value), element);
+ break;
+ }
+ case FieldType::FIELD_SHORT:
+ {
+ if (data.fieldUnsigned)
+ {
+ set_pdata(pObject, data.fieldOffset, static_cast(value), element);
+ }
+ else
+ {
+ set_pdata(pObject, data.fieldOffset, static_cast(value), element);
+ }
+ break;
+ }
+ case FieldType::FIELD_CHARACTER:
+ {
+ if (data.fieldUnsigned)
+ {
+ set_pdata(pObject, data.fieldOffset, static_cast(value), element);
+ }
+ else
+ {
+ set_pdata(pObject, data.fieldOffset, static_cast(value), element);
+ }
+ break;
+ }
+ case FieldType::FIELD_BOOLEAN:
+ {
+ set_pdata(pObject, data.fieldOffset, value != 0, element);
+ break;
+ }
+ }
+ }
+
+
+ static cell GetFloat(int index, TypeDescription &data, int element)
+ {
+ return GetFloat(TypeConversion.id_to_edict(index)->pvPrivateData, data, element);
+ }
+
+ static cell GetFloat(void *pObject, TypeDescription &data, int element)
+ {
+ return amx_ftoc(get_pdata(pObject, data.fieldOffset, element));
+ }
+
+
+ static void SetFloat(int index, TypeDescription &data, float value, int element)
+ {
+ SetFloat(TypeConversion.id_to_edict(index)->pvPrivateData, data, value, element);
+ }
+
+ static void SetFloat(void *pObject, TypeDescription &data, float value, int element)
+ {
+ set_pdata(pObject, data.fieldOffset, value, element);
+ }
+
+
+ static void GetVector(int index, TypeDescription &data, cell *pVector, int element)
+ {
+ return GetVector(TypeConversion.id_to_edict(index)->pvPrivateData, data, pVector, element);
+ }
+
+ static void GetVector(void *pObject, TypeDescription &data, cell *pVector, int element)
+ {
+ auto vector = get_pdata(pObject, data.fieldOffset, element);
+
+ pVector[0] = amx_ftoc(vector.x);
+ pVector[1] = amx_ftoc(vector.y);
+ pVector[2] = amx_ftoc(vector.z);
+ }
+
+
+ static void SetVector(int index, TypeDescription &data, cell *pVector, int element)
+ {
+ SetVector(TypeConversion.id_to_edict(index)->pvPrivateData, data, pVector, element);
+ }
+
+ static void SetVector(void *pObject, TypeDescription &data, cell *pVector, int element)
+ {
+ Vector vector(amx_ctof(pVector[0]), amx_ctof(pVector[1]), amx_ctof(pVector[2]));
+
+ set_pdata(pObject, data.fieldOffset, vector, element);
+ }
+
+
+ static cell GetEntity(int index, TypeDescription &data, int element)
+ {
+ return GetEntity(TypeConversion.id_to_edict(index)->pvPrivateData, data, element);
+ }
+
+ static cell GetEntity(void *pObject, TypeDescription &data, int element)
+ {
+ switch (data.fieldType)
+ {
+ case FieldType::FIELD_CLASSPTR:
+ {
+ return TypeConversion.cbase_to_id(get_pdata(pObject, data.fieldOffset, element));
+ }
+ case FieldType::FIELD_ENTVARS:
+ {
+ return TypeConversion.entvars_to_id(get_pdata(pObject, data.fieldOffset, element));
+ }
+ case FieldType::FIELD_EDICT:
+ {
+ return TypeConversion.edict_to_id(get_pdata(pObject, data.fieldOffset, element));
+ }
+ case FieldType::FIELD_EHANDLE:
+ {
+ return TypeConversion.edict_to_id(get_pdata(pObject, data.fieldOffset, element).Get());
+ }
+ }
+
+ return 0;
+ }
+
+
+ static void SetEntity(int index, TypeDescription &data, int value, int element)
+ {
+ SetEntity(TypeConversion.id_to_edict(index)->pvPrivateData, data, value, element);
+ }
+
+ static void SetEntity(void *pObject, TypeDescription &data, int value, int element)
+ {
+ switch (data.fieldType)
+ {
+ case FieldType::FIELD_CLASSPTR:
+ {
+ set_pdata(pObject, data.fieldOffset, value != -1 ? TypeConversion.id_to_cbase(value) : nullptr, element);
+ break;
+ }
+ case FieldType::FIELD_ENTVARS:
+ {
+ set_pdata(pObject, data.fieldOffset, value != -1 ? TypeConversion.id_to_entvars(value) : nullptr, element);
+ break;
+ }
+ case FieldType::FIELD_EDICT:
+ {
+ set_pdata(pObject, data.fieldOffset, value != -1 ? TypeConversion.id_to_edict(value) : nullptr, element);
+ break;
+ }
+ case FieldType::FIELD_EHANDLE:
+ {
+ get_pdata(pObject, data.fieldOffset, element).Set(value != -1 ? TypeConversion.id_to_edict(value) : nullptr);
+ break;
+ }
+ }
+ }
+
+
+ static char* GetString(int index, TypeDescription &data, int element)
+ {
+ return GetString(TypeConversion.id_to_edict(index)->pvPrivateData, data, element);
+ }
+
+ static char* GetString(void *pObject, TypeDescription &data, int element)
+ {
+ switch (data.fieldType)
+ {
+ case FieldType::FIELD_STRING:
+ {
+ return get_pdata_direct(pObject, data.fieldOffset, element, data.fieldSize);
+ }
+ case FieldType::FIELD_STRINGPTR:
+ {
+ return get_pdata(pObject, data.fieldOffset, element);
+ }
+ }
+
+ return nullptr;
+ }
+
+
+ static cell SetString(int index, TypeDescription &data, const char *value, int maxlen, int element)
+ {
+ return SetString(TypeConversion.id_to_edict(index)->pvPrivateData, data, value, maxlen, element);
+ }
+
+ static cell SetString(void *pObject, TypeDescription &data, const char *value, int maxlen, int element)
+ {
+ switch (data.fieldType)
+ {
+ case FieldType::FIELD_STRING:
+ {
+ auto buffer = get_pdata_direct(pObject, data.fieldOffset);
+ return strncopy(buffer, value, ke::Min(maxlen + 1, data.fieldSize));
+ }
+ case FieldType::FIELD_STRINGPTR:
+ {
+ auto buffer = get_pdata(pObject, data.fieldOffset, element);
+
+ if (!buffer || maxlen > static_cast(strlen(buffer)))
+ {
+ if (buffer)
+ {
+ free(buffer);
+ }
+
+ buffer = reinterpret_cast(malloc(maxlen + 1));
+ set_pdata(pObject, data.fieldOffset, buffer, element);
+ }
+
+ return strncopy(buffer, value, maxlen + 1);
+ }
+ }
+
+ return 0;
+ }
+
+public:
+
+ static BaseFieldType GetBaseDataType(TypeDescription &data)
+ {
+ switch (data.fieldType)
+ {
+ case FieldType::FIELD_INTEGER:
+ case FieldType::FIELD_STRINGINT:
+ case FieldType::FIELD_SHORT:
+ case FieldType::FIELD_CHARACTER:
+ case FieldType::FIELD_CLASS:
+ case FieldType::FIELD_STRUCTURE:
+ case FieldType::FIELD_POINTER:
+ case FieldType::FIELD_FUNCTION:
+ case FieldType::FIELD_BOOLEAN:
+ {
+ return BaseFieldType::Integer;
+ }
+ case FieldType::FIELD_FLOAT:
+ {
+ return BaseFieldType::Float;
+ }
+ case FieldType::FIELD_VECTOR:
+ {
+ return BaseFieldType::Vector;
+ }
+ case FieldType::FIELD_CLASSPTR:
+ case FieldType::FIELD_ENTVARS:
+ case FieldType::FIELD_EDICT:
+ case FieldType::FIELD_EHANDLE:
+ {
+ return BaseFieldType::Entity;
+ }
+ case FieldType::FIELD_STRINGPTR:
+ case FieldType::FIELD_STRING:
+ {
+ return BaseFieldType::String;
+ }
+ }
+
+ return BaseFieldType::None;
+ }
+
+ static const char* GetBaseTypeName(BaseFieldType baseType)
+ {
+ static const char *BaseFieldTypeName[] =
+ {
+ "none",
+ "integer",
+ "float",
+ "vector",
+ "entity",
+ "string",
+ };
+
+ return BaseFieldTypeName[static_cast(baseType)];
+ }
+};
+
+#endif // _PDATA_SHARED_H_
| | | |