From af7cbb2e3ba0828322f9c654987d30165f6b9004 Mon Sep 17 00:00:00 2001 From: scrawl Date: Fri, 8 May 2015 17:52:35 +0200 Subject: [PATCH] Leak fix --- components/resource/resourcesystem.cpp | 5 +++++ components/resource/resourcesystem.hpp | 4 ++++ components/resource/scenemanager.cpp | 5 +++++ components/resource/scenemanager.hpp | 4 ++++ components/resource/texturemanager.cpp | 5 +++++ components/resource/texturemanager.hpp | 4 ++++ 6 files changed, 27 insertions(+) diff --git a/components/resource/resourcesystem.cpp b/components/resource/resourcesystem.cpp index acde8f5d2..bd6824079 100644 --- a/components/resource/resourcesystem.cpp +++ b/components/resource/resourcesystem.cpp @@ -13,6 +13,11 @@ namespace Resource mSceneManager.reset(new SceneManager(vfs, mTextureManager.get())); } + ResourceSystem::~ResourceSystem() + { + // this has to be defined in the .cpp file as we can't delete incomplete types + } + SceneManager* ResourceSystem::getSceneManager() { return mSceneManager.get(); diff --git a/components/resource/resourcesystem.hpp b/components/resource/resourcesystem.hpp index 3bb454785..7c00a11ee 100644 --- a/components/resource/resourcesystem.hpp +++ b/components/resource/resourcesystem.hpp @@ -21,6 +21,7 @@ namespace Resource { public: ResourceSystem(const VFS::Manager* vfs); + ~ResourceSystem(); SceneManager* getSceneManager(); TextureManager* getTextureManager(); @@ -32,6 +33,9 @@ namespace Resource std::auto_ptr mTextureManager; const VFS::Manager* mVFS; + + ResourceSystem(const ResourceSystem&); + void operator = (const ResourceSystem&); }; } diff --git a/components/resource/scenemanager.cpp b/components/resource/scenemanager.cpp index 393f322d7..8a0d526fa 100644 --- a/components/resource/scenemanager.cpp +++ b/components/resource/scenemanager.cpp @@ -70,6 +70,11 @@ namespace Resource { } + SceneManager::~SceneManager() + { + // this has to be defined in the .cpp file as we can't delete incomplete types + } + osg::ref_ptr SceneManager::getTemplate(const std::string &name) { std::string normalized = name; diff --git a/components/resource/scenemanager.hpp b/components/resource/scenemanager.hpp index 6a52dfb21..9f3c5387e 100644 --- a/components/resource/scenemanager.hpp +++ b/components/resource/scenemanager.hpp @@ -32,6 +32,7 @@ namespace Resource { public: SceneManager(const VFS::Manager* vfs, Resource::TextureManager* textureManager); + ~SceneManager(); /// Get a read-only copy of this scene "template" osg::ref_ptr getTemplate(const std::string& name); @@ -69,6 +70,9 @@ namespace Resource typedef std::map > KeyframeIndex; KeyframeIndex mKeyframeIndex; + + SceneManager(const SceneManager&); + void operator = (const SceneManager&); }; } diff --git a/components/resource/texturemanager.cpp b/components/resource/texturemanager.cpp index ee75296a7..b9b9fad5f 100644 --- a/components/resource/texturemanager.cpp +++ b/components/resource/texturemanager.cpp @@ -42,6 +42,11 @@ namespace Resource } + TextureManager::~TextureManager() + { + + } + void TextureManager::setUnRefImageDataAfterApply(bool unref) { mUnRefImageDataAfterApply = unref; diff --git a/components/resource/texturemanager.hpp b/components/resource/texturemanager.hpp index d44d47d24..851a55166 100644 --- a/components/resource/texturemanager.hpp +++ b/components/resource/texturemanager.hpp @@ -21,6 +21,7 @@ namespace Resource { public: TextureManager(const VFS::Manager* vfs); + ~TextureManager(); // TODO: texture filtering settings @@ -48,6 +49,9 @@ namespace Resource osg::ref_ptr mWarningTexture; bool mUnRefImageDataAfterApply; + + TextureManager(const TextureManager&); + void operator = (const TextureManager&); }; }