mirror of
https://github.com/pgbackrest/pgbackrest.git
synced 2024-12-12 10:04:14 +02:00
Do not pass NULL to memcpy() in Buffer/String objects.
glibc and others seem tolerant of this but the behavior is undefined. Found with -fsanitize=undefined.
This commit is contained in:
parent
98792b1b0c
commit
ccbe2a1f70
@ -112,7 +112,10 @@ bufDup(const Buffer *buffer)
|
|||||||
|
|
||||||
// Create object and copy data
|
// Create object and copy data
|
||||||
Buffer *this = bufNew(bufUsed(buffer));
|
Buffer *this = bufNew(bufUsed(buffer));
|
||||||
memcpy(this->pub.buffer, buffer->pub.buffer, bufSize(this));
|
|
||||||
|
if (bufUsed(buffer) != 0)
|
||||||
|
memcpy(this->pub.buffer, buffer->pub.buffer, bufSize(this));
|
||||||
|
|
||||||
this->pub.used = bufSize(this);
|
this->pub.used = bufSize(this);
|
||||||
|
|
||||||
FUNCTION_TEST_RETURN(this);
|
FUNCTION_TEST_RETURN(this);
|
||||||
|
@ -173,7 +173,9 @@ strNewBuf(const Buffer *buffer)
|
|||||||
String *this = strNewFixed(bufUsed(buffer));
|
String *this = strNewFixed(bufUsed(buffer));
|
||||||
|
|
||||||
// Assign string
|
// Assign string
|
||||||
memcpy(this->pub.buffer, bufPtrConst(buffer), strSize(this));
|
if (strSize(this) != 0)
|
||||||
|
memcpy(this->pub.buffer, bufPtrConst(buffer), strSize(this));
|
||||||
|
|
||||||
this->pub.buffer[strSize(this)] = 0;
|
this->pub.buffer[strSize(this)] = 0;
|
||||||
|
|
||||||
FUNCTION_TEST_RETURN(this);
|
FUNCTION_TEST_RETURN(this);
|
||||||
|
@ -29,6 +29,8 @@ testRun(void)
|
|||||||
TEST_ASSIGN(buffer, bufNewC("TEST-STR", sizeof("TEST-STR") - 1), "new buffer from string");
|
TEST_ASSIGN(buffer, bufNewC("TEST-STR", sizeof("TEST-STR") - 1), "new buffer from string");
|
||||||
TEST_RESULT_BOOL(memcmp(bufPtr(buffer), "TEST-STR", 8) == 0, true, "check buffer");
|
TEST_RESULT_BOOL(memcmp(bufPtr(buffer), "TEST-STR", 8) == 0, true, "check buffer");
|
||||||
|
|
||||||
|
TEST_RESULT_UINT(bufSize(bufDup(bufNew(0))), 0, "duplicate empty buffer");
|
||||||
|
|
||||||
TEST_RESULT_VOID(bufFree(buffer), "free buffer");
|
TEST_RESULT_VOID(bufFree(buffer), "free buffer");
|
||||||
TEST_RESULT_VOID(bufFree(bufNew(0)), "free empty buffer");
|
TEST_RESULT_VOID(bufFree(bufNew(0)), "free empty buffer");
|
||||||
|
|
||||||
|
@ -49,6 +49,8 @@ testRun(void)
|
|||||||
TEST_RESULT_UINT(strlen(strZ(string)), 13, "check size with strlen()");
|
TEST_RESULT_UINT(strlen(strZ(string)), 13, "check size with strlen()");
|
||||||
TEST_RESULT_INT(strZNull(string)[2], 'a', "check character");
|
TEST_RESULT_INT(strZNull(string)[2], 'a', "check character");
|
||||||
|
|
||||||
|
TEST_RESULT_UINT(strSize(strNewBuf(bufNew(0))), 0, "new string from empty buffer");
|
||||||
|
|
||||||
TEST_RESULT_VOID(strFree(string), "free string");
|
TEST_RESULT_VOID(strFree(string), "free string");
|
||||||
|
|
||||||
// -------------------------------------------------------------------------------------------------------------------------
|
// -------------------------------------------------------------------------------------------------------------------------
|
||||||
|
Loading…
Reference in New Issue
Block a user