[Libreoffice-commits] core.git: editeng/source include/editeng

Noel (via logerrit) logerrit at kemper.freedesktop.org
Mon Oct 26 12:02:31 UTC 2020


 editeng/source/rtf/svxrtf.cxx |   20 +++++++-------------
 include/editeng/svxrtf.hxx    |   14 ++++++--------
 2 files changed, 13 insertions(+), 21 deletions(-)

New commits:
commit 39ae9d29be0b4308b6e6ab7ee52c3fe6d6dc7d0c
Author:     Noel <noelgrandin at gmail.com>
AuthorDate: Mon Oct 26 10:17:14 2020 +0200
Commit:     Noel Grandin <noel.grandin at collabora.co.uk>
CommitDate: Mon Oct 26 13:01:53 2020 +0100

    std::unique_ptr -> std::optional
    
    Change-Id: Icd4c818579a7b15454706ab4e02d47e1ac368160
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/104796
    Tested-by: Jenkins
    Reviewed-by: Noel Grandin <noel.grandin at collabora.co.uk>

diff --git a/editeng/source/rtf/svxrtf.cxx b/editeng/source/rtf/svxrtf.cxx
index affc44b8f5f2..17ef94553ec5 100644
--- a/editeng/source/rtf/svxrtf.cxx
+++ b/editeng/source/rtf/svxrtf.cxx
@@ -72,13 +72,11 @@ SvxRTFParser::SvxRTFParser( SfxItemPool& rPool, SvStream& rIn )
     , bIsInReadStyleTab( false)
 {
     pDfltFont.reset( new vcl::Font );
-    pDfltColor.reset( new Color );
+    mxDefaultColor = Color();
 }
 
 SvxRTFParser::~SvxRTFParser()
 {
-    if( !aColorTbl.empty() )
-        ClearColorTbl();
     if( !aAttrStack.empty() )
         ClearAttrStack();
 }
@@ -95,7 +93,7 @@ SvParserState SvxRTFParser::CallParser()
     if( !pInsPos )
         return SvParserState::Error;
 
-    if( !aColorTbl.empty() )
+    if( !maColorTable.empty() )
         ClearColorTbl();
     m_FontTable.clear();
     m_StyleTable.clear();
@@ -422,11 +420,11 @@ void SvxRTFParser::ReadColorTable()
             {
                 // one color is finished, fill in the table
                 // try to map the values to SV internal names
-                Color* pColor = new Color( nRed, nGreen, nBlue );
-                if( aColorTbl.empty() &&
+                Color aColor( nRed, nGreen, nBlue );
+                if( maColorTable.empty() &&
                     sal_uInt8(-1) == nRed && sal_uInt8(-1) == nGreen && sal_uInt8(-1) == nBlue )
-                    *pColor = COL_AUTO;
-                aColorTbl.push_back( pColor );
+                    aColor = COL_AUTO;
+                maColorTable.push_back( aColor );
                 nRed = 0;
                 nGreen = 0;
                 nBlue = 0;
@@ -579,11 +577,7 @@ void SvxRTFParser::ReadFontTable()
 
 void SvxRTFParser::ClearColorTbl()
 {
-    while ( !aColorTbl.empty() )
-    {
-        delete aColorTbl.back();
-        aColorTbl.pop_back();
-    }
+    maColorTable.clear();
 }
 
 void SvxRTFParser::ClearAttrStack()
diff --git a/include/editeng/svxrtf.hxx b/include/editeng/svxrtf.hxx
index 2069abb48877..5457cf9765ae 100644
--- a/include/editeng/svxrtf.hxx
+++ b/include/editeng/svxrtf.hxx
@@ -23,16 +23,15 @@
 #include <svl/itemset.hxx>
 #include <svtools/parrtf.hxx>
 #include <rtl/ustring.hxx>
+#include <tools/color.hxx>
 
 #include <editeng/editengdllapi.h>
 
-#include <deque>
 #include <vector>
 #include <map>
 #include <memory>
 
 namespace vcl { class Font; }
-class Color;
 struct SvxRTFStyleType;
 class SvxRTFItemStackType;
 class SvxRTFItemStackList : public std::vector<std::unique_ptr<SvxRTFItemStackType>> {};
@@ -160,7 +159,7 @@ struct RTFPardAttrMapIds
 
 class EDITENG_DLLPUBLIC SvxRTFParser : public SvRTFParser
 {
-    std::deque< Color* >  aColorTbl;
+    std::vector<Color>    maColorTable;
     SvxRTFFontTbl         m_FontTable;
     SvxRTFStyleTbl        m_StyleTable;
     std::deque< std::unique_ptr<SvxRTFItemStackType> >  aAttrStack;
@@ -172,7 +171,7 @@ class EDITENG_DLLPUBLIC SvxRTFParser : public SvRTFParser
 
     std::unique_ptr<EditPosition> pInsPos;
     SfxItemPool* pAttrPool;
-    std::unique_ptr<Color>  pDfltColor;
+    std::optional<Color>  mxDefaultColor;
     std::unique_ptr<vcl::Font>   pDfltFont;
     std::unique_ptr<SfxItemSet> pRTFDefaults;
 
@@ -339,10 +338,9 @@ public:
 
 inline const Color& SvxRTFParser::GetColor( size_t nId ) const
 {
-    Color* pColor = pDfltColor.get();
-    if( nId < aColorTbl.size() )
-        pColor = aColorTbl[ nId ];
-    return *pColor;
+    if( nId < maColorTable.size() )
+        return maColorTable[ nId ];
+    return *mxDefaultColor;
 }
 
 inline SfxItemSet& SvxRTFParser::GetAttrSet()


More information about the Libreoffice-commits mailing list