summaryrefslogtreecommitdiff
path: root/vcl/source
diff options
context:
space:
mode:
authorMark Page <aptitude@btconnect.com>2016-04-29 08:33:13 +0100
committerNoel Grandin <noelgrandin@gmail.com>2016-05-03 06:31:52 +0000
commite76d458422b0f0f713cc17bf47ca94c33ac570a7 (patch)
tree728623c04ad9fca76b2eb6a91b509da640d54454 /vcl/source
parentfa6efd4511a999618fd3958c1c72811dc0ef83ee (diff)
Change vGDIObj pointer to unique_ptr to reduce WinMtfOutput complexity
Change-Id: Ia81d3b30a874c2e722f7b836db9fab0be2d6e27b Reviewed-on: https://gerrit.libreoffice.org/24488 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Noel Grandin <noelgrandin@gmail.com>
Diffstat (limited to 'vcl/source')
-rw-r--r--vcl/source/filter/wmf/winmtf.cxx32
-rw-r--r--vcl/source/filter/wmf/winmtf.hxx2
2 files changed, 15 insertions, 19 deletions
diff --git a/vcl/source/filter/wmf/winmtf.cxx b/vcl/source/filter/wmf/winmtf.cxx
index 5c22b262ca39..ca8141faa713 100644
--- a/vcl/source/filter/wmf/winmtf.cxx
+++ b/vcl/source/filter/wmf/winmtf.cxx
@@ -29,6 +29,7 @@
#include <rtl/strbuf.hxx>
#include <rtl/tencinfo.h>
#include <vcl/virdev.hxx>
+#include <o3tl/make_unique.hxx>
#if OSL_DEBUG_LEVEL > 1
#define EMFP_DEBUG(x) x
@@ -531,19 +532,23 @@ tools::PolyPolygon& WinMtfOutput::ImplMap( tools::PolyPolygon& rPolyPolygon )
void WinMtfOutput::SelectObject( sal_Int32 nIndex )
{
- GDIObj* pGDIObj = nullptr;
+ std::unique_ptr<GDIObj> stock_object;
+ GDIObj *pGDIObj = nullptr;
if ( nIndex & ENHMETA_STOCK_OBJECT )
- pGDIObj = new GDIObj();
+ {
+ stock_object = o3tl::make_unique<GDIObj>();
+ pGDIObj = stock_object.get();
+ }
else
{
nIndex &= 0xffff; // safety check: don't allow index to be > 65535
if ( (sal_uInt32)nIndex < vGDIObj.size() )
- pGDIObj = vGDIObj[ nIndex ];
+ pGDIObj = vGDIObj[ nIndex ].get();
}
- if( pGDIObj == nullptr )
+ if( !pGDIObj )
return;
if ( nIndex & ENHMETA_STOCK_OBJECT )
@@ -616,8 +621,6 @@ void WinMtfOutput::SelectObject( sal_Int32 nIndex )
break; // -Wall many options not handled.
}
}
- if ( nIndex & ENHMETA_STOCK_OBJECT )
- delete pGDIObj;
}
@@ -648,7 +651,7 @@ void WinMtfOutput::SetTextAlign( sal_uInt32 nAlign )
void WinMtfOutput::ImplResizeObjectArry( sal_uInt32 nNewEntrys )
{
- vGDIObj.resize(nNewEntrys, nullptr);
+ vGDIObj.resize(nNewEntrys);
}
void WinMtfOutput::ImplDrawClippedPolyPolygon( const tools::PolyPolygon& rPolyPoly )
@@ -702,13 +705,13 @@ void WinMtfOutput::CreateObject( GDIObjectType eType, void* pStyle )
sal_uInt32 nIndex;
for ( nIndex = 0; nIndex < vGDIObj.size(); nIndex++ )
{
- if ( vGDIObj[ nIndex ] == nullptr )
+ if ( !vGDIObj[ nIndex ] )
break;
}
if ( nIndex == vGDIObj.size() )
ImplResizeObjectArry( vGDIObj.size() + 16 );
- vGDIObj[ nIndex ] = new GDIObj( eType, pStyle );
+ vGDIObj[ nIndex ] = o3tl::make_unique<GDIObj>( eType, pStyle );
}
void WinMtfOutput::CreateObject( sal_Int32 nIndex, GDIObjectType eType, void* pStyle )
@@ -744,10 +747,7 @@ void WinMtfOutput::CreateObject( sal_Int32 nIndex, GDIObjectType eType, void* pS
if ( (sal_uInt32)nIndex >= vGDIObj.size() )
ImplResizeObjectArry( nIndex + 16 );
- if ( vGDIObj[ nIndex ] != nullptr )
- delete vGDIObj[ nIndex ];
-
- vGDIObj[ nIndex ] = new GDIObj( eType, pStyle );
+ vGDIObj[ nIndex ] = o3tl::make_unique<GDIObj>( eType, pStyle );
}
else
{
@@ -776,8 +776,7 @@ void WinMtfOutput::DeleteObject( sal_Int32 nIndex )
{
if ( (sal_uInt32)nIndex < vGDIObj.size() )
{
- delete vGDIObj[ nIndex ];
- vGDIObj[ nIndex ] = nullptr;
+ vGDIObj[ nIndex ].reset();
}
}
}
@@ -883,9 +882,6 @@ WinMtfOutput::~WinMtfOutput()
mpGDIMetaFile->SetPrefSize( Size( mnDevWidth, mnDevHeight ) );
else
mpGDIMetaFile->SetPrefSize( mrclFrame.GetSize() );
-
- for ( size_t i = 0; i < vGDIObj.size(); i++ )
- delete vGDIObj[ i ];
}
void WinMtfOutput::UpdateClipRegion()
diff --git a/vcl/source/filter/wmf/winmtf.hxx b/vcl/source/filter/wmf/winmtf.hxx
index 51aba435b70a..db4aa0155953 100644
--- a/vcl/source/filter/wmf/winmtf.hxx
+++ b/vcl/source/filter/wmf/winmtf.hxx
@@ -551,7 +551,7 @@ class WinMtfOutput
RasterOp meLatestRasterOp;
RasterOp meRasterOp;
- std::vector< GDIObj* > vGDIObj;
+ std::vector< std::unique_ptr<GDIObj> > vGDIObj;
Point maActPos;