From 2c68ed4fb482a1771c7c838d6d9c940c5287c4b5 Mon Sep 17 00:00:00 2001 From: scrawl Date: Mon, 6 Mar 2017 20:42:19 +0100 Subject: [PATCH] Remove no longer required use of UnrefQueue as the new resource manager will naturally clear the cache from the worker thread --- apps/openmw/mwrender/renderingmanager.cpp | 2 +- components/terrain/terraingrid.cpp | 8 +------- components/terrain/terraingrid.hpp | 9 +-------- 3 files changed, 3 insertions(+), 16 deletions(-) diff --git a/apps/openmw/mwrender/renderingmanager.cpp b/apps/openmw/mwrender/renderingmanager.cpp index 090eddd0d..534030b43 100644 --- a/apps/openmw/mwrender/renderingmanager.cpp +++ b/apps/openmw/mwrender/renderingmanager.cpp @@ -218,7 +218,7 @@ namespace MWRender Settings::Manager::getBool("auto use terrain normal maps", "Shaders"), Settings::Manager::getString("terrain specular map pattern", "Shaders"), Settings::Manager::getBool("auto use terrain specular maps", "Shaders")); mTerrain.reset(new Terrain::TerrainGrid(sceneRoot, mResourceSystem, mViewer->getIncrementalCompileOperation(), - mTerrainStorage, Mask_Terrain, &mResourceSystem->getSceneManager()->getShaderManager(), mUnrefQueue.get())); + mTerrainStorage, Mask_Terrain, &mResourceSystem->getSceneManager()->getShaderManager())); mCamera.reset(new Camera(mViewer->getCamera())); diff --git a/components/terrain/terraingrid.cpp b/components/terrain/terraingrid.cpp index fa7b93684..966f161f2 100644 --- a/components/terrain/terraingrid.cpp +++ b/components/terrain/terraingrid.cpp @@ -5,18 +5,15 @@ #include #include -#include - #include "texturemanager.hpp" #include "chunkmanager.hpp" namespace Terrain { -TerrainGrid::TerrainGrid(osg::Group* parent, Resource::ResourceSystem* resourceSystem, osgUtil::IncrementalCompileOperation* ico, Storage* storage, int nodeMask, Shader::ShaderManager* shaderManager, SceneUtil::UnrefQueue* unrefQueue) +TerrainGrid::TerrainGrid(osg::Group* parent, Resource::ResourceSystem* resourceSystem, osgUtil::IncrementalCompileOperation* ico, Storage* storage, int nodeMask, Shader::ShaderManager* shaderManager) : Terrain::World(parent, resourceSystem, ico, storage, nodeMask) , mNumSplits(4) - , mUnrefQueue(unrefQueue) , mShaderManager(shaderManager) { osg::ref_ptr material (new osg::Material); @@ -92,9 +89,6 @@ void TerrainGrid::unloadCell(int x, int y) osg::ref_ptr terrainNode = it->second; mTerrainRoot->removeChild(terrainNode); - if (mUnrefQueue.get()) - mUnrefQueue->push(terrainNode); - mGrid.erase(it); } diff --git a/components/terrain/terraingrid.hpp b/components/terrain/terraingrid.hpp index 59d93dc6f..0a9647bd5 100644 --- a/components/terrain/terraingrid.hpp +++ b/components/terrain/terraingrid.hpp @@ -7,11 +7,6 @@ #include "world.hpp" -namespace SceneUtil -{ - class UnrefQueue; -} - namespace Shader { class ShaderManager; @@ -29,7 +24,7 @@ namespace Terrain class TerrainGrid : public Terrain::World { public: - TerrainGrid(osg::Group* parent, Resource::ResourceSystem* resourceSystem, osgUtil::IncrementalCompileOperation* ico, Storage* storage, int nodeMask, Shader::ShaderManager* shaderManager = NULL, SceneUtil::UnrefQueue* unrefQueue = NULL); + TerrainGrid(osg::Group* parent, Resource::ResourceSystem* resourceSystem, osgUtil::IncrementalCompileOperation* ico, Storage* storage, int nodeMask, Shader::ShaderManager* shaderManager = NULL); ~TerrainGrid(); /// Load a terrain cell and store it in cache for later use. @@ -56,8 +51,6 @@ namespace Terrain typedef std::map, osg::ref_ptr > Grid; Grid mGrid; - osg::ref_ptr mUnrefQueue; - Shader::ShaderManager* mShaderManager; };