summaryrefslogtreecommitdiff
path: root/framework
diff options
context:
space:
mode:
authorStephan Bergmann <sbergman@redhat.com>2014-03-20 15:14:42 +0100
committerStephan Bergmann <sbergman@redhat.com>2014-03-20 15:15:10 +0100
commitc641f300f09ec0e520846b09e12bf8041299a6cf (patch)
treef820852cfba364390b0e622b4dc8416327fd6485 /framework
parente0d936ef7b7fd6b57cdd5ccadddcbd84bd4bb359 (diff)
Use an osl::Mutex directly
Change-Id: If8ff4fc256e530f6b79cc97cf1f47880c93864bf
Diffstat (limited to 'framework')
-rw-r--r--framework/source/accelerators/storageholder.cxx84
-rw-r--r--framework/source/inc/accelerators/storageholder.hxx4
2 files changed, 24 insertions, 64 deletions
diff --git a/framework/source/accelerators/storageholder.cxx b/framework/source/accelerators/storageholder.cxx
index 05227705618d..b19d3e0c3a32 100644
--- a/framework/source/accelerators/storageholder.cxx
+++ b/framework/source/accelerators/storageholder.cxx
@@ -19,7 +19,6 @@
#include <accelerators/storageholder.hxx>
-#include <threadhelp/guard.hxx>
#include <services.h>
#include <com/sun/star/container/NoSuchElementException.hpp>
@@ -49,7 +48,6 @@ namespace framework
StorageHolder::StorageHolder()
- : ThreadHelpBase( )
{
}
@@ -63,9 +61,7 @@ StorageHolder::~StorageHolder()
void StorageHolder::forgetCachedStorages()
{
- // SAFE -> ----------------------------------
- Guard aWriteLock(m_aLock);
-
+ osl::MutexGuard g(m_mutex);
TPath2StorageInfo::iterator pIt;
for ( pIt = m_lStorages.begin();
pIt != m_lStorages.end() ;
@@ -76,28 +72,20 @@ void StorageHolder::forgetCachedStorages()
rInfo.Storage.clear();
}
m_lStorages.clear();
-
- aWriteLock.unlock();
- // <- SAFE ----------------------------------
}
void StorageHolder::setRootStorage(const css::uno::Reference< css::embed::XStorage >& xRoot)
{
- // SAFE -> ----------------------------------
- Guard aWriteLock(m_aLock);
+ osl::MutexGuard g(m_mutex);
m_xRoot = xRoot;
- aWriteLock.unlock();
- // <- SAFE ----------------------------------
}
css::uno::Reference< css::embed::XStorage > StorageHolder::getRootStorage() const
{
- // SAFE -> ----------------------------------
- Guard aReadLock(m_aLock);
+ osl::MutexGuard g(m_mutex);
return m_xRoot;
- // <- SAFE ----------------------------------
}
@@ -108,9 +96,9 @@ css::uno::Reference< css::embed::XStorage > StorageHolder::openPath(const OUStri
OUStringList lFolders = StorageHolder::impl_st_parsePath(sNormedPath);
// SAFE -> ----------------------------------
- Guard aReadLock(m_aLock);
+ osl::ResettableMutexGuard aReadLock(m_mutex);
css::uno::Reference< css::embed::XStorage > xParent = m_xRoot;
- aReadLock.unlock();
+ aReadLock.clear();
// <- SAFE ----------------------------------
css::uno::Reference< css::embed::XStorage > xChild ;
@@ -127,7 +115,7 @@ css::uno::Reference< css::embed::XStorage > StorageHolder::openPath(const OUStri
sCheckPath += PATH_SEPARATOR;
// SAFE -> ------------------------------
- aReadLock.lock();
+ aReadLock.reset();
// If we found an already open storage ... we must increase
// its use count. Otherwhise it will may be closed to early :-)
@@ -138,10 +126,13 @@ css::uno::Reference< css::embed::XStorage > StorageHolder::openPath(const OUStri
pInfo = &(pCheck->second);
++(pInfo->UseCount);
xChild = pInfo->Storage;
+
+ aReadLock.clear();
+ // <- SAFE ------------------------------
}
else
{
- aReadLock.unlock();
+ aReadLock.clear();
// <- SAFE ------------------------------
try
@@ -165,13 +156,10 @@ css::uno::Reference< css::embed::XStorage > StorageHolder::openPath(const OUStri
throw;
}
- // SAFE -> ------------------------------
- Guard aWriteLock(m_aLock);
+ osl::MutexGuard g(m_mutex);
pInfo = &(m_lStorages[sCheckPath]);
pInfo->Storage = xChild;
pInfo->UseCount = 1;
- aWriteLock.unlock();
- // <- SAFE ------------------------------
}
xParent = xChild;
@@ -195,8 +183,7 @@ StorageHolder::TStorageList StorageHolder::getAllPathStorages(const OUString& sP
OUString sRelPath ;
OUStringList::const_iterator pIt ;
- // SAFE -> ----------------------------------
- Guard aReadLock(m_aLock);
+ osl::MutexGuard g(m_mutex);
for ( pIt = lFolders.begin();
pIt != lFolders.end() ;
@@ -223,9 +210,6 @@ StorageHolder::TStorageList StorageHolder::getAllPathStorages(const OUString& sP
sRelPath += PATH_SEPARATOR;
}
- aReadLock.unlock();
- // <- SAFE ----------------------------------
-
return lStoragesOfPath;
}
@@ -247,9 +231,9 @@ void StorageHolder::commitPath(const OUString& sPath)
}
// SAFE -> ------------------------------
- Guard aReadLock(m_aLock);
+ osl::ClearableMutexGuard aReadLock(m_mutex);
xCommit = css::uno::Reference< css::embed::XTransactedObject >(m_xRoot, css::uno::UNO_QUERY);
- aReadLock.unlock();
+ aReadLock.clear();
// <- SAFE ------------------------------
if (xCommit.is())
@@ -280,8 +264,7 @@ void StorageHolder::closePath(const OUString& rPath)
sParentPath = sCurrentRelPath;
}
- // SAFE -> ------------------------------
- Guard aReadLock(m_aLock);
+ osl::MutexGuard g(m_mutex);
OUStringList::reverse_iterator pIt2;
for ( pIt2 = lFolders.rbegin();
@@ -301,9 +284,6 @@ void StorageHolder::closePath(const OUString& rPath)
m_lStorages.erase(pPath);
}
}
-
- aReadLock.unlock();
- // <- SAFE ------------------------------
}
@@ -311,8 +291,7 @@ void StorageHolder::notifyPath(const OUString& sPath)
{
OUString sNormedPath = StorageHolder::impl_st_normPath(sPath);
- // SAFE -> ------------------------------
- Guard aReadLock(m_aLock);
+ osl::MutexGuard g(m_mutex);
TPath2StorageInfo::iterator pIt1 = m_lStorages.find(sNormedPath);
if (pIt1 == m_lStorages.end())
@@ -328,9 +307,6 @@ void StorageHolder::notifyPath(const OUString& sPath)
if (pListener)
pListener->changesOccurred(sNormedPath);
}
-
- aReadLock.unlock();
- // <- SAFE ------------------------------
}
@@ -339,8 +315,7 @@ void StorageHolder::addStorageListener( IStorageListener* pListener,
{
OUString sNormedPath = StorageHolder::impl_st_normPath(sPath);
- // SAFE -> ------------------------------
- Guard aReadLock(m_aLock);
+ osl::MutexGuard g(m_mutex);
TPath2StorageInfo::iterator pIt1 = m_lStorages.find(sNormedPath);
if (pIt1 == m_lStorages.end())
@@ -350,9 +325,6 @@ void StorageHolder::addStorageListener( IStorageListener* pListener,
TStorageListenerList::iterator pIt2 = ::std::find(rInfo.Listener.begin(), rInfo.Listener.end(), pListener);
if (pIt2 == rInfo.Listener.end())
rInfo.Listener.push_back(pListener);
-
- aReadLock.unlock();
- // <- SAFE ------------------------------
}
@@ -361,8 +333,7 @@ void StorageHolder::removeStorageListener( IStorageListener* pListener,
{
OUString sNormedPath = StorageHolder::impl_st_normPath(sPath);
- // SAFE -> ------------------------------
- Guard aReadLock(m_aLock);
+ osl::MutexGuard g(m_mutex);
TPath2StorageInfo::iterator pIt1 = m_lStorages.find(sNormedPath);
if (pIt1 == m_lStorages.end())
@@ -372,16 +343,12 @@ void StorageHolder::removeStorageListener( IStorageListener* pListener,
TStorageListenerList::iterator pIt2 = ::std::find(rInfo.Listener.begin(), rInfo.Listener.end(), pListener);
if (pIt2 != rInfo.Listener.end())
rInfo.Listener.erase(pIt2);
-
- aReadLock.unlock();
- // <- SAFE ------------------------------
}
OUString StorageHolder::getPathOfStorage(const css::uno::Reference< css::embed::XStorage >& xStorage)
{
- // SAFE -> ------------------------------
- Guard aReadLock(m_aLock);
+ osl::MutexGuard g(m_mutex);
TPath2StorageInfo::const_iterator pIt;
for ( pIt = m_lStorages.begin();
@@ -397,8 +364,6 @@ OUString StorageHolder::getPathOfStorage(const css::uno::Reference< css::embed::
return OUString();
return pIt->first;
-
- // <- SAFE ------------------------------
}
@@ -425,7 +390,7 @@ css::uno::Reference< css::embed::XStorage > StorageHolder::getParentStorage(cons
return css::uno::Reference< css::embed::XStorage >();
// SAFE -> ----------------------------------
- Guard aReadLock(m_aLock);
+ osl::ClearableMutexGuard aReadLock(m_mutex);
// b)
if (c < 2)
@@ -444,7 +409,7 @@ css::uno::Reference< css::embed::XStorage > StorageHolder::getParentStorage(cons
if (pParent != m_lStorages.end())
return pParent->second.Storage;
- aReadLock.unlock();
+ aReadLock.clear();
// <- SAFE ----------------------------------
// ?
@@ -455,14 +420,9 @@ css::uno::Reference< css::embed::XStorage > StorageHolder::getParentStorage(cons
void StorageHolder::operator=(const StorageHolder& rCopy)
{
- // SAFE -> ----------------------------------
- Guard aWriteLock(m_aLock);
-
+ osl::MutexGuard g(m_mutex);
m_xRoot = rCopy.m_xRoot;
m_lStorages = rCopy.m_lStorages;
-
- aWriteLock.unlock();
- // <- SAFE ----------------------------------
}
diff --git a/framework/source/inc/accelerators/storageholder.hxx b/framework/source/inc/accelerators/storageholder.hxx
index 8879e0319900..07c0b116c999 100644
--- a/framework/source/inc/accelerators/storageholder.hxx
+++ b/framework/source/inc/accelerators/storageholder.hxx
@@ -21,7 +21,6 @@
#define INCLUDED_FRAMEWORK_SOURCE_INC_ACCELERATORS_STORAGEHOLDER_HXX
#include <accelerators/istoragelistener.hxx>
-#include <threadhelp/threadhelpbase.hxx>
#include <general.h>
#include <stdtypes.h>
@@ -36,7 +35,7 @@ namespace framework
/**
TODO document me
*/
-class StorageHolder : private ThreadHelpBase // attention! Must be the first base class to guarentee right initialize lock ...
+class StorageHolder
{
// types
@@ -68,6 +67,7 @@ class StorageHolder : private ThreadHelpBase // attention! Must be the first bas
// member
private:
+ mutable osl::Mutex m_mutex;
/** @short TODO */
css::uno::Reference< css::embed::XStorage > m_xRoot;