From afa769408aa8f4253b94e851accb6785f76149cc Mon Sep 17 00:00:00 2001 From: elsid Date: Sat, 19 Oct 2024 14:07:47 +0200 Subject: [PATCH] Use normalized path for correctActorModelPath --- apps/navmeshtool/worldspacedata.cpp | 2 +- apps/opencs/view/render/actor.cpp | 2 +- apps/openmw/mwphysics/physicssystem.cpp | 5 ++--- apps/openmw/mwrender/animation.cpp | 3 ++- apps/openmw/mwrender/npcanimation.cpp | 5 +++-- apps/openmw/mwrender/objects.cpp | 6 ++++-- apps/openmw/mwscript/miscextensions.cpp | 4 ++-- apps/openmw/mwworld/scene.cpp | 5 +++-- components/misc/resourcehelpers.cpp | 21 +++++++++++---------- components/misc/resourcehelpers.hpp | 2 +- 10 files changed, 30 insertions(+), 25 deletions(-) diff --git a/apps/navmeshtool/worldspacedata.cpp b/apps/navmeshtool/worldspacedata.cpp index 077b43f72f..1e44e65b8b 100644 --- a/apps/navmeshtool/worldspacedata.cpp +++ b/apps/navmeshtool/worldspacedata.cpp @@ -121,7 +121,7 @@ namespace NavMeshTool for (CellRef& cellRef : cellRefs) { - std::string model(getModel(esmData, cellRef.mRefId, cellRef.mType)); + VFS::Path::Normalized model(getModel(esmData, cellRef.mRefId, cellRef.mType)); if (model.empty()) continue; diff --git a/apps/opencs/view/render/actor.cpp b/apps/opencs/view/render/actor.cpp index 1b1e4dfcaa..43ac25461e 100644 --- a/apps/opencs/view/render/actor.cpp +++ b/apps/opencs/view/render/actor.cpp @@ -47,7 +47,7 @@ namespace CSVRender mBaseNode->removeChildren(0, mBaseNode->getNumChildren()); // Load skeleton - std::string skeletonModel = mActorData->getSkeleton(); + VFS::Path::Normalized skeletonModel = mActorData->getSkeleton(); skeletonModel = Misc::ResourceHelpers::correctActorModelPath(skeletonModel, mData.getResourceSystem()->getVFS()); loadSkeleton(skeletonModel); diff --git a/apps/openmw/mwphysics/physicssystem.cpp b/apps/openmw/mwphysics/physicssystem.cpp index 83ffb9d701..77ea0fe7da 100644 --- a/apps/openmw/mwphysics/physicssystem.cpp +++ b/apps/openmw/mwphysics/physicssystem.cpp @@ -413,8 +413,7 @@ namespace MWPhysics return; const VFS::Path::Normalized animationMesh = ptr.getClass().useAnim() - ? VFS::Path::toNormalized( - Misc::ResourceHelpers::correctActorModelPath(mesh.value(), mResourceSystem->getVFS())) + ? Misc::ResourceHelpers::correctActorModelPath(mesh, mResourceSystem->getVFS()) : VFS::Path::Normalized(mesh); osg::ref_ptr shapeInstance = mShapeManager->getInstance(animationMesh); if (!shapeInstance || !shapeInstance->mCollisionShape) @@ -564,7 +563,7 @@ namespace MWPhysics void PhysicsSystem::addActor(const MWWorld::Ptr& ptr, VFS::Path::NormalizedView mesh) { const VFS::Path::Normalized animationMesh - = Misc::ResourceHelpers::correctActorModelPath(mesh.value(), mResourceSystem->getVFS()); + = Misc::ResourceHelpers::correctActorModelPath(mesh, mResourceSystem->getVFS()); osg::ref_ptr shape = mShapeManager->getShape(animationMesh); // Try to get shape from basic model as fallback for creatures diff --git a/apps/openmw/mwrender/animation.cpp b/apps/openmw/mwrender/animation.cpp index 80ba39c465..5779a4f709 100644 --- a/apps/openmw/mwrender/animation.cpp +++ b/apps/openmw/mwrender/animation.cpp @@ -1625,7 +1625,8 @@ namespace MWRender const bool werewolf = false; defaultSkeleton = Misc::ResourceHelpers::correctActorModelPath( - getActorSkeleton(firstPerson, isFemale, isBeast, werewolf), mResourceSystem->getVFS()); + VFS::Path::toNormalized(getActorSkeleton(firstPerson, isFemale, isBeast, werewolf)), + mResourceSystem->getVFS()); } } } diff --git a/apps/openmw/mwrender/npcanimation.cpp b/apps/openmw/mwrender/npcanimation.cpp index d6fdad4082..58bd3734ee 100644 --- a/apps/openmw/mwrender/npcanimation.cpp +++ b/apps/openmw/mwrender/npcanimation.cpp @@ -494,13 +494,14 @@ namespace MWRender } const std::string defaultSkeleton = Misc::ResourceHelpers::correctActorModelPath( - getActorSkeleton(is1stPerson, isFemale, isBeast, isWerewolf), mResourceSystem->getVFS()); + VFS::Path::toNormalized(getActorSkeleton(is1stPerson, isFemale, isBeast, isWerewolf)), + mResourceSystem->getVFS()); std::string smodel = defaultSkeleton; bool isCustomModel = false; if (!is1stPerson && !isWerewolf && !mNpc->mModel.empty()) { - std::string model = Misc::ResourceHelpers::correctMeshPath(mNpc->mModel); + VFS::Path::Normalized model = Misc::ResourceHelpers::correctMeshPath(mNpc->mModel); isCustomModel = !isDefaultActorSkeleton(model); smodel = Misc::ResourceHelpers::correctActorModelPath(model, mResourceSystem->getVFS()); } diff --git a/apps/openmw/mwrender/objects.cpp b/apps/openmw/mwrender/objects.cpp index d93dc47641..9393846d7a 100644 --- a/apps/openmw/mwrender/objects.cpp +++ b/apps/openmw/mwrender/objects.cpp @@ -79,7 +79,8 @@ namespace MWRender std::string animationMesh = mesh; if (animated && !mesh.empty()) { - animationMesh = Misc::ResourceHelpers::correctActorModelPath(mesh, mResourceSystem->getVFS()); + animationMesh = Misc::ResourceHelpers::correctActorModelPath( + VFS::Path::toNormalized(mesh), mResourceSystem->getVFS()); if (animationMesh == mesh && Misc::StringUtils::ciEndsWith(animationMesh, ".nif")) animated = false; } @@ -96,7 +97,8 @@ namespace MWRender ptr.getRefData().getBaseNode()->setNodeMask(Mask_Actor); bool animated = true; - std::string animationMesh = Misc::ResourceHelpers::correctActorModelPath(mesh, mResourceSystem->getVFS()); + std::string animationMesh + = Misc::ResourceHelpers::correctActorModelPath(VFS::Path::toNormalized(mesh), mResourceSystem->getVFS()); if (animationMesh == mesh && Misc::StringUtils::ciEndsWith(animationMesh, ".nif")) animated = false; diff --git a/apps/openmw/mwscript/miscextensions.cpp b/apps/openmw/mwscript/miscextensions.cpp index c808cc2518..5d5f6be529 100644 --- a/apps/openmw/mwscript/miscextensions.cpp +++ b/apps/openmw/mwscript/miscextensions.cpp @@ -1437,8 +1437,8 @@ namespace MWScript osg::Vec3f pos(ptr.getRefData().getPosition().asVec3()); msg << "Coordinates: " << pos.x() << " " << pos.y() << " " << pos.z() << std::endl; auto vfs = MWBase::Environment::get().getResourceSystem()->getVFS(); - const VFS::Path::Normalized model( - ::Misc::ResourceHelpers::correctActorModelPath(ptr.getClass().getCorrectedModel(ptr), vfs)); + const VFS::Path::Normalized model = ::Misc::ResourceHelpers::correctActorModelPath( + VFS::Path::toNormalized(ptr.getClass().getCorrectedModel(ptr)), vfs); msg << "Model: " << model.value() << std::endl; if (!model.empty()) { diff --git a/apps/openmw/mwworld/scene.cpp b/apps/openmw/mwworld/scene.cpp index b95777ec76..275e152b29 100644 --- a/apps/openmw/mwworld/scene.cpp +++ b/apps/openmw/mwworld/scene.cpp @@ -1126,8 +1126,9 @@ namespace MWWorld void Scene::preload(const std::string& mesh, bool useAnim) { const VFS::Path::Normalized meshPath = useAnim - ? Misc::ResourceHelpers::correctActorModelPath(mesh, mRendering.getResourceSystem()->getVFS()) - : mesh; + ? Misc::ResourceHelpers::correctActorModelPath( + VFS::Path::toNormalized(mesh), mRendering.getResourceSystem()->getVFS()) + : VFS::Path::toNormalized(mesh); if (mRendering.getResourceSystem()->getSceneManager()->checkLoaded(meshPath, mRendering.getReferenceTime())) return; diff --git a/components/misc/resourcehelpers.cpp b/components/misc/resourcehelpers.cpp index 90cdcdb726..c3413b10e8 100644 --- a/components/misc/resourcehelpers.cpp +++ b/components/misc/resourcehelpers.cpp @@ -142,22 +142,23 @@ std::string Misc::ResourceHelpers::correctBookartPath( return image; } -std::string Misc::ResourceHelpers::correctActorModelPath(std::string_view resPath, const VFS::Manager* vfs) +VFS::Path::Normalized Misc::ResourceHelpers::correctActorModelPath( + VFS::Path::NormalizedView resPath, const VFS::Manager* vfs) { - std::string mdlname(resPath); - std::string::size_type p = mdlname.find_last_of("/\\"); + std::string mdlname(resPath.value()); + std::string::size_type p = mdlname.find_last_of('/'); if (p != std::string::npos) - mdlname.insert(mdlname.begin() + p + 1, 'x'); + mdlname.insert(mdlname.begin() + static_cast(p) + 1, 'x'); else mdlname.insert(mdlname.begin(), 'x'); - std::string kfname = mdlname; - if (Misc::StringUtils::ciEndsWith(kfname, ".nif")) - kfname.replace(kfname.size() - 4, 4, ".kf"); + + VFS::Path::Normalized kfname(mdlname); + if (Misc::getFileExtension(mdlname) == "nif") + kfname.changeExtension("kf"); if (!vfs->exists(kfname)) - { - return std::string(resPath); - } + return VFS::Path::Normalized(resPath); + return mdlname; } diff --git a/components/misc/resourcehelpers.hpp b/components/misc/resourcehelpers.hpp index f97e865770..f66fc415a6 100644 --- a/components/misc/resourcehelpers.hpp +++ b/components/misc/resourcehelpers.hpp @@ -33,7 +33,7 @@ namespace Misc std::string correctBookartPath(std::string_view resPath, int width, int height, const VFS::Manager* vfs); /// Use "xfoo.nif" instead of "foo.nif" if "xfoo.kf" is available /// Note that if "xfoo.nif" is actually unavailable, we can't fall back to "foo.nif". :( - std::string correctActorModelPath(std::string_view resPath, const VFS::Manager* vfs); + VFS::Path::Normalized correctActorModelPath(VFS::Path::NormalizedView resPath, const VFS::Manager* vfs); std::string correctMaterialPath(std::string_view resPath, const VFS::Manager* vfs); // Adds "meshes\\".