cleanup osx/clipboard.{cxx,hxx}
Change-Id: Iff472d81f7ef0a3371a0735f025a72c595321efd Reviewed-on: https://gerrit.libreoffice.org/71352 Tested-by: Jenkins Reviewed-by: Tomaž Vajngerl <quikee@gmail.com>
This commit is contained in:
committed by
Tomaž Vajngerl
parent
43f8ea2195
commit
785b300a26
@@ -26,14 +26,7 @@
|
|||||||
#include <comphelper/processfactory.hxx>
|
#include <comphelper/processfactory.hxx>
|
||||||
#include <cppuhelper/supportsservice.hxx>
|
#include <cppuhelper/supportsservice.hxx>
|
||||||
|
|
||||||
using namespace com::sun::star::datatransfer;
|
using namespace css;
|
||||||
using namespace com::sun::star::datatransfer::clipboard;
|
|
||||||
using namespace com::sun::star::lang;
|
|
||||||
using namespace com::sun::star::uno;
|
|
||||||
using namespace cppu;
|
|
||||||
using namespace osl;
|
|
||||||
using namespace std;
|
|
||||||
using namespace comphelper;
|
|
||||||
|
|
||||||
@implementation EventListener;
|
@implementation EventListener;
|
||||||
|
|
||||||
@@ -71,18 +64,18 @@ static OUString clipboard_getImplementationName()
|
|||||||
return OUString("com.sun.star.datatransfer.clipboard.AquaClipboard");
|
return OUString("com.sun.star.datatransfer.clipboard.AquaClipboard");
|
||||||
}
|
}
|
||||||
|
|
||||||
static Sequence<OUString> clipboard_getSupportedServiceNames()
|
static uno::Sequence<OUString> clipboard_getSupportedServiceNames()
|
||||||
{
|
{
|
||||||
return { OUString("com.sun.star.datatransfer.clipboard.SystemClipboard") };
|
return { OUString("com.sun.star.datatransfer.clipboard.SystemClipboard") };
|
||||||
}
|
}
|
||||||
|
|
||||||
AquaClipboard::AquaClipboard(NSPasteboard* pasteboard, bool bUseSystemPasteboard) :
|
AquaClipboard::AquaClipboard(NSPasteboard* pasteboard, bool bUseSystemPasteboard)
|
||||||
WeakComponentImplHelper<XSystemClipboard, XFlushableClipboard, XServiceInfo>(m_aMutex),
|
: WeakComponentImplHelper<XSystemClipboard, XFlushableClipboard, XServiceInfo>(m_aMutex)
|
||||||
mIsSystemPasteboard(bUseSystemPasteboard)
|
, mIsSystemPasteboard(bUseSystemPasteboard)
|
||||||
{
|
{
|
||||||
Reference<XComponentContext> xContext = comphelper::getProcessComponentContext();
|
uno::Reference<uno::XComponentContext> xContext = comphelper::getProcessComponentContext();
|
||||||
|
|
||||||
mrXMimeCntFactory = MimeContentTypeFactory::create(xContext);
|
mrXMimeCntFactory = datatransfer::MimeContentTypeFactory::create(xContext);
|
||||||
|
|
||||||
mpDataFlavorMapper = DataFlavorMapperPtr_t(new DataFlavorMapper());
|
mpDataFlavorMapper = DataFlavorMapperPtr_t(new DataFlavorMapper());
|
||||||
|
|
||||||
@@ -100,7 +93,7 @@ AquaClipboard::AquaClipboard(NSPasteboard* pasteboard, bool bUseSystemPasteboard
|
|||||||
|
|
||||||
if (mPasteboard == nil)
|
if (mPasteboard == nil)
|
||||||
{
|
{
|
||||||
throw RuntimeException("AquaClipboard: Cannot create Cocoa pasteboard",
|
throw uno::RuntimeException("AquaClipboard: Cannot create Cocoa pasteboard",
|
||||||
static_cast<XClipboardEx*>(this));
|
static_cast<XClipboardEx*>(this));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -113,7 +106,7 @@ AquaClipboard::AquaClipboard(NSPasteboard* pasteboard, bool bUseSystemPasteboard
|
|||||||
{
|
{
|
||||||
[mPasteboard release];
|
[mPasteboard release];
|
||||||
|
|
||||||
throw RuntimeException(
|
throw uno::RuntimeException(
|
||||||
"AquaClipboard: Cannot create pasteboard change listener",
|
"AquaClipboard: Cannot create pasteboard change listener",
|
||||||
static_cast<XClipboardEx*>(this));
|
static_cast<XClipboardEx*>(this));
|
||||||
}
|
}
|
||||||
@@ -143,9 +136,9 @@ AquaClipboard::~AquaClipboard()
|
|||||||
[mPasteboard release];
|
[mPasteboard release];
|
||||||
}
|
}
|
||||||
|
|
||||||
Reference<XTransferable> SAL_CALL AquaClipboard::getContents()
|
uno::Reference<datatransfer::XTransferable> SAL_CALL AquaClipboard::getContents()
|
||||||
{
|
{
|
||||||
MutexGuard aGuard(m_aMutex);
|
osl::MutexGuard aGuard(m_aMutex);
|
||||||
|
|
||||||
// Shortcut: If we are clipboard owner already we don't need
|
// Shortcut: If we are clipboard owner already we don't need
|
||||||
// to drag the data through the system clipboard
|
// to drag the data through the system clipboard
|
||||||
@@ -154,24 +147,26 @@ Reference<XTransferable> SAL_CALL AquaClipboard::getContents()
|
|||||||
return mXClipboardContent;
|
return mXClipboardContent;
|
||||||
}
|
}
|
||||||
|
|
||||||
return Reference<XTransferable>(new OSXTransferable(mrXMimeCntFactory,
|
return uno::Reference<datatransfer::XTransferable>(
|
||||||
|
new OSXTransferable(mrXMimeCntFactory,
|
||||||
mpDataFlavorMapper,
|
mpDataFlavorMapper,
|
||||||
mPasteboard));
|
mPasteboard));
|
||||||
}
|
}
|
||||||
|
|
||||||
void SAL_CALL AquaClipboard::setContents(const Reference<XTransferable>& xTransferable,
|
void SAL_CALL AquaClipboard::setContents(
|
||||||
const Reference<XClipboardOwner>& xClipboardOwner)
|
uno::Reference<datatransfer::XTransferable> const & xTransferable,
|
||||||
|
uno::Reference<datatransfer::clipboard::XClipboardOwner> const & xClipboardOwner)
|
||||||
{
|
{
|
||||||
NSArray* types = xTransferable.is() ?
|
NSArray* types = xTransferable.is() ?
|
||||||
mpDataFlavorMapper->flavorSequenceToTypesArray(xTransferable->getTransferDataFlavors()) :
|
mpDataFlavorMapper->flavorSequenceToTypesArray(xTransferable->getTransferDataFlavors()) :
|
||||||
[NSArray array];
|
[NSArray array];
|
||||||
|
|
||||||
ClearableMutexGuard aGuard(m_aMutex);
|
osl::ClearableMutexGuard aGuard(m_aMutex);
|
||||||
|
|
||||||
Reference<XClipboardOwner> oldOwner(mXClipboardOwner);
|
uno::Reference<datatransfer::clipboard::XClipboardOwner> oldOwner(mXClipboardOwner);
|
||||||
mXClipboardOwner = xClipboardOwner;
|
mXClipboardOwner = xClipboardOwner;
|
||||||
|
|
||||||
Reference<XTransferable> oldContent(mXClipboardContent);
|
uno::Reference<datatransfer::XTransferable> oldContent(mXClipboardContent);
|
||||||
mXClipboardContent = xTransferable;
|
mXClipboardContent = xTransferable;
|
||||||
|
|
||||||
mPasteboardChangeCount = [mPasteboard declareTypes: types owner: mEventListener];
|
mPasteboardChangeCount = [mPasteboard declareTypes: types owner: mEventListener];
|
||||||
@@ -198,23 +193,23 @@ sal_Int8 SAL_CALL AquaClipboard::getRenderingCapabilities()
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SAL_CALL AquaClipboard::addClipboardListener(const Reference< XClipboardListener >& listener)
|
void SAL_CALL AquaClipboard::addClipboardListener(uno::Reference<datatransfer::clipboard::XClipboardListener> const & listener)
|
||||||
{
|
{
|
||||||
MutexGuard aGuard(m_aMutex);
|
osl::MutexGuard aGuard(m_aMutex);
|
||||||
|
|
||||||
if (!listener.is())
|
if (!listener.is())
|
||||||
throw IllegalArgumentException("empty reference",
|
throw lang::IllegalArgumentException("empty reference",
|
||||||
static_cast<XClipboardEx*>(this), 1);
|
static_cast<XClipboardEx*>(this), 1);
|
||||||
|
|
||||||
mClipboardListeners.push_back(listener);
|
mClipboardListeners.push_back(listener);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SAL_CALL AquaClipboard::removeClipboardListener(const Reference< XClipboardListener >& listener)
|
void SAL_CALL AquaClipboard::removeClipboardListener(uno::Reference<datatransfer::clipboard::XClipboardListener> const & listener)
|
||||||
{
|
{
|
||||||
MutexGuard aGuard(m_aMutex);
|
osl::MutexGuard aGuard(m_aMutex);
|
||||||
|
|
||||||
if (!listener.is())
|
if (!listener.is())
|
||||||
throw IllegalArgumentException("empty reference",
|
throw lang::IllegalArgumentException("empty reference",
|
||||||
static_cast<XClipboardEx*>(this), 1);
|
static_cast<XClipboardEx*>(this), 1);
|
||||||
|
|
||||||
mClipboardListeners.remove(listener);
|
mClipboardListeners.remove(listener);
|
||||||
@@ -222,7 +217,7 @@ void SAL_CALL AquaClipboard::removeClipboardListener(const Reference< XClipboard
|
|||||||
|
|
||||||
void AquaClipboard::applicationDidBecomeActive(NSNotification*)
|
void AquaClipboard::applicationDidBecomeActive(NSNotification*)
|
||||||
{
|
{
|
||||||
ClearableMutexGuard aGuard(m_aMutex);
|
osl::ClearableMutexGuard aGuard(m_aMutex);
|
||||||
|
|
||||||
int currentPboardChgCount = [mPasteboard changeCount];
|
int currentPboardChgCount = [mPasteboard changeCount];
|
||||||
|
|
||||||
@@ -233,10 +228,10 @@ void AquaClipboard::applicationDidBecomeActive(NSNotification*)
|
|||||||
// Clear clipboard content and owner and send lostOwnership
|
// Clear clipboard content and owner and send lostOwnership
|
||||||
// notification to the old clipboard owner as well as
|
// notification to the old clipboard owner as well as
|
||||||
// ClipboardChanged notification to any clipboard listener
|
// ClipboardChanged notification to any clipboard listener
|
||||||
Reference<XClipboardOwner> oldOwner(mXClipboardOwner);
|
uno::Reference<datatransfer::clipboard::XClipboardOwner> oldOwner(mXClipboardOwner);
|
||||||
mXClipboardOwner.clear();
|
mXClipboardOwner.clear();
|
||||||
|
|
||||||
Reference<XTransferable> oldContent(mXClipboardContent);
|
uno::Reference<datatransfer::XTransferable> oldContent(mXClipboardContent);
|
||||||
mXClipboardContent.clear();
|
mXClipboardContent.clear();
|
||||||
|
|
||||||
aGuard.clear();
|
aGuard.clear();
|
||||||
@@ -252,34 +247,43 @@ void AquaClipboard::applicationDidBecomeActive(NSNotification*)
|
|||||||
|
|
||||||
void AquaClipboard::fireClipboardChangedEvent()
|
void AquaClipboard::fireClipboardChangedEvent()
|
||||||
{
|
{
|
||||||
ClearableMutexGuard aGuard(m_aMutex);
|
osl::ClearableMutexGuard aGuard(m_aMutex);
|
||||||
|
|
||||||
list<Reference< XClipboardListener > > listeners(mClipboardListeners);
|
datatransfer::clipboard::ClipboardEvent aEvent;
|
||||||
ClipboardEvent aEvent;
|
|
||||||
|
|
||||||
if (!listeners.empty())
|
if (!mClipboardListeners.empty())
|
||||||
{
|
{
|
||||||
aEvent = ClipboardEvent(static_cast<OWeakObject*>(this), getContents());
|
aEvent = datatransfer::clipboard::ClipboardEvent(static_cast<OWeakObject*>(this), getContents());
|
||||||
}
|
}
|
||||||
|
|
||||||
aGuard.clear();
|
aGuard.clear();
|
||||||
|
|
||||||
for (auto const& listener : listeners)
|
for (auto const& rListener : mClipboardListeners)
|
||||||
{
|
{
|
||||||
if (listener.is())
|
if (rListener.is())
|
||||||
{
|
{
|
||||||
try { listener->changedContents(aEvent); }
|
try
|
||||||
catch (RuntimeException&) { }
|
{
|
||||||
|
rListener->changedContents(aEvent);
|
||||||
|
}
|
||||||
|
catch (uno::RuntimeException& )
|
||||||
|
{}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void AquaClipboard::fireLostClipboardOwnershipEvent(Reference<XClipboardOwner> const & oldOwner, Reference<XTransferable> const & oldContent)
|
void AquaClipboard::fireLostClipboardOwnershipEvent(
|
||||||
|
uno::Reference<datatransfer::clipboard::XClipboardOwner> const & rOldOwner,
|
||||||
|
uno::Reference<datatransfer::XTransferable> const & rOldContent)
|
||||||
{
|
{
|
||||||
assert(oldOwner.is());
|
assert(rOldOwner.is());
|
||||||
|
|
||||||
try { oldOwner->lostOwnership(static_cast<XClipboardEx*>(this), oldContent); }
|
try
|
||||||
catch(RuntimeException&) { }
|
{
|
||||||
|
rOldOwner->lostOwnership(static_cast<XClipboardEx*>(this), rOldContent);
|
||||||
|
}
|
||||||
|
catch(uno::RuntimeException&)
|
||||||
|
{}
|
||||||
}
|
}
|
||||||
|
|
||||||
void AquaClipboard::provideDataForType(NSPasteboard* sender, const NSString* type)
|
void AquaClipboard::provideDataForType(NSPasteboard* sender, const NSString* type)
|
||||||
@@ -301,7 +305,7 @@ void SAL_CALL AquaClipboard::flushClipboard()
|
|||||||
{
|
{
|
||||||
if (mXClipboardContent.is())
|
if (mXClipboardContent.is())
|
||||||
{
|
{
|
||||||
Sequence<DataFlavor> flavorList = mXClipboardContent->getTransferDataFlavors();
|
uno::Sequence<datatransfer::DataFlavor> flavorList = mXClipboardContent->getTransferDataFlavors();
|
||||||
sal_uInt32 nFlavors = flavorList.getLength();
|
sal_uInt32 nFlavors = flavorList.getLength();
|
||||||
bool bInternal(false);
|
bool bInternal(false);
|
||||||
|
|
||||||
@@ -328,12 +332,12 @@ OUString SAL_CALL AquaClipboard::getImplementationName()
|
|||||||
return clipboard_getImplementationName();
|
return clipboard_getImplementationName();
|
||||||
}
|
}
|
||||||
|
|
||||||
sal_Bool SAL_CALL AquaClipboard::supportsService( const OUString& ServiceName )
|
sal_Bool SAL_CALL AquaClipboard::supportsService(OUString const & rServiceName)
|
||||||
{
|
{
|
||||||
return cppu::supportsService(this, ServiceName);
|
return cppu::supportsService(this, rServiceName);
|
||||||
}
|
}
|
||||||
|
|
||||||
Sequence< OUString > SAL_CALL AquaClipboard::getSupportedServiceNames()
|
uno::Sequence<OUString> SAL_CALL AquaClipboard::getSupportedServiceNames()
|
||||||
{
|
{
|
||||||
return clipboard_getSupportedServiceNames();
|
return clipboard_getSupportedServiceNames();
|
||||||
}
|
}
|
||||||
|
@@ -89,8 +89,8 @@ public:
|
|||||||
|
|
||||||
virtual css::uno::Reference<css::datatransfer::XTransferable> SAL_CALL getContents() override;
|
virtual css::uno::Reference<css::datatransfer::XTransferable> SAL_CALL getContents() override;
|
||||||
|
|
||||||
virtual void SAL_CALL setContents( const css::uno::Reference< css::datatransfer::XTransferable >& xTransferable,
|
virtual void SAL_CALL setContents(css::uno::Reference<css::datatransfer::XTransferable> const & xTransferable,
|
||||||
const css::uno::Reference< css::datatransfer::clipboard::XClipboardOwner >& xClipboardOwner ) override;
|
css::uno::Reference<css::datatransfer::clipboard::XClipboardOwner> const & xClipboardOwner) override;
|
||||||
|
|
||||||
virtual OUString SAL_CALL getName() override;
|
virtual OUString SAL_CALL getName() override;
|
||||||
|
|
||||||
@@ -100,9 +100,8 @@ public:
|
|||||||
|
|
||||||
// XClipboardNotifier
|
// XClipboardNotifier
|
||||||
|
|
||||||
virtual void SAL_CALL addClipboardListener( const css::uno::Reference< css::datatransfer::clipboard::XClipboardListener >& listener ) override;
|
virtual void SAL_CALL addClipboardListener(css::uno::Reference<css::datatransfer::clipboard::XClipboardListener> const & listener) override;
|
||||||
|
virtual void SAL_CALL removeClipboardListener(css::uno::Reference<css::datatransfer::clipboard::XClipboardListener> const & listener) override;
|
||||||
virtual void SAL_CALL removeClipboardListener( const css::uno::Reference< css::datatransfer::clipboard::XClipboardListener >& listener ) override;
|
|
||||||
|
|
||||||
// XFlushableClipboard
|
// XFlushableClipboard
|
||||||
|
|
||||||
@@ -111,9 +110,7 @@ public:
|
|||||||
// XServiceInfo
|
// XServiceInfo
|
||||||
|
|
||||||
virtual OUString SAL_CALL getImplementationName() override;
|
virtual OUString SAL_CALL getImplementationName() override;
|
||||||
|
|
||||||
virtual sal_Bool SAL_CALL supportsService( const OUString& ServiceName ) override;
|
virtual sal_Bool SAL_CALL supportsService( const OUString& ServiceName ) override;
|
||||||
|
|
||||||
virtual css::uno::Sequence< OUString > SAL_CALL getSupportedServiceNames() override;
|
virtual css::uno::Sequence< OUString > SAL_CALL getSupportedServiceNames() override;
|
||||||
|
|
||||||
/* Get a reference to the used pastboard.
|
/* Get a reference to the used pastboard.
|
||||||
@@ -140,7 +137,7 @@ private:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
css::uno::Reference<css::datatransfer::XMimeContentTypeFactory> mrXMimeCntFactory;
|
css::uno::Reference<css::datatransfer::XMimeContentTypeFactory> mrXMimeCntFactory;
|
||||||
::std::list< css::uno::Reference< css::datatransfer::clipboard::XClipboardListener > > mClipboardListeners;
|
std::list<css::uno::Reference<css::datatransfer::clipboard::XClipboardListener>> mClipboardListeners;
|
||||||
css::uno::Reference<css::datatransfer::XTransferable> mXClipboardContent;
|
css::uno::Reference<css::datatransfer::XTransferable> mXClipboardContent;
|
||||||
css::uno::Reference<css::datatransfer::clipboard::XClipboardOwner> mXClipboardOwner;
|
css::uno::Reference<css::datatransfer::clipboard::XClipboardOwner> mXClipboardOwner;
|
||||||
DataFlavorMapperPtr_t mpDataFlavorMapper;
|
DataFlavorMapperPtr_t mpDataFlavorMapper;
|
||||||
|
Reference in New Issue
Block a user