Skip to content

Commit

Permalink
Merge branch 'constcorrectattributes' into 'master'
Browse files Browse the repository at this point in the history
Sprinkle const-correctness in NifLoader

See merge request OpenMW/openmw!4436
  • Loading branch information
Assumeru committed Oct 31, 2024
2 parents 20d9105 + b71ec84 commit 81612a5
Showing 1 changed file with 30 additions and 28 deletions.
58 changes: 30 additions & 28 deletions components/nifosg/nifloader.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -535,7 +535,7 @@ namespace NifOsg
return nullptr;
}

bool handleEffect(const Nif::NiAVObject* nifNode, osg::StateSet* stateset)
bool handleEffect(const Nif::NiAVObject* nifNode, osg::StateSet* stateset) const
{
if (nifNode->recType != Nif::RC_NiTextureEffect)
{
Expand Down Expand Up @@ -592,7 +592,7 @@ namespace NifOsg
}

// Get a default dataVariance for this node to be used as a hint by optimization (post)routines
osg::ref_ptr<osg::Group> createNode(const Nif::NiAVObject* nifNode)
static osg::ref_ptr<osg::Group> createNode(const Nif::NiAVObject* nifNode)
{
osg::ref_ptr<osg::Group> node;
osg::Object::DataVariance dataVariance = osg::Object::UNSPECIFIED;
Expand Down Expand Up @@ -863,7 +863,7 @@ namespace NifOsg
return node;
}

void handleMeshControllers(const Nif::NiAVObject* nifNode, osg::Node* node,
static void handleMeshControllers(const Nif::NiAVObject* nifNode, osg::Node* node,
SceneUtil::CompositeStateSetUpdater* composite, const std::vector<unsigned int>& boundTextures,
int animflags)
{
Expand Down Expand Up @@ -891,7 +891,8 @@ namespace NifOsg
}
}

void handleNodeControllers(const Nif::NiAVObject* nifNode, osg::Node* node, int animflags, bool& isAnimated)
void handleNodeControllers(
const Nif::NiAVObject* nifNode, osg::Node* node, int animflags, bool& isAnimated) const
{
for (Nif::NiTimeControllerPtr ctrl = nifNode->mController; !ctrl.empty(); ctrl = ctrl->mNext)
{
Expand Down Expand Up @@ -969,7 +970,7 @@ namespace NifOsg
}

void handleMaterialControllers(const Nif::NiProperty* materialProperty,
SceneUtil::CompositeStateSetUpdater* composite, int animflags, const osg::Material* baseMaterial)
SceneUtil::CompositeStateSetUpdater* composite, int animflags, const osg::Material* baseMaterial) const
{
for (Nif::NiTimeControllerPtr ctrl = materialProperty->mController; !ctrl.empty(); ctrl = ctrl->mNext)
{
Expand Down Expand Up @@ -1026,8 +1027,9 @@ namespace NifOsg
VFS::Path::toNormalized(Misc::ResourceHelpers::correctTexturePath(path, mImageManager->getVFS())));
}

osg::ref_ptr<osg::Texture2D> attachTexture(const std::string& name, osg::ref_ptr<osg::Image> image, bool wrapS,
bool wrapT, unsigned int uvSet, osg::StateSet* stateset, std::vector<unsigned int>& boundTextures)
static osg::ref_ptr<osg::Texture2D> attachTexture(const std::string& name, osg::ref_ptr<osg::Image> image,
bool wrapS, bool wrapT, unsigned int uvSet, osg::StateSet* stateset,
std::vector<unsigned int>& boundTextures)
{
osg::ref_ptr<osg::Texture2D> texture2d = new osg::Texture2D(image);
if (image)
Expand All @@ -1047,14 +1049,14 @@ namespace NifOsg
}

osg::ref_ptr<osg::Texture2D> attachExternalTexture(const std::string& name, const std::string& path, bool wrapS,
bool wrapT, unsigned int uvSet, osg::StateSet* stateset, std::vector<unsigned int>& boundTextures)
bool wrapT, unsigned int uvSet, osg::StateSet* stateset, std::vector<unsigned int>& boundTextures) const
{
return attachTexture(name, getTextureImage(path), wrapS, wrapT, uvSet, stateset, boundTextures);
}

osg::ref_ptr<osg::Texture2D> attachNiSourceTexture(const std::string& name, const Nif::NiSourceTexture* st,
bool wrapS, bool wrapT, unsigned int uvSet, osg::StateSet* stateset,
std::vector<unsigned int>& boundTextures)
std::vector<unsigned int>& boundTextures) const
{
return attachTexture(name, handleSourceTexture(st), wrapS, wrapT, uvSet, stateset, boundTextures);
}
Expand All @@ -1070,7 +1072,7 @@ namespace NifOsg
}

void handleTextureControllers(const Nif::NiProperty* texProperty,
SceneUtil::CompositeStateSetUpdater* composite, osg::StateSet* stateset, int animflags)
SceneUtil::CompositeStateSetUpdater* composite, osg::StateSet* stateset, int animflags) const
{
for (Nif::NiTimeControllerPtr ctrl = texProperty->mController; !ctrl.empty(); ctrl = ctrl->mNext)
{
Expand Down Expand Up @@ -1122,7 +1124,7 @@ namespace NifOsg

void handleParticlePrograms(Nif::NiParticleModifierPtr modifier, Nif::NiParticleModifierPtr collider,
osg::Group* attachTo, osgParticle::ParticleSystem* partsys,
osgParticle::ParticleProcessor::ReferenceFrame rf)
osgParticle::ParticleProcessor::ReferenceFrame rf) const
{
osgParticle::ModularProgram* program = new osgParticle::ModularProgram;
attachTo->addChild(program);
Expand Down Expand Up @@ -1189,7 +1191,7 @@ namespace NifOsg

// Load the initial state of the particle system, i.e. the initial particles and their positions, velocity and
// colors.
void handleParticleInitialState(
static void handleParticleInitialState(
const Nif::NiAVObject* nifNode, ParticleSystem* partsys, const Nif::NiParticleSystemController* partctrl)
{
auto particleNode = static_cast<const Nif::NiParticles*>(nifNode);
Expand Down Expand Up @@ -1245,7 +1247,7 @@ namespace NifOsg
partsys->setInitialBound(box);
}

osg::ref_ptr<Emitter> handleParticleEmitter(const Nif::NiParticleSystemController* partctrl)
static osg::ref_ptr<Emitter> handleParticleEmitter(const Nif::NiParticleSystemController* partctrl)
{
std::vector<int> targets;
if (partctrl->recType == Nif::RC_NiBSPArrayController && !partctrl->emitAtVertex())
Expand Down Expand Up @@ -1743,7 +1745,7 @@ namespace NifOsg
parentNode->addChild(drawable);
}

osg::BlendFunc::BlendFuncMode getBlendMode(int mode)
osg::BlendFunc::BlendFuncMode getBlendMode(int mode) const
{
switch (mode)
{
Expand Down Expand Up @@ -1775,7 +1777,7 @@ namespace NifOsg
}
}

osg::AlphaFunc::ComparisonFunction getTestMode(int mode)
osg::AlphaFunc::ComparisonFunction getTestMode(int mode) const
{
switch (mode)
{
Expand All @@ -1801,7 +1803,7 @@ namespace NifOsg
}
}

osg::Stencil::Function getStencilFunction(Nif::NiStencilProperty::TestFunc func)
osg::Stencil::Function getStencilFunction(Nif::NiStencilProperty::TestFunc func) const
{
using TestFunc = Nif::NiStencilProperty::TestFunc;
switch (func)
Expand Down Expand Up @@ -1829,7 +1831,7 @@ namespace NifOsg
}
}

osg::Stencil::Operation getStencilOperation(Nif::NiStencilProperty::Action op)
osg::Stencil::Operation getStencilOperation(Nif::NiStencilProperty::Action op) const
{
using Action = Nif::NiStencilProperty::Action;
switch (op)
Expand Down Expand Up @@ -2002,7 +2004,7 @@ namespace NifOsg
return texEnv;
}

void handleDepthFlags(osg::StateSet* stateset, bool depthTest, bool depthWrite)
static void handleDepthFlags(osg::StateSet* stateset, bool depthTest, bool depthWrite)
{
if (!depthWrite && !depthTest)
{
Expand All @@ -2019,7 +2021,7 @@ namespace NifOsg

void handleTextureProperty(const Nif::NiTexturingProperty* texprop, const std::string& nodeName,
osg::StateSet* stateset, SceneUtil::CompositeStateSetUpdater* composite,
std::vector<unsigned int>& boundTextures, int animflags)
std::vector<unsigned int>& boundTextures, int animflags) const
{
// overriding a parent NiTexturingProperty, so remove what was previously bound
clearBoundTextures(stateset, boundTextures);
Expand Down Expand Up @@ -2182,7 +2184,7 @@ namespace NifOsg
}

void handleShaderMaterialNodeProperties(
const Bgsm::MaterialFile* material, osg::StateSet* stateset, std::vector<unsigned int>& boundTextures)
const Bgsm::MaterialFile* material, osg::StateSet* stateset, std::vector<unsigned int>& boundTextures) const
{
const unsigned int uvSet = 0;
const bool wrapS = material->wrapS();
Expand Down Expand Up @@ -2222,7 +2224,7 @@ namespace NifOsg
handleDepthFlags(stateset, material->mDepthTest, material->mDepthWrite);
}

void handleDecal(bool enabled, bool hasSortAlpha, osg::Node& node)
void handleDecal(bool enabled, bool hasSortAlpha, osg::Node& node) const
{
if (!enabled)
return;
Expand All @@ -2236,7 +2238,7 @@ namespace NifOsg
stateset->setRenderBinDetails(1, "SORT_BACK_TO_FRONT");
}

void handleAlphaTesting(
static void handleAlphaTesting(
bool enabled, osg::AlphaFunc::ComparisonFunction function, int threshold, osg::Node& node)
{
if (enabled)
Expand All @@ -2253,7 +2255,7 @@ namespace NifOsg
}

void handleAlphaBlending(
bool enabled, int sourceMode, int destMode, bool sort, bool& hasSortAlpha, osg::Node& node)
bool enabled, int sourceMode, int destMode, bool sort, bool& hasSortAlpha, osg::Node& node) const
{
if (enabled)
{
Expand Down Expand Up @@ -2288,8 +2290,8 @@ namespace NifOsg
}
}

void handleShaderMaterialDrawableProperties(
const Bgsm::MaterialFile* shaderMat, osg::ref_ptr<osg::Material> mat, osg::Node& node, bool& hasSortAlpha)
void handleShaderMaterialDrawableProperties(const Bgsm::MaterialFile* shaderMat,
osg::ref_ptr<osg::Material> mat, osg::Node& node, bool& hasSortAlpha) const
{
mat->setAlpha(osg::Material::FRONT_AND_BACK, shaderMat->mTransparency);
handleAlphaTesting(shaderMat->mAlphaTest, osg::AlphaFunc::GREATER, shaderMat->mAlphaTestThreshold, node);
Expand All @@ -2312,7 +2314,7 @@ namespace NifOsg
}

void handleTextureSet(const Nif::BSShaderTextureSet* textureSet, bool wrapS, bool wrapT,
const std::string& nodeName, osg::StateSet* stateset, std::vector<unsigned int>& boundTextures)
const std::string& nodeName, osg::StateSet* stateset, std::vector<unsigned int>& boundTextures) const
{
const unsigned int uvSet = 0;

Expand Down Expand Up @@ -2653,9 +2655,9 @@ namespace NifOsg
// global sharing of State Attributes will reduce the number of GL calls as the osg::State will check by pointer
// to see if state is the same
template <class Attribute>
Attribute* shareAttribute(const osg::ref_ptr<Attribute>& attr)
static Attribute* shareAttribute(const osg::ref_ptr<Attribute>& attr)
{
typedef std::set<osg::ref_ptr<Attribute>, CompareStateAttribute> Cache;
using Cache = std::set<osg::ref_ptr<Attribute>, CompareStateAttribute>;
static Cache sCache;
static std::mutex sMutex;
std::lock_guard<std::mutex> lock(sMutex);
Expand Down

0 comments on commit 81612a5

Please sign in to comment.