2015-08-27 03:59:21 +00:00
|
|
|
#include "weatherstate.hpp"
|
|
|
|
|
|
|
|
#include "esmreader.hpp"
|
|
|
|
#include "esmwriter.hpp"
|
|
|
|
|
2022-04-11 22:18:39 +00:00
|
|
|
namespace ESM
|
|
|
|
{
|
2015-08-27 03:59:21 +00:00
|
|
|
namespace
|
|
|
|
{
|
2022-04-11 22:18:39 +00:00
|
|
|
constexpr NAME currentRegionRecord = "CREG";
|
|
|
|
constexpr NAME timePassedRecord = "TMPS";
|
|
|
|
constexpr NAME fastForwardRecord = "FAST";
|
|
|
|
constexpr NAME weatherUpdateTimeRecord = "WUPD";
|
|
|
|
constexpr NAME transitionFactorRecord = "TRFC";
|
|
|
|
constexpr NAME currentWeatherRecord = "CWTH";
|
|
|
|
constexpr NAME nextWeatherRecord = "NWTH";
|
|
|
|
constexpr NAME queuedWeatherRecord = "QWTH";
|
|
|
|
constexpr NAME regionNameRecord = "RGNN";
|
|
|
|
constexpr NAME regionWeatherRecord = "RGNW";
|
|
|
|
constexpr NAME regionChanceRecord = "RGNC";
|
|
|
|
}
|
2015-08-27 03:59:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
void WeatherState::load(ESMReader& esm)
|
|
|
|
{
|
|
|
|
mCurrentRegion = esm.getHNString(currentRegionRecord);
|
|
|
|
esm.getHNT(mTimePassed, timePassedRecord);
|
|
|
|
esm.getHNT(mFastForward, fastForwardRecord);
|
|
|
|
esm.getHNT(mWeatherUpdateTime, weatherUpdateTimeRecord);
|
|
|
|
esm.getHNT(mTransitionFactor, transitionFactorRecord);
|
|
|
|
esm.getHNT(mCurrentWeather, currentWeatherRecord);
|
|
|
|
esm.getHNT(mNextWeather, nextWeatherRecord);
|
|
|
|
esm.getHNT(mQueuedWeather, queuedWeatherRecord);
|
|
|
|
|
2021-05-05 19:23:06 +00:00
|
|
|
while (esm.isNextSub(regionNameRecord))
|
2015-08-27 03:59:21 +00:00
|
|
|
{
|
2021-05-05 19:23:06 +00:00
|
|
|
std::string regionID = esm.getHString();
|
2015-08-27 03:59:21 +00:00
|
|
|
RegionWeatherState region;
|
|
|
|
esm.getHNT(region.mWeather, regionWeatherRecord);
|
2021-05-05 19:23:06 +00:00
|
|
|
while (esm.isNextSub(regionChanceRecord))
|
2015-08-27 03:59:21 +00:00
|
|
|
{
|
|
|
|
char chance;
|
2021-05-05 19:23:06 +00:00
|
|
|
esm.getHT(chance);
|
2015-08-27 03:59:21 +00:00
|
|
|
region.mChances.push_back(chance);
|
|
|
|
}
|
|
|
|
|
|
|
|
mRegions.insert(std::make_pair(regionID, region));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void WeatherState::save(ESMWriter& esm) const
|
|
|
|
{
|
2021-06-23 20:19:08 +00:00
|
|
|
esm.writeHNCString(currentRegionRecord, mCurrentRegion);
|
2015-08-27 03:59:21 +00:00
|
|
|
esm.writeHNT(timePassedRecord, mTimePassed);
|
|
|
|
esm.writeHNT(fastForwardRecord, mFastForward);
|
|
|
|
esm.writeHNT(weatherUpdateTimeRecord, mWeatherUpdateTime);
|
|
|
|
esm.writeHNT(transitionFactorRecord, mTransitionFactor);
|
|
|
|
esm.writeHNT(currentWeatherRecord, mCurrentWeather);
|
|
|
|
esm.writeHNT(nextWeatherRecord, mNextWeather);
|
|
|
|
esm.writeHNT(queuedWeatherRecord, mQueuedWeather);
|
|
|
|
|
|
|
|
std::map<std::string, RegionWeatherState>::const_iterator it = mRegions.begin();
|
|
|
|
for(; it != mRegions.end(); ++it)
|
|
|
|
{
|
|
|
|
esm.writeHNCString(regionNameRecord, it->first.c_str());
|
|
|
|
esm.writeHNT(regionWeatherRecord, it->second.mWeather);
|
|
|
|
for(size_t i = 0; i < it->second.mChances.size(); ++i)
|
|
|
|
{
|
|
|
|
esm.writeHNT(regionChanceRecord, it->second.mChances[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|