From 1c15686353060c89e3e5518b49fabd4d757fb3ee Mon Sep 17 00:00:00 2001 From: scrawl Date: Thu, 9 Mar 2017 04:01:27 +0100 Subject: [PATCH] Remove non required use of WorkQueue --- apps/openmw/mwrender/renderingmanager.cpp | 2 +- components/terrain/quadtreeworld.cpp | 46 ++++++++--------------- components/terrain/quadtreeworld.hpp | 12 +----- 3 files changed, 17 insertions(+), 43 deletions(-) diff --git a/apps/openmw/mwrender/renderingmanager.cpp b/apps/openmw/mwrender/renderingmanager.cpp index 40403a4fb6..a41adc2fcc 100644 --- a/apps/openmw/mwrender/renderingmanager.cpp +++ b/apps/openmw/mwrender/renderingmanager.cpp @@ -219,7 +219,7 @@ namespace MWRender Settings::Manager::getBool("auto use terrain specular maps", "Shaders")); if (distantTerrain) - mTerrain.reset(new Terrain::QuadTreeWorld(mWorkQueue.get(), sceneRoot, mRootNode, mResourceSystem, mTerrainStorage, Mask_Terrain, Mask_PreCompile)); + mTerrain.reset(new Terrain::QuadTreeWorld(sceneRoot, mRootNode, mResourceSystem, mTerrainStorage, Mask_Terrain, Mask_PreCompile)); else mTerrain.reset(new Terrain::TerrainGrid(sceneRoot, mRootNode, mResourceSystem, mTerrainStorage, Mask_Terrain, Mask_PreCompile)); diff --git a/components/terrain/quadtreeworld.cpp b/components/terrain/quadtreeworld.cpp index 66748a4aa1..e91a513cb5 100644 --- a/components/terrain/quadtreeworld.cpp +++ b/components/terrain/quadtreeworld.cpp @@ -2,8 +2,6 @@ #include -#include - #include "quadtreenode.hpp" #include "storage.hpp" #include "viewdata.hpp" @@ -109,10 +107,10 @@ private: QuadTreeWorld* mWorld; }; -class BuildQuadTreeItem : public SceneUtil::WorkItem +class QuadTreeBuilder { public: - BuildQuadTreeItem(Terrain::Storage* storage, ViewDataMap* viewDataMap, float minSize) + QuadTreeBuilder(Terrain::Storage* storage, ViewDataMap* viewDataMap, float minSize) : mStorage(storage) , mMinX(0.f), mMaxX(0.f), mMinY(0.f), mMaxY(0.f) , mMinSize(minSize) @@ -120,7 +118,7 @@ public: { } - virtual void doWork() + void build() { mStorage->getBounds(mMinX, mMaxX, mMinY, mMaxY); @@ -226,9 +224,8 @@ private: osg::ref_ptr mRootNode; }; -QuadTreeWorld::QuadTreeWorld(SceneUtil::WorkQueue* workQueue, osg::Group *parent, osg::Group *compileRoot, Resource::ResourceSystem *resourceSystem, Storage *storage, int nodeMask, int preCompileMask) +QuadTreeWorld::QuadTreeWorld(osg::Group *parent, osg::Group *compileRoot, Resource::ResourceSystem *resourceSystem, Storage *storage, int nodeMask, int preCompileMask) : World(parent, compileRoot, resourceSystem, storage, nodeMask, preCompileMask) - , mWorkQueue(workQueue) , mViewDataMap(new ViewDataMap) , mQuadTreeBuilt(false) { @@ -236,12 +233,7 @@ QuadTreeWorld::QuadTreeWorld(SceneUtil::WorkQueue* workQueue, osg::Group *parent QuadTreeWorld::~QuadTreeWorld() { - if (mWorkItem) - { - mWorkItem->abort(); - mWorkItem->waitTillDone(); - } - + ensureQuadTreeBuilt(); mViewDataMap->clear(); } @@ -339,25 +331,17 @@ void QuadTreeWorld::accept(osg::NodeVisitor &nv) void QuadTreeWorld::ensureQuadTreeBuilt() { - { - OpenThreads::ScopedLock lock(mQuadTreeMutex); - if (mQuadTreeBuilt) - return; - if (!mQuadTreeBuilt && !mWorkItem) - { - const float minSize = 1/4.f; - mWorkItem = new BuildQuadTreeItem(mStorage, mViewDataMap.get(), minSize); - mWorkQueue->addWorkItem(mWorkItem); - } - } + OpenThreads::ScopedLock lock(mQuadTreeMutex); + if (mQuadTreeBuilt) + return; - mWorkItem->waitTillDone(); - { - OpenThreads::ScopedLock lock(mQuadTreeMutex); - mRootNode = mWorkItem->getRootNode(); - mRootNode->setWorld(this); - mQuadTreeBuilt = true; - } + const float minSize = 1/4.f; + QuadTreeBuilder builder(mStorage, mViewDataMap.get(), minSize); + builder.build(); + + mRootNode = builder.getRootNode(); + mRootNode->setWorld(this); + mQuadTreeBuilt = true; } void QuadTreeWorld::enable(bool enabled) diff --git a/components/terrain/quadtreeworld.hpp b/components/terrain/quadtreeworld.hpp index f66426ed24..5838bcaa94 100644 --- a/components/terrain/quadtreeworld.hpp +++ b/components/terrain/quadtreeworld.hpp @@ -7,11 +7,6 @@ #include -namespace SceneUtil -{ - class WorkQueue; -} - namespace osg { class NodeVisitor; @@ -20,14 +15,13 @@ namespace osg namespace Terrain { class RootNode; - class BuildQuadTreeItem; class ViewDataMap; /// @brief Terrain implementation that loads cells into a Quad Tree, with geometry LOD and texture LOD. The entire world is displayed at all times. class QuadTreeWorld : public Terrain::World { public: - QuadTreeWorld(SceneUtil::WorkQueue* workQueue, osg::Group* parent, osg::Group* compileRoot, Resource::ResourceSystem* resourceSystem, Storage* storage, int nodeMask, int preCompileMask=~0); + QuadTreeWorld(osg::Group* parent, osg::Group* compileRoot, Resource::ResourceSystem* resourceSystem, Storage* storage, int nodeMask, int preCompileMask=~0); ~QuadTreeWorld(); void accept(osg::NodeVisitor& nv); @@ -39,10 +33,6 @@ namespace Terrain osg::ref_ptr mRootNode; - osg::ref_ptr mWorkQueue; - - osg::ref_ptr mWorkItem; - osg::ref_ptr mViewDataMap; OpenThreads::Mutex mQuadTreeMutex;