|
|
@ -37,7 +37,7 @@ ESM::VarType ESM::Variant::getType() const
|
|
|
|
return mType;
|
|
|
|
return mType;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::string ESM::Variant::toString() const
|
|
|
|
std::string ESM::Variant::getString() const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (!mData)
|
|
|
|
if (!mData)
|
|
|
|
throw std::runtime_error ("can not convert empty variant to string");
|
|
|
|
throw std::runtime_error ("can not convert empty variant to string");
|
|
|
@ -81,23 +81,30 @@ void ESM::Variant::read (ESMReader& esm, Format format)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else // GMST
|
|
|
|
else // GMST
|
|
|
|
{
|
|
|
|
{
|
|
|
|
esm.getSubName();
|
|
|
|
if (!esm.hasMoreSubs())
|
|
|
|
NAME name = esm.retSubName();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (name=="STRV")
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
type = VT_String;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (name=="INTV")
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
type = VT_Int;
|
|
|
|
type = VT_None;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (name=="FLTV")
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
type = VT_Float;
|
|
|
|
esm.getSubName();
|
|
|
|
|
|
|
|
NAME name = esm.retSubName();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (name=="STRV")
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
type = VT_String;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (name=="INTV")
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
type = VT_Int;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (name=="FLTV")
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
type = VT_Float;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
esm.fail ("invalid subrecord: " + name.toString());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
|
|
|
|
esm.fail ("invalid subrecord: " + name.toString());
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
setType (type);
|
|
|
|
setType (type);
|
|
|
|