summaryrefslogtreecommitdiff
path: root/vcl/win
diff options
context:
space:
mode:
Diffstat (limited to 'vcl/win')
-rw-r--r--vcl/win/dtrans/WinClipboard.cxx55
-rw-r--r--vcl/win/dtrans/WinClipboard.hxx13
2 files changed, 27 insertions, 41 deletions
diff --git a/vcl/win/dtrans/WinClipboard.cxx b/vcl/win/dtrans/WinClipboard.cxx
index c2fa269dfc5d..f82c56784523 100644
--- a/vcl/win/dtrans/WinClipboard.cxx
+++ b/vcl/win/dtrans/WinClipboard.cxx
@@ -58,8 +58,7 @@ osl::Mutex s_aClipboardSingletonMutex;
/*XEventListener,*/
CWinClipboard::CWinClipboard(const uno::Reference<uno::XComponentContext>& rxContext,
const OUString& aClipboardName)
- : WeakComponentImplHelper<XSystemClipboard, XFlushableClipboard, XServiceInfo>(m_aMutex)
- , m_xContext(rxContext)
+ : m_xContext(rxContext)
, m_itsName(aClipboardName)
, m_pCurrentClipContent(nullptr)
{
@@ -95,7 +94,7 @@ uno::Reference<datatransfer::XTransferable> SAL_CALL CWinClipboard::getContents(
{
osl::MutexGuard aGuard(m_aContentMutex);
- if (rBHelper.bDisposed)
+ if (m_bDisposed)
throw lang::DisposedException("object is already disposed",
static_cast<XClipboardEx*>(this));
@@ -139,7 +138,7 @@ IDataObjectPtr CWinClipboard::getIDataObject()
{
osl::MutexGuard aGuard(m_aContentMutex);
- if (rBHelper.bDisposed)
+ if (m_bDisposed)
throw lang::DisposedException("object is already disposed",
static_cast<XClipboardEx*>(this));
@@ -163,7 +162,7 @@ void SAL_CALL CWinClipboard::setContents(
{
osl::MutexGuard aGuard(m_aContentMutex);
- if (rBHelper.bDisposed)
+ if (m_bDisposed)
throw lang::DisposedException("object is already disposed",
static_cast<XClipboardEx*>(this));
@@ -189,7 +188,7 @@ void SAL_CALL CWinClipboard::setContents(
OUString SAL_CALL CWinClipboard::getName()
{
- if (rBHelper.bDisposed)
+ if (m_bDisposed)
throw lang::DisposedException("object is already disposed",
static_cast<XClipboardEx*>(this));
@@ -202,7 +201,7 @@ void SAL_CALL CWinClipboard::flushClipboard()
{
osl::MutexGuard aGuard(m_aContentMutex);
- if (rBHelper.bDisposed)
+ if (m_bDisposed)
throw lang::DisposedException("object is already disposed",
static_cast<XClipboardEx*>(this));
@@ -224,7 +223,7 @@ void SAL_CALL CWinClipboard::flushClipboard()
sal_Int8 SAL_CALL CWinClipboard::getRenderingCapabilities()
{
- if (rBHelper.bDisposed)
+ if (m_bDisposed)
throw lang::DisposedException("object is already disposed",
static_cast<XClipboardEx*>(this));
@@ -237,7 +236,7 @@ sal_Int8 SAL_CALL CWinClipboard::getRenderingCapabilities()
void SAL_CALL CWinClipboard::addClipboardListener(
const uno::Reference<datatransfer::clipboard::XClipboardListener>& listener)
{
- if (rBHelper.bDisposed)
+ if (m_bDisposed)
throw lang::DisposedException("object is already disposed",
static_cast<XClipboardEx*>(this));
@@ -246,13 +245,14 @@ void SAL_CALL CWinClipboard::addClipboardListener(
throw lang::IllegalArgumentException("empty reference", static_cast<XClipboardEx*>(this),
1);
- rBHelper.aLC.addInterface(cppu::UnoType<decltype(listener)>::get(), listener);
+ std::unique_lock aGuard(m_aMutex);
+ maClipboardListeners.addInterface(aGuard, listener);
}
void SAL_CALL CWinClipboard::removeClipboardListener(
const uno::Reference<datatransfer::clipboard::XClipboardListener>& listener)
{
- if (rBHelper.bDisposed)
+ if (m_bDisposed)
throw lang::DisposedException("object is already disposed",
static_cast<XClipboardEx*>(this));
@@ -261,50 +261,35 @@ void SAL_CALL CWinClipboard::removeClipboardListener(
throw lang::IllegalArgumentException("empty reference", static_cast<XClipboardEx*>(this),
1);
- rBHelper.aLC.removeInterface(cppu::UnoType<decltype(listener)>::get(), listener);
+ std::unique_lock aGuard(m_aMutex);
+ maClipboardListeners.removeInterface(aGuard, listener);
}
void CWinClipboard::notifyAllClipboardListener()
{
- if (rBHelper.bDisposed)
+ if (m_bDisposed)
return;
- osl::ClearableMutexGuard aGuard(rBHelper.rMutex);
- if (rBHelper.bDisposed)
+ std::unique_lock aGuard(m_aMutex);
+ if (m_bDisposed)
return;
- aGuard.clear();
- cppu::OInterfaceContainerHelper* pICHelper = rBHelper.aLC.getContainer(
- cppu::UnoType<datatransfer::clipboard::XClipboardListener>::get());
- if (!pICHelper)
+ if (!maClipboardListeners.getLength(aGuard))
return;
try
{
- cppu::OInterfaceIteratorHelper iter(*pICHelper);
uno::Reference<datatransfer::XTransferable> rXTransf(getContents());
datatransfer::clipboard::ClipboardEvent aClipbEvent(static_cast<XClipboard*>(this),
rXTransf);
-
- while (iter.hasMoreElements())
- {
- try
- {
- uno::Reference<datatransfer::clipboard::XClipboardListener> xCBListener(
- iter.next(), uno::UNO_QUERY);
- if (xCBListener.is())
- xCBListener->changedContents(aClipbEvent);
- }
- catch (uno::RuntimeException&)
- {
- TOOLS_WARN_EXCEPTION("vcl", "");
- }
- }
+ maClipboardListeners.notifyEach(
+ aGuard, &datatransfer::clipboard::XClipboardListener::changedContents, aClipbEvent);
}
catch (const lang::DisposedException&)
{
OSL_FAIL("Service Manager disposed");
+ aGuard.unlock();
// no further clipboard changed notifications
unregisterClipboardViewer();
}
diff --git a/vcl/win/dtrans/WinClipboard.hxx b/vcl/win/dtrans/WinClipboard.hxx
index ac86d0d547b4..779c272c56c9 100644
--- a/vcl/win/dtrans/WinClipboard.hxx
+++ b/vcl/win/dtrans/WinClipboard.hxx
@@ -21,8 +21,8 @@
#include <rtl/ustring.hxx>
#include <sal/types.h>
-#include <cppuhelper/basemutex.hxx>
-#include <cppuhelper/compbase.hxx>
+#include <comphelper/compbase.hxx>
+#include <comphelper/interfacecontainer4.hxx>
#include <com/sun/star/datatransfer/XTransferable.hpp>
#include <com/sun/star/datatransfer/clipboard/XClipboardEx.hpp>
#include <com/sun/star/datatransfer/clipboard/XClipboardOwner.hpp>
@@ -48,10 +48,9 @@
// by this class!
class CWinClipboard final
- : public cppu::BaseMutex,
- public cppu::WeakComponentImplHelper<css::datatransfer::clipboard::XSystemClipboard,
- css::datatransfer::clipboard::XFlushableClipboard,
- css::lang::XServiceInfo>
+ : public comphelper::WeakComponentImplHelper<css::datatransfer::clipboard::XSystemClipboard,
+ css::datatransfer::clipboard::XFlushableClipboard,
+ css::lang::XServiceInfo>
{
friend STDMETHODIMP_(ULONG) CXNotifyingDataObject::Release();
@@ -62,6 +61,8 @@ class CWinClipboard final
com::sun::star::uno::Reference<com::sun::star::datatransfer::XTransferable> m_foreignContent;
osl::Mutex m_aContentMutex;
osl::Mutex m_aContentCacheMutex;
+ comphelper::OInterfaceContainerHelper4<css::datatransfer::clipboard::XClipboardListener>
+ maClipboardListeners;
void notifyAllClipboardListener();
void onReleaseDataObject(CXNotifyingDataObject* theCaller);