aboutsummaryrefslogtreecommitdiff
path: root/src/server/database/Database/Field.cpp
diff options
context:
space:
mode:
authorjackpoz <giacomopoz@gmail.com>2016-08-10 16:02:22 +0200
committerjackpoz <giacomopoz@gmail.com>2016-08-10 16:02:22 +0200
commitabe37e458c2b482d478ce98ba44bc8dcf76caeb1 (patch)
tree9cbbbbaa3ab019e549b3e310e6f3ebf9aae8d62b /src/server/database/Database/Field.cpp
parent375593761167ba1bf8ef16bbe345cb569ad1e00b (diff)
Server/Database: Reduce differences between 3.3.5 and 6.x branches
Cherry-pick 1bea52fd4649b6a1761aa157f9e74f01e19872e7 and 543bea32 to add support to TYPE_BINARY MySQL field type
Diffstat (limited to 'src/server/database/Database/Field.cpp')
-rw-r--r--src/server/database/Database/Field.cpp10
1 files changed, 5 insertions, 5 deletions
diff --git a/src/server/database/Database/Field.cpp b/src/server/database/Database/Field.cpp
index 20a42871b91..efddd005c06 100644
--- a/src/server/database/Database/Field.cpp
+++ b/src/server/database/Database/Field.cpp
@@ -39,7 +39,7 @@ void Field::SetByteValue(void* newValue, enum_field_types newType, uint32 length
data.raw = true;
}
-void Field::SetStructuredValue(char* newValue, enum_field_types newType)
+void Field::SetStructuredValue(char* newValue, enum_field_types newType, uint32 length)
{
if (data.value)
CleanUp();
@@ -47,10 +47,10 @@ void Field::SetStructuredValue(char* newValue, enum_field_types newType)
// This value stores somewhat structured data that needs function style casting
if (newValue)
{
- size_t size = strlen(newValue);
- data.value = new char [size+1];
- strcpy((char*)data.value, newValue);
- data.length = size;
+ data.value = new char[length + 1];
+ memcpy(data.value, newValue, length);
+ *(reinterpret_cast<char*>(data.value) + length) = '\0';
+ data.length = length;
}
data.type = newType;