From 865bdc95f7d48124ce61a217bdeb562550eca686 Mon Sep 17 00:00:00 2001 From: asmodai Date: Tue, 25 Oct 2016 01:15:53 +0300 Subject: [PATCH] Fixed crash when motd_write called without arguments --- rehlds/engine/host_cmd.cpp | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/rehlds/engine/host_cmd.cpp b/rehlds/engine/host_cmd.cpp index 882331e..a71c03f 100644 --- a/rehlds/engine/host_cmd.cpp +++ b/rehlds/engine/host_cmd.cpp @@ -276,7 +276,7 @@ void Host_Motd_f(void) /* <3d5d4> ../engine/host_cmd.c:335 */ void Host_Motd_Write_f(void) { - char newFile[2048]; + char newFile[2048] = ""; unsigned int i; FileHandle_t pFile; @@ -295,18 +295,22 @@ void Host_Motd_Write_f(void) return; } - Q_strncpy(newFile, Cmd_Args(), ARRAYSIZE(newFile)); #ifdef REHLDS_FIXES - newFile[ARRAYSIZE(newFile) - 1] = 0; + if (Cmd_Args()) { + Q_strncpy(newFile, Cmd_Args(), ARRAYSIZE(newFile) - 1); + newFile[ARRAYSIZE(newFile) - 1] = '\0'; + } +#else // REHLDS_FIXES + Q_strncpy(newFile, Cmd_Args(), ARRAYSIZE(newFile)); #endif // REHLDS_FIXES - for (i = 0; i < Q_strlen(newFile); i++) + auto len = Q_strlen(newFile); + for (i = 0; i < len; i++) { if (newFile[i] == '\\' && newFile[i + 1] == 'n') { newFile[i] = '\n'; - Q_strncpy(&newFile[i + 1], &newFile[i + 2], min(sizeof(newFile) - 1, Q_strlen(newFile) + 1)); - newFile[sizeof(newFile) - 1] = 0; + Q_memmove(&newFile[i + 1], &newFile[i + 2], Q_strlen(&newFile[i + 2]) + 1); } } FS_Write(newFile, Q_strlen(newFile), 1, pFile);