summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Meeks <michael.meeks@collabora.com>2017-12-15 14:22:10 +0000
committerpranavk <pranavk@collabora.co.uk>2017-12-15 21:06:07 +0100
commitd93718ff92e485ebcd014713574be596b8815ff8 (patch)
treedf5f5d135e3fb721a59c2ae8ce3b949d8f715ccc
parentcf54640727c9b58856e9abf15c0ac82d876262b6 (diff)
Handle resmgr lifecycle with vcl's de-init more cleanly.
Change-Id: Iee5f54edc09d0df7062ffdcb301876fcec791373 Reviewed-on: https://gerrit.libreoffice.org/46562 Reviewed-by: pranavk <pranavk@collabora.co.uk> Tested-by: pranavk <pranavk@collabora.co.uk>
-rw-r--r--cui/source/factory/cuiresmgr.cxx5
-rw-r--r--sfx2/source/bastyp/sfxresid.cxx5
-rw-r--r--svtools/source/misc/svtresid.cxx5
-rw-r--r--tools/source/rc/resmgr.cxx4
4 files changed, 9 insertions, 10 deletions
diff --git a/cui/source/factory/cuiresmgr.cxx b/cui/source/factory/cuiresmgr.cxx
index e61da43b6710..48e942a90685 100644
--- a/cui/source/factory/cuiresmgr.cxx
+++ b/cui/source/factory/cuiresmgr.cxx
@@ -21,15 +21,16 @@
#include <svl/solar.hrc>
#include <vcl/svapp.hxx>
#include <vcl/settings.hxx>
+#include <vcl/lazydelete.hxx>
// struct DialogsResMgr --------------------------------------------------
ResMgr* CuiResMgr::GetResMgr()
{
- static std::unique_ptr<ResMgr> pResMgr;
+ static vcl::DeleteOnDeinit<ResMgr> pResMgr(nullptr);
const LanguageTag& rLocale = Application::GetSettings().GetUILanguageTag();
- if (!pResMgr || pResMgr->GetLocale() != rLocale)
+ if (!pResMgr.get() || pResMgr.get()->GetLocale() != rLocale)
{
pResMgr.reset(ResMgr::CreateResMgr("cui", rLocale));
}
diff --git a/sfx2/source/bastyp/sfxresid.cxx b/sfx2/source/bastyp/sfxresid.cxx
index 40f02c4c3caa..a90d67adee41 100644
--- a/sfx2/source/bastyp/sfxresid.cxx
+++ b/sfx2/source/bastyp/sfxresid.cxx
@@ -21,8 +21,9 @@
#include <vcl/svapp.hxx>
#include <vcl/settings.hxx>
#include <tools/resmgr.hxx>
+#include <vcl/lazydelete.hxx>
-static std::unique_ptr<ResMgr> pMgr;
+static vcl::DeleteOnDeinit<ResMgr> pMgr(nullptr);
SfxResId::SfxResId( sal_uInt16 nId ) :
ResId( nId, *GetResMgr() )
@@ -33,7 +34,7 @@ ResMgr* SfxResId::GetResMgr()
{
const LanguageTag& rLocale = Application::GetSettings().GetUILanguageTag();
- if (!pMgr || pMgr->GetLocale() != rLocale)
+ if (!pMgr.get() || pMgr.get()->GetLocale() != rLocale)
pMgr.reset(ResMgr::CreateResMgr("sfx", rLocale));
return pMgr.get();
diff --git a/svtools/source/misc/svtresid.cxx b/svtools/source/misc/svtresid.cxx
index e727d95ce461..fa7261f6979e 100644
--- a/svtools/source/misc/svtresid.cxx
+++ b/svtools/source/misc/svtresid.cxx
@@ -21,14 +21,15 @@
#include <svtools/svtresid.hxx>
#include <vcl/svapp.hxx>
#include <vcl/settings.hxx>
+#include <vcl/lazydelete.hxx>
-static std::unique_ptr<ResMgr> pMgr;
+static vcl::DeleteOnDeinit<ResMgr> pMgr(nullptr);
namespace
{
ResMgr* getResMgr(const LanguageTag& aLocale)
{
- if (!pMgr || pMgr->GetLocale() != aLocale)
+ if (!pMgr.get() || pMgr.get()->GetLocale() != aLocale)
pMgr.reset(ResMgr::CreateResMgr("svt", aLocale));
return pMgr.get();
diff --git a/tools/source/rc/resmgr.cxx b/tools/source/rc/resmgr.cxx
index daea1b5bde64..31c4765f0304 100644
--- a/tools/source/rc/resmgr.cxx
+++ b/tools/source/rc/resmgr.cxx
@@ -838,10 +838,6 @@ ResMgr::ResMgr( InternalResMgr * pImpMgr )
ResMgr::~ResMgr()
{
- // our container was freed by DestroyAllResMgr
- if (!pResMgrMutex)
- return;
-
osl::Guard<osl::Mutex> aGuard( getResMgrMutex() );
ResMgrContainer::get().freeResMgr( pImpRes );