Core/Boot/Boot: Amend use-after-move cases in GenerateFromFile()

In terms of order of operations, the move would occur first before the
construction of the relevant reader would occur. However, given the
local variable 'path' was declared const, this bug actually wouldn't
occur, as std::move on a const variable does nothing (in a non-mutable
context), resulting in a copy instead, masking this issue.

Given this is a bug waiting to happen, we correct the code.
This commit is contained in:
Lioncash 2019-05-21 08:35:26 -04:00
parent e2c769a9c5
commit 1d22e50899

View File

@ -155,7 +155,7 @@ BootParameters::GenerateFromFile(std::vector<std::string> paths,
std::transform(extension.begin(), extension.end(), extension.begin(), ::tolower); std::transform(extension.begin(), extension.end(), extension.begin(), ::tolower);
} }
const std::string path = paths.front(); std::string path = paths.front();
if (paths.size() == 1) if (paths.size() == 1)
paths.clear(); paths.clear();
@ -172,14 +172,16 @@ BootParameters::GenerateFromFile(std::vector<std::string> paths,
if (extension == ".elf") if (extension == ".elf")
{ {
return std::make_unique<BootParameters>( auto elf_reader = std::make_unique<ElfReader>(path);
Executable{std::move(path), std::make_unique<ElfReader>(path)}, savestate_path); return std::make_unique<BootParameters>(Executable{std::move(path), std::move(elf_reader)},
savestate_path);
} }
if (extension == ".dol") if (extension == ".dol")
{ {
return std::make_unique<BootParameters>( auto dol_reader = std::make_unique<DolReader>(path);
Executable{std::move(path), std::make_unique<DolReader>(path)}, savestate_path); return std::make_unique<BootParameters>(Executable{std::move(path), std::move(dol_reader)},
savestate_path);
} }
if (is_drive) if (is_drive)