mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-26 09:35:28 +00:00
Don't check mInterpolationType each iteration
This commit is contained in:
parent
68d6b6b2f3
commit
029e438c11
@ -177,42 +177,49 @@ struct KeyListT {
|
|||||||
|
|
||||||
KeyT<T> key;
|
KeyT<T> key;
|
||||||
NIFStream &nifReference = *nif;
|
NIFStream &nifReference = *nif;
|
||||||
for(size_t i = 0;i < count;i++)
|
|
||||||
|
if(mInterpolationType == sLinearInterpolation)
|
||||||
{
|
{
|
||||||
if(mInterpolationType == sLinearInterpolation)
|
for(size_t i = 0;i < count;i++)
|
||||||
{
|
{
|
||||||
readTimeAndValue(nifReference, key);
|
readTimeAndValue(nifReference, key);
|
||||||
mKeys.push_back(key);
|
mKeys.push_back(key);
|
||||||
}
|
}
|
||||||
else if(mInterpolationType == sQuadraticInterpolation)
|
}
|
||||||
|
else if(mInterpolationType == sQuadraticInterpolation)
|
||||||
|
{
|
||||||
|
for(size_t i = 0;i < count;i++)
|
||||||
{
|
{
|
||||||
readQuadratic(nifReference, key);
|
readQuadratic(nifReference, key);
|
||||||
mKeys.push_back(key);
|
mKeys.push_back(key);
|
||||||
}
|
}
|
||||||
else if(mInterpolationType == sTBCInterpolation)
|
}
|
||||||
|
else if(mInterpolationType == sTBCInterpolation)
|
||||||
|
{
|
||||||
|
for(size_t i = 0;i < count;i++)
|
||||||
{
|
{
|
||||||
readTBC(nifReference, key);
|
readTBC(nifReference, key);
|
||||||
mKeys.push_back(key);
|
mKeys.push_back(key);
|
||||||
}
|
}
|
||||||
//XYZ keys aren't actually read here.
|
|
||||||
//data.hpp sees that the last type read was sXYZInterpolation and:
|
|
||||||
// Eats a floating point number, then
|
|
||||||
// Re-runs the read function 3 more times, with force enabled so that the previous values aren't cleared.
|
|
||||||
// When it does that it's reading in a bunch of sLinearInterpolation keys, not sXYZInterpolation.
|
|
||||||
else if(mInterpolationType == sXYZInterpolation)
|
|
||||||
{
|
|
||||||
//Don't try to read XYZ keys into the wrong part
|
|
||||||
if ( count != 1 )
|
|
||||||
nif->file->fail("XYZ_ROTATION_KEY count should always be '1' . Retrieved Value: "+Ogre::StringConverter::toString(count));
|
|
||||||
}
|
|
||||||
else if (0 == mInterpolationType)
|
|
||||||
{
|
|
||||||
if (count != 0)
|
|
||||||
nif->file->fail("Interpolation type 0 doesn't work with keys");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
nif->file->fail("Unhandled interpolation type: "+Ogre::StringConverter::toString(mInterpolationType));
|
|
||||||
}
|
}
|
||||||
|
//XYZ keys aren't actually read here.
|
||||||
|
//data.hpp sees that the last type read was sXYZInterpolation and:
|
||||||
|
// Eats a floating point number, then
|
||||||
|
// Re-runs the read function 3 more times, with force enabled so that the previous values aren't cleared.
|
||||||
|
// When it does that it's reading in a bunch of sLinearInterpolation keys, not sXYZInterpolation.
|
||||||
|
else if(mInterpolationType == sXYZInterpolation)
|
||||||
|
{
|
||||||
|
//Don't try to read XYZ keys into the wrong part
|
||||||
|
if ( count != 1 )
|
||||||
|
nif->file->fail("XYZ_ROTATION_KEY count should always be '1' . Retrieved Value: "+Ogre::StringConverter::toString(count));
|
||||||
|
}
|
||||||
|
else if (0 == mInterpolationType)
|
||||||
|
{
|
||||||
|
if (count != 0)
|
||||||
|
nif->file->fail("Interpolation type 0 doesn't work with keys");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
nif->file->fail("Unhandled interpolation type: "+Ogre::StringConverter::toString(mInterpolationType));
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user