saveload fix

This commit is contained in:
nillerusr 2022-01-09 19:59:13 +03:00
parent 5cb2d31b4b
commit 0ff5b74afa
3 changed files with 25 additions and 15 deletions

View file

@ -2128,8 +2128,8 @@ int CSaveRestore::SaveReadNameAndComment( FileHandle_t f, OUT_Z_CAP(nameSize) ch
int nNumberOfFields; int nNumberOfFields;
char *pData; char *pData;
int nFieldSize; short nFieldSize;
pData = pSaveData; pData = pSaveData;
// Allocate a table for the strings, and parse the table // Allocate a table for the strings, and parse the table
@ -2148,9 +2148,12 @@ int CSaveRestore::SaveReadNameAndComment( FileHandle_t f, OUT_Z_CAP(nameSize) ch
pTokenList = NULL; pTokenList = NULL;
// short, short (size, index of field name) // short, short (size, index of field name)
nFieldSize = *(short *)pData;
Q_memcpy( &nFieldSize, pData, sizeof(short) );
pData += sizeof(short); pData += sizeof(short);
pFieldName = pTokenList[ *(short *)pData ]; short index = 0;
Q_memcpy( &index, pData, sizeof(short) );
pFieldName = pTokenList[index];
if ( !pFieldName || Q_stricmp( pFieldName, "GameHeader" ) ) if ( !pFieldName || Q_stricmp( pFieldName, "GameHeader" ) )
{ {
@ -2161,7 +2164,7 @@ int CSaveRestore::SaveReadNameAndComment( FileHandle_t f, OUT_Z_CAP(nameSize) ch
// int (fieldcount) // int (fieldcount)
pData += sizeof(short); pData += sizeof(short);
nNumberOfFields = *(int*)pData; Q_memcpy( &nNumberOfFields, pData, sizeof(int) );
pData += nFieldSize; pData += nFieldSize;
// Each field is a short (size), short (index of name), binary string of "size" bytes (data) // Each field is a short (size), short (index of name), binary string of "size" bytes (data)
@ -2172,10 +2175,11 @@ int CSaveRestore::SaveReadNameAndComment( FileHandle_t f, OUT_Z_CAP(nameSize) ch
// szName // szName
// Actual Data // Actual Data
nFieldSize = *(short *)pData; Q_memcpy( &nFieldSize, pData, sizeof(short) );
pData += sizeof(short); pData += sizeof(short);
pFieldName = pTokenList[ *(short *)pData ]; Q_memcpy( &index, pData, sizeof(short) );
pFieldName = pTokenList[index];
pData += sizeof(short); pData += sizeof(short);
if ( !Q_stricmp( pFieldName, "comment" ) ) if ( !Q_stricmp( pFieldName, "comment" ) )

View file

@ -152,7 +152,7 @@ const char *UTIL_FunctionToName( datamap_t *pMap, inputfunc_t *function )
// This is used to save/restore function pointers (convert text back to pointer) // This is used to save/restore function pointers (convert text back to pointer)
// Input : *pName - name of the member function // Input : *pName - name of the member function
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
inputfunc_t *UTIL_FunctionFromName( datamap_t *pMap, const char *pName ) inputfunc_t UTIL_FunctionFromName( datamap_t *pMap, const char *pName )
{ {
while ( pMap ) while ( pMap )
{ {
@ -170,7 +170,7 @@ inputfunc_t *UTIL_FunctionFromName( datamap_t *pMap, const char *pName )
{ {
if ( FStrEq( pName, pMap->dataDesc[i].fieldName ) ) if ( FStrEq( pName, pMap->dataDesc[i].fieldName ) )
{ {
return EXTRACT_INPUTFUNC_FUNCTIONPTR(pMap->dataDesc[i].inputFunc); return pMap->dataDesc[i].inputFunc;
} }
} }
} }
@ -2240,8 +2240,14 @@ int CRestore::ReadFunction( datamap_t *pMap, inputfunc_t **pValue, int count, in
if ( *pszFunctionName == 0 ) if ( *pszFunctionName == 0 )
*pValue = NULL; *pValue = NULL;
else else
*pValue = UTIL_FunctionFromName( pMap, pszFunctionName ); {
inputfunc_t func = UTIL_FunctionFromName( pMap, pszFunctionName );
#ifdef GNUC
Q_memcpy( (void*)pValue, &func, sizeof(void*)*2 );
#else
Q_memcpy( (void*)pValue, &func, sizeof(void*) );
#endif
}
return 0; return 0;
} }

View file

@ -113,9 +113,9 @@ DECLARE_FIELD_SIZE( FIELD_SOUNDNAME, sizeof(int))
DECLARE_FIELD_SIZE( FIELD_INPUT, sizeof(int)) DECLARE_FIELD_SIZE( FIELD_INPUT, sizeof(int))
#ifdef POSIX #ifdef POSIX
// pointer to members under gnuc are 8bytes if you have a virtual func // pointer to members under gnuc are 8bytes if you have a virtual func
DECLARE_FIELD_SIZE( FIELD_FUNCTION, sizeof(uint64)) DECLARE_FIELD_SIZE( FIELD_FUNCTION, 2 * sizeof(void *))
#else #else
DECLARE_FIELD_SIZE( FIELD_FUNCTION, sizeof(int *)) DECLARE_FIELD_SIZE( FIELD_FUNCTION, sizeof(void *))
#endif #endif
DECLARE_FIELD_SIZE( FIELD_VMATRIX, 16 * sizeof(float)) DECLARE_FIELD_SIZE( FIELD_VMATRIX, 16 * sizeof(float))
DECLARE_FIELD_SIZE( FIELD_VMATRIX_WORLDSPACE, 16 * sizeof(float)) DECLARE_FIELD_SIZE( FIELD_VMATRIX_WORLDSPACE, 16 * sizeof(float))
@ -202,7 +202,7 @@ extern ISaveRestoreOps *eventFuncs;
#define DEFINE_OUTPUT( name, outputname ) { FIELD_CUSTOM, #name, { _offsetof(classNameTypedef, name), 0 }, 1, FTYPEDESC_OUTPUT | FTYPEDESC_SAVE | FTYPEDESC_KEY, outputname, eventFuncs } #define DEFINE_OUTPUT( name, outputname ) { FIELD_CUSTOM, #name, { _offsetof(classNameTypedef, name), 0 }, 1, FTYPEDESC_OUTPUT | FTYPEDESC_SAVE | FTYPEDESC_KEY, outputname, eventFuncs }
// replaces EXPORT table for portability and non-DLL based systems (xbox) // replaces EXPORT table for portability and non-DLL based systems (xbox)
#define DEFINE_FUNCTION_RAW( function, func_type ) { FIELD_VOID, nameHolder.GenerateName(#function), { NULL, NULL }, 1, FTYPEDESC_FUNCTIONTABLE, NULL, NULL, (inputfunc_t)((func_type)(&classNameTypedef::function)) } #define DEFINE_FUNCTION_RAW( function, func_type ) { FIELD_VOID, nameHolder.GenerateName(#function), { NULL, NULL }, 1, FTYPEDESC_FUNCTIONTABLE, NULL, NULL, (inputfunc_t)(&classNameTypedef::function) }
#define DEFINE_FUNCTION( function ) DEFINE_FUNCTION_RAW( function, inputfunc_t ) #define DEFINE_FUNCTION( function ) DEFINE_FUNCTION_RAW( function, inputfunc_t )
@ -278,7 +278,7 @@ struct typedescription_t
// Used to track exclusion of baseclass fields // Used to track exclusion of baseclass fields
int override_count; int override_count;
// Tolerance for field errors for float fields // Tolerance for field errors for float fields
float fieldTolerance; float fieldTolerance;
}; };