mirror of
https://github.com/vcmi/vcmi.git
synced 2025-09-16 09:26:28 +02:00
Fix double free and use of dead reference when saving (#445)
This commit is contained in:
committed by
ArseniyShestakov
parent
4af288aee4
commit
ce0b4b222d
@@ -32,7 +32,7 @@ CSavingScreen::CSavingScreen()
|
|||||||
center(pos);
|
center(pos);
|
||||||
// TODO: we should really use std::shared_ptr for passing StartInfo around.
|
// TODO: we should really use std::shared_ptr for passing StartInfo around.
|
||||||
localSi = new StartInfo(*LOCPLINT->cb->getStartInfo());
|
localSi = new StartInfo(*LOCPLINT->cb->getStartInfo());
|
||||||
localMi = new CMapInfo();
|
localMi = std::make_shared<CMapInfo>();
|
||||||
localMi->mapHeader = std::unique_ptr<CMapHeader>(new CMapHeader(*LOCPLINT->cb->getMapHeader()));
|
localMi->mapHeader = std::unique_ptr<CMapHeader>(new CMapHeader(*LOCPLINT->cb->getMapHeader()));
|
||||||
|
|
||||||
tabSel = std::make_shared<SelectionTab>(screenType);
|
tabSel = std::make_shared<SelectionTab>(screenType);
|
||||||
@@ -46,12 +46,11 @@ CSavingScreen::CSavingScreen()
|
|||||||
|
|
||||||
CSavingScreen::~CSavingScreen()
|
CSavingScreen::~CSavingScreen()
|
||||||
{
|
{
|
||||||
vstd::clear_pointer(localMi);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const CMapInfo * CSavingScreen::getMapInfo()
|
const CMapInfo * CSavingScreen::getMapInfo()
|
||||||
{
|
{
|
||||||
return localMi;
|
return localMi.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
const StartInfo * CSavingScreen::getStartInfo()
|
const StartInfo * CSavingScreen::getStartInfo()
|
||||||
@@ -61,10 +60,10 @@ const StartInfo * CSavingScreen::getStartInfo()
|
|||||||
|
|
||||||
void CSavingScreen::changeSelection(std::shared_ptr<CMapInfo> to)
|
void CSavingScreen::changeSelection(std::shared_ptr<CMapInfo> to)
|
||||||
{
|
{
|
||||||
if(localMi == to.get())
|
if(localMi == to)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
localMi = to.get();
|
localMi = to;
|
||||||
localSi = localMi->scenarioOptionsOfSave;
|
localSi = localMi->scenarioOptionsOfSave;
|
||||||
card->changeSelection();
|
card->changeSelection();
|
||||||
}
|
}
|
||||||
@@ -76,7 +75,7 @@ void CSavingScreen::saveGame()
|
|||||||
|
|
||||||
std::string path = "Saves/" + tabSel->inputName->text;
|
std::string path = "Saves/" + tabSel->inputName->text;
|
||||||
|
|
||||||
auto overWrite = [&]() -> void
|
auto overWrite = [this, path]() -> void
|
||||||
{
|
{
|
||||||
Settings lastSave = settings.write["general"]["lastSave"];
|
Settings lastSave = settings.write["general"]["lastSave"];
|
||||||
lastSave->String() = path;
|
lastSave->String() = path;
|
||||||
|
@@ -19,7 +19,7 @@ class CSavingScreen : public CSelectionBase
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
const StartInfo * localSi;
|
const StartInfo * localSi;
|
||||||
CMapInfo * localMi;
|
std::shared_ptr<CMapInfo> localMi;
|
||||||
|
|
||||||
CSavingScreen();
|
CSavingScreen();
|
||||||
~CSavingScreen();
|
~CSavingScreen();
|
||||||
|
Reference in New Issue
Block a user