summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNoel Grandin <noel.grandin@collabora.co.uk>2017-01-19 12:27:03 +0200
committerNoel Grandin <noel.grandin@collabora.co.uk>2017-01-19 13:06:47 +0200
commit6944b82d6d892e9921af659a4eabec5976511392 (patch)
tree1478f46e6934d677a3e4911505f7f46fbe6c9a48
parenta024b6dfff0c773e8cfbefa7f6a9d3579ce8e759 (diff)
use rtl::Reference in SdrOle2ObjImpl
instead of manual acquire/release Change-Id: I7110073e9ada8c034295133468c38754e9b55b69
-rw-r--r--svx/source/svdraw/svdoole2.cxx27
1 files changed, 12 insertions, 15 deletions
diff --git a/svx/source/svdraw/svdoole2.cxx b/svx/source/svdraw/svdoole2.cxx
index 6e6609164b75..3b924abb13c1 100644
--- a/svx/source/svdraw/svdoole2.cxx
+++ b/svx/source/svdraw/svdoole2.cxx
@@ -84,6 +84,7 @@
#include <basegfx/polygon/b2dpolypolygon.hxx>
#include <editeng/outlobj.hxx>
#include <svx/svdpage.hxx>
+#include <rtl/ref.hxx>
using namespace ::com::sun::star;
@@ -643,7 +644,7 @@ public:
SdrEmbedObjectLink* mpObjectLink;
OUString maLinkURL;
- SvxUnoShapeModifyListener* mpModifyListener;
+ rtl::Reference<SvxUnoShapeModifyListener> mxModifyListener;
explicit SdrOle2ObjImpl( bool bFrame ) :
mpGraphic(nullptr),
@@ -656,8 +657,7 @@ public:
mbIsChart(false),
mbLoadingOLEObjectFailed(false),
mbConnected(false),
- mpObjectLink(nullptr),
- mpModifyListener(nullptr)
+ mpObjectLink(nullptr)
{
mxObjRef.Lock();
}
@@ -674,8 +674,7 @@ public:
mbIsChart(false),
mbLoadingOLEObjectFailed(false),
mbConnected(false),
- mpObjectLink(nullptr),
- mpModifyListener(nullptr)
+ mpObjectLink(nullptr)
{
mxObjRef.Lock();
}
@@ -685,10 +684,9 @@ public:
delete mpGraphic;
delete mpGraphicObject;
- if (mpModifyListener)
+ if (mxModifyListener.is())
{
- mpModifyListener->invalidate();
- mpModifyListener->release();
+ mxModifyListener->invalidate();
}
}
};
@@ -1099,16 +1097,15 @@ void SdrOle2Obj::AddListeners_Impl()
if( mpImpl->mxObjRef.is() && mpImpl->mxObjRef->getCurrentState() != embed::EmbedStates::LOADED )
{
// register modify listener
- if (!mpImpl->mpModifyListener)
+ if (!mpImpl->mxModifyListener.is())
{
- mpImpl->mpModifyListener = new SvxUnoShapeModifyListener(this);
- mpImpl->mpModifyListener->acquire();
+ mpImpl->mxModifyListener = new SvxUnoShapeModifyListener(this);
}
uno::Reference< util::XModifyBroadcaster > xBC( getXModel(), uno::UNO_QUERY );
- if (xBC.is() && mpImpl->mpModifyListener)
+ if (xBC.is())
{
- uno::Reference<util::XModifyListener> xListener(mpImpl->mpModifyListener);
+ uno::Reference<util::XModifyListener> xListener(mpImpl->mxModifyListener.get());
xBC->addModifyListener( xListener );
}
}
@@ -1139,9 +1136,9 @@ void SdrOle2Obj::RemoveListeners_Impl()
if ( nState != embed::EmbedStates::LOADED )
{
uno::Reference< util::XModifyBroadcaster > xBC( getXModel(), uno::UNO_QUERY );
- if (xBC.is() && mpImpl->mpModifyListener)
+ if (xBC.is() && mpImpl->mxModifyListener.is())
{
- uno::Reference<util::XModifyListener> xListener(mpImpl->mpModifyListener);
+ uno::Reference<util::XModifyListener> xListener(mpImpl->mxModifyListener.get());
xBC->removeModifyListener( xListener );
}
}