From 66a3f3d4752354ab6a4ae49117fd4d6aae357bce Mon Sep 17 00:00:00 2001 From: David Cernat Date: Fri, 23 Jun 2017 08:29:14 +0300 Subject: [PATCH] [Server] Use cleaner solution for safely reading cell descriptions --- apps/openmw-mp/Script/Functions/Cells.cpp | 20 ++++++-------------- 1 file changed, 6 insertions(+), 14 deletions(-) diff --git a/apps/openmw-mp/Script/Functions/Cells.cpp b/apps/openmw-mp/Script/Functions/Cells.cpp index 0b26adbe8..88b73f1de 100644 --- a/apps/openmw-mp/Script/Functions/Cells.cpp +++ b/apps/openmw-mp/Script/Functions/Cells.cpp @@ -8,6 +8,8 @@ #include using namespace std; +static std::string tempCellDescription; + unsigned int CellFunctions::GetCellStateChangesSize(unsigned short pid) noexcept { Player *player; @@ -32,13 +34,8 @@ const char *CellFunctions::GetCellStateDescription(unsigned short pid, unsigned if (i >= player->cellStateChanges.count) return "invalid"; - string cellDescription = player->cellStateChanges.cellStates.at(i).cell.getDescription(); - - static vector cstrDescription; - cstrDescription.reserve(cellDescription.size() + 1); - strncpy(&cstrDescription[0], cellDescription.c_str(), cstrDescription.capacity()); - - return &cstrDescription[0]; + tempCellDescription = player->cellStateChanges.cellStates.at(i).cell.getDescription(); + return tempCellDescription.c_str(); } const char *CellFunctions::GetCell(unsigned short pid) noexcept @@ -46,13 +43,8 @@ const char *CellFunctions::GetCell(unsigned short pid) noexcept Player *player; GET_PLAYER(pid, player, 0); - string cellDescription = player->cell.getDescription().c_str(); - - static vector cstrDescription; - cstrDescription.reserve(cellDescription.size() + 1); - strncpy(&cstrDescription[0], cellDescription.c_str(), cstrDescription.capacity()); - - return &cstrDescription[0]; + tempCellDescription = player->cell.getDescription().c_str(); + return tempCellDescription.c_str(); } void CellFunctions::SetCell(unsigned short pid, const char *cellDescription) noexcept