From 3f42df45fda4a07a59ae31605ef98530993244c6 Mon Sep 17 00:00:00 2001 From: nukeykt Date: Mon, 16 Sep 2019 04:53:08 +0900 Subject: [PATCH] Fix memory issues in resource manager --- source/blood/src/resource.cpp | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/source/blood/src/resource.cpp b/source/blood/src/resource.cpp index 2e701923b..14749421b 100644 --- a/source/blood/src/resource.cpp +++ b/source/blood/src/resource.cpp @@ -147,8 +147,8 @@ void Resource::Init(const char *filename) int nNameLength = strnlen(tdict[i].name, 8); dict[i].type = (char*)Alloc(nTypeLength+1); dict[i].name = (char*)Alloc(nNameLength+1); - strncpy(dict[i].type, tdict[i].type, 3); - strncpy(dict[i].name, tdict[i].name, 8); + strncpy(dict[i].type, tdict[i].type, min(3, nTypeLength)); + strncpy(dict[i].name, tdict[i].name, min(8, nNameLength)); dict[i].type[nTypeLength] = 0; dict[i].name[nNameLength] = 0; dict[i].id = B_LITTLE32(tdict[i].id); @@ -234,7 +234,7 @@ void Resource::Flush(CACHENODE *h) #ifdef USE_QHEAP heap->Free(h->ptr); #else - delete h->ptr; + delete[] (char*)h->ptr; #endif h->ptr = NULL; @@ -489,7 +489,7 @@ void *Resource::Alloc(int nSize) { dassert(node->lockCount == 0); dassert(node->ptr != NULL); - delete node->ptr; + delete[] (char*)node->ptr; node->ptr = NULL; RemoveMRU(node); p = new char[nSize]; @@ -509,7 +509,7 @@ void Resource::Free(void *p) heap->Free(p); #else dassert(p != NULL); - delete p; + delete[] (char*)p; #endif } @@ -807,7 +807,8 @@ void Resource::RemoveNode(DICTNODE* pNode) pNode->type = NULL; } *pNode = dict[--count]; - if (pNode->ptr) + Bmemset(&dict[count], 0, sizeof(DICTNODE)); + if (pNode->ptr && !pNode->lockCount) { pNode->prev->next = pNode; pNode->next->prev = pNode;