From d93f8eadf838eaa688c5e139c76c7f02b1369f40 Mon Sep 17 00:00:00 2001 From: Ray Date: Sun, 8 Sep 2019 01:11:53 +0200 Subject: [PATCH] REVIEW: GetFileName(): Security checks --- src/core.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/core.c b/src/core.c index 9e26a6399..44ac12b52 100644 --- a/src/core.c +++ b/src/core.c @@ -1838,9 +1838,10 @@ static const char *strprbrk(const char *s, const char *charset) // Get pointer to filename for a path string const char *GetFileName(const char *filePath) { - const char *fileName = strprbrk(filePath, "\\/"); + const char *fileName = NULL; + if (filePath != NULL) fileName = strprbrk(filePath, "\\/"); - if (!fileName || fileName == filePath) return filePath; + if (!fileName || (fileName == filePath)) return filePath; return fileName + 1; } @@ -1853,7 +1854,7 @@ const char *GetFileNameWithoutExt(const char *filePath) static char fileName[MAX_FILENAMEWITHOUTEXT_LENGTH]; memset(fileName, 0, MAX_FILENAMEWITHOUTEXT_LENGTH); - strcpy(fileName, GetFileName(filePath)); // Get filename with extension + if (filePath != NULL) strcpy(fileName, GetFileName(filePath)); // Get filename with extension int len = strlen(fileName);