Store permanent magic effects in savegame (Fixes #1648)

moveref
scrawl 10 years ago
parent 6c9875969a
commit e2346d7c37

@ -170,9 +170,9 @@ namespace MWWorld
Ptr search (const std::string& id); Ptr search (const std::string& id);
void writeState (ESM::InventoryState& state) const; virtual void writeState (ESM::InventoryState& state) const;
void readState (const ESM::InventoryState& state); virtual void readState (const ESM::InventoryState& state);
friend class ContainerStoreIterator; friend class ContainerStoreIterator;
}; };

@ -5,6 +5,7 @@
#include <algorithm> #include <algorithm>
#include <components/esm/loadench.hpp> #include <components/esm/loadench.hpp>
#include <components/esm/inventorystate.hpp>
#include "../mwbase/environment.hpp" #include "../mwbase/environment.hpp"
#include "../mwbase/world.hpp" #include "../mwbase/world.hpp"
@ -654,3 +655,39 @@ bool MWWorld::InventoryStore::isEquipped(const MWWorld::Ptr &item)
} }
return false; return false;
} }
void MWWorld::InventoryStore::writeState(ESM::InventoryState &state) const
{
MWWorld::ContainerStore::writeState(state);
for (TEffectMagnitudes::const_iterator it = mPermanentMagicEffectMagnitudes.begin(); it != mPermanentMagicEffectMagnitudes.end(); ++it)
{
std::vector<std::pair<float, float> > params;
for (std::vector<EffectParams>::const_iterator pIt = it->second.begin(); pIt != it->second.end(); ++pIt)
{
params.push_back(std::make_pair(pIt->mRandom, pIt->mMultiplier));
}
state.mPermanentMagicEffectMagnitudes[it->first] = params;
}
}
void MWWorld::InventoryStore::readState(const ESM::InventoryState &state)
{
MWWorld::ContainerStore::readState(state);
for (ESM::InventoryState::TEffectMagnitudes::const_iterator it = state.mPermanentMagicEffectMagnitudes.begin();
it != state.mPermanentMagicEffectMagnitudes.end(); ++it)
{
std::vector<EffectParams> params;
for (std::vector<std::pair<float, float> >::const_iterator pIt = it->second.begin(); pIt != it->second.end(); ++pIt)
{
EffectParams p;
p.mRandom = pIt->first;
p.mMultiplier = pIt->second;
params.push_back(p);
}
mPermanentMagicEffectMagnitudes[it->first] = params;
}
}

@ -205,6 +205,10 @@ namespace MWWorld
virtual void clear(); virtual void clear();
///< Empty container. ///< Empty container.
virtual void writeState (ESM::InventoryState& state) const;
virtual void readState (const ESM::InventoryState& state);
}; };
} }

@ -59,6 +59,21 @@ void ESM::InventoryState::load (ESMReader &esm)
esm.getHNT (count, "COUN"); esm.getHNT (count, "COUN");
mLevelledItemMap[id] = count; mLevelledItemMap[id] = count;
} }
while (esm.isNextSub("MAGI"))
{
std::string id = esm.getHString();
std::vector<std::pair<float, float> > params;
while (esm.isNextSub("RAND"))
{
float rand, multiplier;
esm.getHT (rand);
esm.getHNT (multiplier, "MULT");
params.push_back(std::make_pair(rand, multiplier));
}
mPermanentMagicEffectMagnitudes[id] = params;
}
} }
void ESM::InventoryState::save (ESMWriter &esm) const void ESM::InventoryState::save (ESMWriter &esm) const
@ -75,4 +90,16 @@ void ESM::InventoryState::save (ESMWriter &esm) const
esm.writeHNString ("LEVM", it->first); esm.writeHNString ("LEVM", it->first);
esm.writeHNT ("COUN", it->second); esm.writeHNT ("COUN", it->second);
} }
for (TEffectMagnitudes::const_iterator it = mPermanentMagicEffectMagnitudes.begin(); it != mPermanentMagicEffectMagnitudes.end(); ++it)
{
esm.writeHNString("MAGI", it->first);
const std::vector<std::pair<float, float> >& params = it->second;
for (std::vector<std::pair<float, float> >::const_iterator pIt = params.begin(); pIt != params.end(); ++pIt)
{
esm.writeHNT ("RAND", pIt->first);
esm.writeHNT ("MULT", pIt->second);
}
}
} }

@ -24,6 +24,9 @@ namespace ESM
std::map<std::string, int> mLevelledItemMap; std::map<std::string, int> mLevelledItemMap;
typedef std::map<std::string, std::vector<std::pair<float, float> > > TEffectMagnitudes;
TEffectMagnitudes mPermanentMagicEffectMagnitudes;
virtual ~InventoryState() {} virtual ~InventoryState() {}
virtual void load (ESMReader &esm); virtual void load (ESMReader &esm);

Loading…
Cancel
Save