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:
parent
e2c769a9c5
commit
1d22e50899
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue