#include "loadglob.hpp" #include "esm_reader.hpp" #include "esm_writer.hpp" namespace ESM { void Global::load(ESMReader &esm) { std::string tmp = esm.getHNString("FNAM"); if (tmp == "s") mType = VT_Short; else if (tmp == "l") mType = VT_Int; else if (tmp == "f") mType = VT_Float; else esm.fail("Illegal global variable type " + tmp); // Note: Both floats and longs are represented as floats. esm.getHNT(mValue, "FLTV"); } void Global::save(ESMWriter &esm) { switch(mType) { case VT_Short: esm.writeHNString("FNAM", "s"); break; case VT_Int: esm.writeHNString("FNAM", "l"); break; case VT_Float: esm.writeHNString("FNAM", "f"); break; default: return; } esm.writeHNT("FLTV", mValue); } }