refactor(Core/InstanceScript): refactored load and save methods (#14977)

Co-authored-by: joschiwald <736792+joschiwald@users.noreply.github.com>
This commit is contained in:
Skjalf
2023-02-12 15:53:48 -03:00
committed by GitHub
parent 5cc73e1963
commit 0dbb8c814c
126 changed files with 677 additions and 2004 deletions

View File

@@ -18,6 +18,8 @@
#ifndef BFD_H_
#define BFD_H_
#define DataHeader "BFD"
enum Data
{
TYPE_GELIHAST = 0,

View File

@@ -35,6 +35,7 @@ public:
void Initialize() override
{
SetHeaders(DataHeader);
memset(&_encounters, 0, sizeof(_encounters));
_requiredDeaths = 0;
}
@@ -111,30 +112,24 @@ public:
SaveToDB();
}
std::string GetSaveData() override
void ReadSaveDataMore(std::istringstream& data) override
{
std::ostringstream saveStream;
saveStream << "B L " << _encounters[0] << ' ' << _encounters[1] << ' ' << _encounters[2] << ' ' << _encounters[3] << ' ' << _encounters[4] << ' ' << _encounters[5];
return saveStream.str();
data >> _encounters[0];
data >> _encounters[1];
data >> _encounters[2];
data >> _encounters[3];
data >> _encounters[4];
data >> _encounters[5];
}
void Load(const char* in) override
void WriteSaveDataMore(std::ostringstream& data) override
{
if (!in)
return;
char dataHead1, dataHead2;
std::istringstream loadStream(in);
loadStream >> dataHead1 >> dataHead2;
if (dataHead1 == 'B' && dataHead2 == 'L')
{
for (uint8 i = 0; i < MAX_ENCOUNTERS; ++i)
{
loadStream >> _encounters[i];
if (_encounters[i] == IN_PROGRESS)
_encounters[i] = NOT_STARTED;
}
}
data << _encounters[0] << ' '
<< _encounters[1] << ' '
<< _encounters[2] << ' '
<< _encounters[3] << ' '
<< _encounters[4] << ' '
<< _encounters[5];
}
bool IsFireEventDone()