- fixed stale pointer access in Unix version of D_AddFile.

Pointer was assigned a buffer of a local variable that went out of scope before checking its content.
Fixes #268 (hopefully)
This commit is contained in:
Christoph Oelckers 2021-02-26 13:28:02 +01:00
parent a46792e519
commit 4c915180da

View file

@ -208,10 +208,10 @@ bool D_AddFile(TArray<FString>& wadfiles, const char* file, bool check, int posi
// Confirm file exists in filesystem. // Confirm file exists in filesystem.
struct stat info; struct stat info;
bool found = stat(file, &info) == 0; bool found = stat(file, &info) == 0;
FString fullpath = file;
if (!found) if (!found)
{ {
// File not found, so split file into path and filename so we can enumerate the path for the file. // File not found, so split file into path and filename so we can enumerate the path for the file.
FString fullpath = file;
auto lastindex = fullpath.LastIndexOf("/"); auto lastindex = fullpath.LastIndexOf("/");
FString basepath = fullpath.Left(lastindex); FString basepath = fullpath.Left(lastindex);
FString filename = fullpath.Right(fullpath.Len() - lastindex - 1); FString filename = fullpath.Right(fullpath.Len() - lastindex - 1);