diff options
Diffstat (limited to 'src/common/DataStores/DB2FileLoader.cpp')
-rw-r--r-- | src/common/DataStores/DB2FileLoader.cpp | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/src/common/DataStores/DB2FileLoader.cpp b/src/common/DataStores/DB2FileLoader.cpp index f15864e4c7b..ab2c5a99f50 100644 --- a/src/common/DataStores/DB2FileLoader.cpp +++ b/src/common/DataStores/DB2FileLoader.cpp @@ -575,13 +575,19 @@ char* DB2FileLoaderRegularImpl::AutoProduceStrings(char** indexTable, uint32 ind break; case FT_STRING: { - ((LocalizedString*)(&recordData[offset]))->Str[locale] = stringPool + (RecordGetString(rawRecord, x, z) - (char const*)_stringTable); + char const* string = RecordGetString(rawRecord, x, z); + if (string >= reinterpret_cast<char const*>(_stringTable)) // ensure string is inside _stringTable + reinterpret_cast<LocalizedString*>(&recordData[offset])->Str[locale] = stringPool + (string - reinterpret_cast<char const*>(_stringTable)); + offset += sizeof(LocalizedString); break; } case FT_STRING_NOT_LOCALIZED: { - *((char**)(&recordData[offset])) = stringPool + (RecordGetString(rawRecord, x, z) - (char const*)_stringTable); + char const* string = RecordGetString(rawRecord, x, z); + if (string >= reinterpret_cast<char const*>(_stringTable)) // ensure string is inside _stringTable + *reinterpret_cast<char**>(&recordData[offset]) = stringPool + (string - reinterpret_cast<char const*>(_stringTable)); + offset += sizeof(char*); break; } |