mirror of
https://github.com/mod-playerbots/azerothcore-wotlk.git
synced 2026-01-21 12:47:07 +00:00
refactor(Core/InstanceScript): refactored load and save methods (#14977)
Co-authored-by: joschiwald <736792+joschiwald@users.noreply.github.com>
This commit is contained in:
@@ -43,6 +43,7 @@ public:
|
||||
|
||||
void Initialize() override
|
||||
{
|
||||
SetHeaders(DataHeader);
|
||||
memset(&_encounters, 0, sizeof(_encounters));
|
||||
}
|
||||
|
||||
@@ -101,31 +102,18 @@ public:
|
||||
return 0;
|
||||
}
|
||||
|
||||
std::string GetSaveData() override
|
||||
void ReadSaveDataMore(std::istringstream& data) override
|
||||
{
|
||||
std::ostringstream saveStream;
|
||||
saveStream << "U D " << _encounters[DATA_IRONAYA_DOORS] << ' ' << _encounters[DATA_STONE_KEEPERS] << ' ' << _encounters[DATA_ARCHAEDAS];
|
||||
return saveStream.str();
|
||||
data >> _encounters[DATA_IRONAYA_DOORS];
|
||||
data >> _encounters[DATA_STONE_KEEPERS];
|
||||
data >> _encounters[DATA_ARCHAEDAS];
|
||||
}
|
||||
|
||||
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 == 'U' && dataHead2 == 'D')
|
||||
{
|
||||
for (uint8 i = 0; i < MAX_ENCOUNTERS; ++i)
|
||||
{
|
||||
loadStream >> _encounters[i];
|
||||
if (_encounters[i] == IN_PROGRESS)
|
||||
_encounters[i] = NOT_STARTED;
|
||||
}
|
||||
}
|
||||
data << _encounters[DATA_IRONAYA_DOORS] << ' '
|
||||
<< _encounters[DATA_STONE_KEEPERS] << ' '
|
||||
<< _encounters[DATA_ARCHAEDAS];
|
||||
}
|
||||
|
||||
void OnCreatureCreate(Creature* creature) override
|
||||
|
||||
@@ -18,6 +18,8 @@
|
||||
#ifndef DEF_ULDAMAN_H
|
||||
#define DEF_ULDAMAN_H
|
||||
|
||||
#define DataHeader "UD"
|
||||
|
||||
enum DataTypes
|
||||
{
|
||||
DATA_IRONAYA_DOORS = 0,
|
||||
|
||||
Reference in New Issue
Block a user