Merge branch 'local_static_init' into 'master'

Properly initialize local static pointers and collections

See merge request OpenMW/openmw!4386
pull/3236/head
Evil Eye 3 months ago
commit 9de501a62c

@ -846,14 +846,12 @@ namespace MWMechanics
mAI = true; mAI = true;
} }
bool MechanicsManager::isBoundItem(const MWWorld::Ptr& item) namespace
{ {
static std::set<ESM::RefId> boundItemIDCache; std::set<ESM::RefId> makeBoundItemIdCache()
// If this is empty then we haven't executed the GMST cache logic yet; or there isn't any sMagicBound* GMST's
// for some reason
if (boundItemIDCache.empty())
{ {
std::set<ESM::RefId> boundItemIDCache;
// Build a list of known bound item ID's // Build a list of known bound item ID's
const MWWorld::Store<ESM::GameSetting>& gameSettings const MWWorld::Store<ESM::GameSetting>& gameSettings
= MWBase::Environment::get().getESMStore()->get<ESM::GameSetting>(); = MWBase::Environment::get().getESMStore()->get<ESM::GameSetting>();
@ -870,15 +868,16 @@ namespace MWMechanics
boundItemIDCache.insert(ESM::RefId::stringRefId(currentGMSTValue)); boundItemIDCache.insert(ESM::RefId::stringRefId(currentGMSTValue));
} }
}
// Perform bound item check and assign the Flag_Bound bit if it passes return boundItemIDCache;
const ESM::RefId& tempItemID = item.getCellRef().getRefId(); }
}
if (boundItemIDCache.count(tempItemID) != 0) bool MechanicsManager::isBoundItem(const MWWorld::Ptr& item)
return true; {
static const std::set<ESM::RefId> boundItemIdCache = makeBoundItemIdCache();
return false; return boundItemIdCache.find(item.getCellRef().getRefId()) != boundItemIdCache.end();
} }
bool MechanicsManager::isAllowedToUse(const MWWorld::Ptr& ptr, const MWWorld::Ptr& target, MWWorld::Ptr& victim) bool MechanicsManager::isAllowedToUse(const MWWorld::Ptr& ptr, const MWWorld::Ptr& target, MWWorld::Ptr& victim)

@ -388,18 +388,21 @@ namespace
std::string_view mEffectId; std::string_view mEffectId;
}; };
osg::ref_ptr<osg::LightModel> getVFXLightModelInstance() namespace
{ {
static osg::ref_ptr<osg::LightModel> lightModel = nullptr; osg::ref_ptr<osg::LightModel> makeVFXLightModelInstance()
if (!lightModel)
{ {
lightModel = new osg::LightModel; osg::ref_ptr<osg::LightModel> lightModel = new osg::LightModel;
lightModel->setAmbientIntensity({ 1, 1, 1, 1 }); lightModel->setAmbientIntensity({ 1, 1, 1, 1 });
return lightModel;
} }
const osg::ref_ptr<osg::LightModel>& getVFXLightModelInstance()
{
static const osg::ref_ptr<osg::LightModel> lightModel = makeVFXLightModelInstance();
return lightModel; return lightModel;
} }
}
void assignBoneBlendCallbackRecursive(MWRender::BoneAnimBlendController* controller, osg::Node* parent, bool isRoot) void assignBoneBlendCallbackRecursive(MWRender::BoneAnimBlendController* controller, osg::Node* parent, bool isRoot)
{ {

@ -451,8 +451,7 @@ namespace MWWorld
} }
else if (!ESM::isEsm4Ext(worldspace)) else if (!ESM::isEsm4Ext(worldspace))
{ {
static std::vector<float> defaultHeight; static const std::vector<float> defaultHeight(verts * verts, ESM::Land::DEFAULT_HEIGHT);
defaultHeight.resize(verts * verts, ESM::Land::DEFAULT_HEIGHT);
mPhysics->addHeightField(defaultHeight.data(), cellX, cellY, worldsize, verts, mPhysics->addHeightField(defaultHeight.data(), cellX, cellY, worldsize, verts,
ESM::Land::DEFAULT_HEIGHT, ESM::Land::DEFAULT_HEIGHT, land.get()); ESM::Land::DEFAULT_HEIGHT, ESM::Land::DEFAULT_HEIGHT, land.get());
} }

@ -132,52 +132,60 @@ namespace ESM
esm.writeHNOString("DESC", mDescription); esm.writeHNOString("DESC", mDescription);
} }
short MagicEffect::getResistanceEffect(short effect) namespace
{ {
// Source https://wiki.openmw.org/index.php?title=Research:Magic#Effect_attribute std::map<short, short> makeEffectsMap()
// <Effect, Effect providing resistance against first effect>
static std::map<short, short> effects;
if (effects.empty())
{ {
effects[DisintegrateArmor] = Sanctuary; std::map<short, short> effects;
effects[DisintegrateWeapon] = Sanctuary;
for (int i = DrainAttribute; i <= DamageSkill; ++i) effects[MagicEffect::Effects::DisintegrateArmor] = MagicEffect::Effects::Sanctuary;
effects[i] = ResistMagicka; effects[MagicEffect::Effects::DisintegrateWeapon] = MagicEffect::Effects::Sanctuary;
for (int i = AbsorbAttribute; i <= AbsorbSkill; ++i)
effects[i] = ResistMagicka; for (int i = MagicEffect::Effects::DrainAttribute; i <= MagicEffect::Effects::DamageSkill; ++i)
for (int i = WeaknessToFire; i <= WeaknessToNormalWeapons; ++i) effects[i] = MagicEffect::Effects::ResistMagicka;
effects[i] = ResistMagicka; for (int i = MagicEffect::Effects::AbsorbAttribute; i <= MagicEffect::Effects::AbsorbSkill; ++i)
effects[i] = MagicEffect::Effects::ResistMagicka;
for (int i = MagicEffect::Effects::WeaknessToFire; i <= MagicEffect::Effects::WeaknessToNormalWeapons; ++i)
effects[i] = MagicEffect::Effects::ResistMagicka;
effects[Burden] = ResistMagicka; effects[MagicEffect::Effects::Burden] = MagicEffect::Effects::ResistMagicka;
effects[Charm] = ResistMagicka; effects[MagicEffect::Effects::Charm] = MagicEffect::Effects::ResistMagicka;
effects[Silence] = ResistMagicka; effects[MagicEffect::Effects::Silence] = MagicEffect::Effects::ResistMagicka;
effects[Blind] = ResistMagicka; effects[MagicEffect::Effects::Blind] = MagicEffect::Effects::ResistMagicka;
effects[Sound] = ResistMagicka; effects[MagicEffect::Effects::Sound] = MagicEffect::Effects::ResistMagicka;
for (int i = 0; i < 2; ++i) for (int i = 0; i < 2; ++i)
{ {
effects[CalmHumanoid + i] = ResistMagicka; effects[MagicEffect::Effects::CalmHumanoid + i] = MagicEffect::Effects::ResistMagicka;
effects[FrenzyHumanoid + i] = ResistMagicka; effects[MagicEffect::Effects::FrenzyHumanoid + i] = MagicEffect::Effects::ResistMagicka;
effects[DemoralizeHumanoid + i] = ResistMagicka; effects[MagicEffect::Effects::DemoralizeHumanoid + i] = MagicEffect::Effects::ResistMagicka;
effects[RallyHumanoid + i] = ResistMagicka; effects[MagicEffect::Effects::RallyHumanoid + i] = MagicEffect::Effects::ResistMagicka;
} }
effects[TurnUndead] = ResistMagicka; effects[MagicEffect::Effects::TurnUndead] = MagicEffect::Effects::ResistMagicka;
effects[MagicEffect::Effects::FireDamage] = MagicEffect::Effects::ResistFire;
effects[MagicEffect::Effects::FrostDamage] = MagicEffect::Effects::ResistFrost;
effects[MagicEffect::Effects::ShockDamage] = MagicEffect::Effects::ResistShock;
effects[MagicEffect::Effects::Vampirism] = MagicEffect::Effects::ResistCommonDisease;
effects[MagicEffect::Effects::Corprus] = MagicEffect::Effects::ResistCorprusDisease;
effects[MagicEffect::Effects::Poison] = MagicEffect::Effects::ResistPoison;
effects[MagicEffect::Effects::Paralyze] = MagicEffect::Effects::ResistParalysis;
effects[FireDamage] = ResistFire; return effects;
effects[FrostDamage] = ResistFrost; }
effects[ShockDamage] = ResistShock;
effects[Vampirism] = ResistCommonDisease;
effects[Corprus] = ResistCorprusDisease;
effects[Poison] = ResistPoison;
effects[Paralyze] = ResistParalysis;
} }
if (effects.find(effect) != effects.end()) short MagicEffect::getResistanceEffect(short effect)
return effects[effect]; {
else // Source https://wiki.openmw.org/index.php?title=Research:Magic#Effect_attribute
// <Effect, Effect providing resistance against first effect>
static const std::map<short, short> effects = makeEffectsMap();
if (const auto it = effects.find(effect); it != effects.end())
return it->second;
return -1; return -1;
} }

@ -82,6 +82,9 @@ namespace SceneUtil
std::string_view mFilter; std::string_view mFilter;
}; };
namespace
{
void mergeUserData(const osg::UserDataContainer* source, osg::Object* target) void mergeUserData(const osg::UserDataContainer* source, osg::Object* target)
{ {
if (!source) if (!source)
@ -97,6 +100,17 @@ namespace SceneUtil
} }
} }
osg::ref_ptr<osg::StateSet> makeFrontFaceStateSet()
{
osg::ref_ptr<osg::FrontFace> frontFace = new osg::FrontFace;
frontFace->setMode(osg::FrontFace::CLOCKWISE);
osg::ref_ptr<osg::StateSet> frontFaceStateSet = new osg::StateSet;
frontFaceStateSet->setAttributeAndModes(frontFace, osg::StateAttribute::ON);
return frontFaceStateSet;
}
}
osg::ref_ptr<osg::Node> attach(osg::ref_ptr<const osg::Node> toAttach, osg::Node* master, std::string_view filter, osg::ref_ptr<osg::Node> attach(osg::ref_ptr<const osg::Node> toAttach, osg::Node* master, std::string_view filter,
osg::Group* attachNode, Resource::SceneManager* sceneManager, const osg::Quat* attitude) osg::Group* attachNode, Resource::SceneManager* sceneManager, const osg::Quat* attitude)
{ {
@ -159,14 +173,8 @@ namespace SceneUtil
// Note: for absolute correctness we would need to check the current front face for every mesh then // Note: for absolute correctness we would need to check the current front face for every mesh then
// invert it However MW isn't doing this either, so don't. Assuming all meshes are using backface // invert it However MW isn't doing this either, so don't. Assuming all meshes are using backface
// culling is more efficient. // culling is more efficient.
static osg::ref_ptr<osg::StateSet> frontFaceStateSet; static const osg::ref_ptr<osg::StateSet> frontFaceStateSet = makeFrontFaceStateSet();
if (!frontFaceStateSet)
{
frontFaceStateSet = new osg::StateSet;
osg::FrontFace* frontFace = new osg::FrontFace;
frontFace->setMode(osg::FrontFace::CLOCKWISE);
frontFaceStateSet->setAttributeAndModes(frontFace, osg::StateAttribute::ON);
}
trans->setStateSet(frontFaceStateSet); trans->setStateSet(frontFaceStateSet);
} }

@ -404,6 +404,25 @@ namespace Terrain
} }
} }
namespace
{
osg::ref_ptr<osg::StateSet> makeStateSet()
{
osg::ref_ptr<osg::StateSet> stateSet = new osg::StateSet;
stateSet->setMode(GL_CULL_FACE, osg::StateAttribute::OFF);
stateSet->setMode(GL_DEPTH_TEST, osg::StateAttribute::OFF);
stateSet->setAttributeAndModes(
new osg::PolygonMode(osg::PolygonMode::FRONT_AND_BACK, osg::PolygonMode::LINE),
osg::StateAttribute::ON);
osg::ref_ptr<osg::Material> material = new osg::Material;
material->setEmission(osg::Material::FRONT_AND_BACK, osg::Vec4f(0, 0, 1, 1));
material->setDiffuse(osg::Material::FRONT_AND_BACK, osg::Vec4f(0, 0, 0, 1));
material->setAmbient(osg::Material::FRONT_AND_BACK, osg::Vec4f(0, 0, 0, 1));
stateSet->setAttributeAndModes(material, osg::StateAttribute::ON);
stateSet->setRenderBinDetails(100, "RenderBin");
return stateSet;
}
void updateWaterCullingView( void updateWaterCullingView(
HeightCullCallback* callback, ViewData* vd, osgUtil::CullVisitor* cv, float cellworldsize, bool outofworld) HeightCullCallback* callback, ViewData* vd, osgUtil::CullVisitor* cv, float cellworldsize, bool outofworld)
{ {
@ -421,8 +440,8 @@ namespace Terrain
for (unsigned int i = 0; i < vd->getNumEntries(); ++i) for (unsigned int i = 0; i < vd->getNumEntries(); ++i)
{ {
ViewDataEntry& entry = vd->getEntry(i); ViewDataEntry& entry = vd->getEntry(i);
osg::BoundingBox bb osg::BoundingBox bb = static_cast<TerrainDrawable*>(entry.mRenderingNode->asGroup()->getChild(0))
= static_cast<TerrainDrawable*>(entry.mRenderingNode->asGroup()->getChild(0))->getWaterBoundingBox(); ->getWaterBoundingBox();
if (!bb.valid()) if (!bb.valid())
continue; continue;
osg::Vec3f ofs( osg::Vec3f ofs(
@ -440,28 +459,14 @@ namespace Terrain
osg::Box* b = new osg::Box; osg::Box* b = new osg::Box;
b->set(bb.center(), bb._max - bb.center()); b->set(bb.center(), bb._max - bb.center());
osg::ShapeDrawable* drw = new osg::ShapeDrawable(b); osg::ShapeDrawable* drw = new osg::ShapeDrawable(b);
static osg::ref_ptr<osg::StateSet> stateset = nullptr; static const osg::ref_ptr<osg::StateSet> stateset = makeStateSet();
if (!stateset)
{
stateset = new osg::StateSet;
stateset->setMode(GL_CULL_FACE, osg::StateAttribute::OFF);
stateset->setMode(GL_DEPTH_TEST, osg::StateAttribute::OFF);
stateset->setAttributeAndModes(
new osg::PolygonMode(osg::PolygonMode::FRONT_AND_BACK, osg::PolygonMode::LINE),
osg::StateAttribute::ON);
osg::Material* m = new osg::Material;
m->setEmission(osg::Material::FRONT_AND_BACK, osg::Vec4f(0, 0, 1, 1));
m->setDiffuse(osg::Material::FRONT_AND_BACK, osg::Vec4f(0, 0, 0, 1));
m->setAmbient(osg::Material::FRONT_AND_BACK, osg::Vec4f(0, 0, 0, 1));
stateset->setAttributeAndModes(m, osg::StateAttribute::ON);
stateset->setRenderBinDetails(100, "RenderBin");
}
drw->setStateSet(stateset); drw->setStateSet(stateset);
drw->accept(*cv); drw->accept(*cv);
} }
callback->setLowZ(lowZ); callback->setLowZ(lowZ);
cv->popCurrentMask(); cv->popCurrentMask();
} }
}
void QuadTreeWorld::accept(osg::NodeVisitor& nv) void QuadTreeWorld::accept(osg::NodeVisitor& nv)
{ {

Loading…
Cancel
Save