summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Kaganski <mike.kaganski@collabora.com>2019-06-07 23:22:13 +1000
committerMike Kaganski <mike.kaganski@collabora.com>2019-06-08 03:50:29 +0200
commit5fca7ba2fd6031515636842b44996bac74287568 (patch)
treeb26aec974e98a42e66741d4592218b7bef3cdd7a
parent2cb6a591b643a0f65dc58f060f60cc707ad3589c (diff)
Drop SwAttrHandler::SwAttrStack; use std::vector instead
Change-Id: I3e6257cc34782ca32fb2a7c87c9976494b36907b Reviewed-on: https://gerrit.libreoffice.org/73660 Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk> Tested-by: Jenkins Reviewed-by: Mike Kaganski <mike.kaganski@collabora.com>
-rw-r--r--sw/source/core/text/atrhndl.hxx47
-rw-r--r--sw/source/core/text/atrstck.cxx129
2 files changed, 35 insertions, 141 deletions
diff --git a/sw/source/core/text/atrhndl.hxx b/sw/source/core/text/atrhndl.hxx
index 81a141327e30..8abb678ea9fd 100644
--- a/sw/source/core/text/atrhndl.hxx
+++ b/sw/source/core/text/atrhndl.hxx
@@ -20,10 +20,10 @@
#ifndef INCLUDED_SW_SOURCE_CORE_TEXT_ATRHNDL_HXX
#define INCLUDED_SW_SOURCE_CORE_TEXT_ATRHNDL_HXX
-#define INITIAL_NUM_ATTR 3
#define NUM_ATTRIBUTE_STACKS 44
#include <memory>
+#include <vector>
#include <swfntcch.hxx>
class SwTextAttr;
@@ -40,47 +40,7 @@ extern const sal_uInt8 StackPos[];
class SwAttrHandler
{
private:
-
- /// Container for SwTextAttr Objects
- class SwAttrStack
- {
- private:
- SwTextAttr* m_pInitialArray[ INITIAL_NUM_ATTR ];
- SwTextAttr** m_pArray;
- sal_uInt32 m_nCount; // number of elements on stack
- sal_uInt32 m_nSize; // number of positions in Array
-
- public:
- // Ctor, Dtor
- inline SwAttrStack();
- ~SwAttrStack() {
- if (m_nSize > INITIAL_NUM_ATTR) delete [] m_pArray;
- }
-
- // reset stack
- void Reset() { m_nCount = 0; };
-
- // insert on top
- void Push( const SwTextAttr& rAttr ) { Insert(rAttr, m_nCount); };
- // insert at specified position, take care for not inserting behind
- // the value returned by Count()
- void Insert( const SwTextAttr& rAttr, const sal_uInt32 nPos );
-
- // remove specified attribute
- void Remove( const SwTextAttr& rAttr );
-
- // get attribute from top if exists, otherwise 0
- const SwTextAttr* Top() const;
-
- // number of elements on stack
- sal_uInt32 Count() const { return m_nCount; };
-
- // returns position of rAttr on Stack if found, otherwise USHRT_MAX
- // can be used for Remove of an attribute
- sal_uInt32 Pos( const SwTextAttr& rAttr ) const;
- };
-
- SwAttrStack m_aAttrStack[ NUM_ATTRIBUTE_STACKS ]; // stack collection
+ std::vector<const SwTextAttr*> m_aAttrStack[NUM_ATTRIBUTE_STACKS]; // stack collection
const SfxPoolItem* m_pDefaultArray[ NUM_DEFAULT_VALUES ];
const IDocumentSettingAccess* m_pIDocumentSettingAccess;
const SwViewShell* m_pShell;
@@ -91,6 +51,9 @@ private:
bool m_bVertLayout;
+ const SwTextAttr* GetTop(sal_uInt16 nStack);
+ void RemoveFromStack(sal_uInt16 nWhich, const SwTextAttr& rAttr);
+
// change font according to pool item
void FontChg(const SfxPoolItem& rItem, SwFont& rFnt, bool bPush );
diff --git a/sw/source/core/text/atrstck.cxx b/sw/source/core/text/atrstck.cxx
index eb2762fffb40..39ea69a42b33 100644
--- a/sw/source/core/text/atrstck.cxx
+++ b/sw/source/core/text/atrstck.cxx
@@ -54,8 +54,6 @@
#include <IDocumentSettingAccess.hxx>
#include <viewsh.hxx>
-#define STACK_INCREMENT 4
-
/**
* Attribute to Stack Mapping
*
@@ -264,84 +262,6 @@ static bool lcl_ChgHyperLinkColor( const SwTextAttr& rAttr,
return false;
}
-inline SwAttrHandler::SwAttrStack::SwAttrStack()
- : m_nCount( 0 ), m_nSize( INITIAL_NUM_ATTR )
-{
- m_pArray = m_pInitialArray;
-}
-
-void SwAttrHandler::SwAttrStack::Insert( const SwTextAttr& rAttr, const sal_uInt32 nPos )
-{
- // do we still have enough space?
- if (m_nCount >= m_nSize)
- {
- // we are still in our initial array
- if (INITIAL_NUM_ATTR == m_nSize)
- {
- m_nSize += STACK_INCREMENT;
- m_pArray = new SwTextAttr*[ m_nSize ];
- // copy from pInitArray to new Array
- memcpy( m_pArray, m_pInitialArray,
- INITIAL_NUM_ATTR * sizeof(SwTextAttr*)
- );
- }
- // we are in new memory
- else
- {
- m_nSize += STACK_INCREMENT;
- SwTextAttr** pTmpArray = new SwTextAttr*[ m_nSize ];
- // copy from m_pArray to new Array
- memcpy( pTmpArray, m_pArray, m_nCount * sizeof(SwTextAttr*) );
- // free old array
- delete [] m_pArray;
- m_pArray = pTmpArray;
- }
- }
-
- OSL_ENSURE(nPos <= m_nCount, "wrong position for insert operation");
-
- if (nPos < m_nCount)
- memmove( m_pArray + nPos + 1, m_pArray + nPos,
- (m_nCount - nPos) * sizeof(SwTextAttr*)
- );
- m_pArray[ nPos ] = const_cast<SwTextAttr*>(&rAttr);
-
- m_nCount++;
-}
-
-void SwAttrHandler::SwAttrStack::Remove( const SwTextAttr& rAttr )
-{
- sal_uInt32 nPos = Pos( rAttr );
- if (nPos < m_nCount)
- {
- memmove( m_pArray + nPos, m_pArray + nPos + 1,
- (m_nCount - 1 - nPos) * sizeof(SwTextAttr*)
- );
- m_nCount--;
- }
-}
-
-const SwTextAttr* SwAttrHandler::SwAttrStack::Top() const
-{
- return m_nCount ? m_pArray[ m_nCount - 1 ] : nullptr;
-}
-
-sal_uInt32 SwAttrHandler::SwAttrStack::Pos( const SwTextAttr& rAttr ) const
-{
- if ( ! m_nCount )
- // empty stack
- return std::numeric_limits<sal_uInt32>::max();
-
- for (sal_uInt32 nIdx = m_nCount; nIdx > 0;)
- {
- if (&rAttr == m_pArray[ --nIdx ])
- return nIdx;
- }
-
- // element not found
- return std::numeric_limits<sal_uInt32>::max();
-}
-
SwAttrHandler::SwAttrHandler()
: m_pIDocumentSettingAccess(nullptr)
, m_pShell(nullptr)
@@ -416,8 +336,8 @@ void SwAttrHandler::Init( const SfxPoolItem** pPoolItem, const SwAttrSet* pAS,
void SwAttrHandler::Reset( )
{
- for (SwAttrStack & i : m_aAttrStack)
- i.Reset();
+ for (auto& i : m_aAttrStack)
+ i.clear();
}
void SwAttrHandler::PushAndChg( const SwTextAttr& rAttr, SwFont& rFnt )
@@ -464,6 +384,11 @@ void SwAttrHandler::PushAndChg( const SwTextAttr& rAttr, SwFont& rFnt )
}
}
+const SwTextAttr* SwAttrHandler::GetTop(sal_uInt16 nStack)
+{
+ return m_aAttrStack[nStack].empty() ? nullptr : m_aAttrStack[nStack].back();
+}
+
bool SwAttrHandler::Push( const SwTextAttr& rAttr, const SfxPoolItem& rItem )
{
OSL_ENSURE( rItem.Which() < RES_TXTATR_WITHEND_END,
@@ -477,22 +402,29 @@ bool SwAttrHandler::Push( const SwTextAttr& rAttr, const SfxPoolItem& rItem )
// attributes originating from redlining have highest priority
// second priority are hyperlink attributes, which have a color replacement
- const SwTextAttr* pTopAttr = m_aAttrStack[ nStack ].Top();
+ const SwTextAttr* pTopAttr = GetTop(nStack);
if ( !pTopAttr
|| rAttr.IsPriorityAttr()
|| ( !pTopAttr->IsPriorityAttr()
&& !lcl_ChgHyperLinkColor(*pTopAttr, rItem, m_pShell, nullptr)))
{
- m_aAttrStack[ nStack ].Push( rAttr );
+ m_aAttrStack[nStack].push_back(&rAttr);
return true;
}
- const sal_uInt32 nPos = m_aAttrStack[ nStack ].Count();
- OSL_ENSURE( nPos, "empty stack?" );
- m_aAttrStack[ nStack ].Insert( rAttr, nPos - 1 );
+ const auto it = m_aAttrStack[nStack].end() - 1;
+ m_aAttrStack[nStack].insert(it, &rAttr);
return false;
}
+void SwAttrHandler::RemoveFromStack(sal_uInt16 nWhich, const SwTextAttr& rAttr)
+{
+ auto& rStack = m_aAttrStack[StackPos[nWhich]];
+ const auto it = std::find(rStack.begin(), rStack.end(), &rAttr);
+ if (it != rStack.end())
+ rStack.erase(it);
+}
+
void SwAttrHandler::PopAndChg( const SwTextAttr& rAttr, SwFont& rFnt )
{
if ( RES_TXTATR_WITHEND_END <= rAttr.Which() )
@@ -514,8 +446,7 @@ void SwAttrHandler::PopAndChg( const SwTextAttr& rAttr, SwFont& rFnt )
if ( bRet )
{
// we remove rAttr from the appropriate stack
- const sal_uInt16 nStackPos = StackPos[ i ];
- m_aAttrStack[ nStackPos ].Remove( rAttr );
+ RemoveFromStack(i, rAttr);
// reset font according to attribute on top of stack
// or default value
ActivateTop( rFnt, i );
@@ -526,7 +457,7 @@ void SwAttrHandler::PopAndChg( const SwTextAttr& rAttr, SwFont& rFnt )
// stack and reset the font
else
{
- m_aAttrStack[ StackPos[ rAttr.Which() ] ].Remove( rAttr );
+ RemoveFromStack(rAttr.Which(), rAttr);
// reset font according to attribute on top of stack
// or default value
ActivateTop( rFnt, rAttr.Which() );
@@ -541,7 +472,7 @@ void SwAttrHandler::Pop( const SwTextAttr& rAttr )
if ( rAttr.Which() < RES_TXTATR_WITHEND_END )
{
- m_aAttrStack[ StackPos[ rAttr.Which() ] ].Remove( rAttr );
+ RemoveFromStack(rAttr.Which(), rAttr);
}
}
@@ -551,7 +482,7 @@ void SwAttrHandler::ActivateTop( SwFont& rFnt, const sal_uInt16 nAttr )
"I cannot activate this attribute, nWhich >= RES_TXTATR_WITHEND_END" );
const sal_uInt16 nStackPos = StackPos[ nAttr ];
- const SwTextAttr* pTopAt = m_aAttrStack[ nStackPos ].Top();
+ const SwTextAttr* pTopAt = GetTop(nStackPos);
if ( pTopAt )
{
const SfxPoolItem* pItemNext(nullptr);
@@ -598,7 +529,7 @@ void SwAttrHandler::ActivateTop( SwFont& rFnt, const sal_uInt16 nAttr )
// check, if an rotation attribute has to be applied
const sal_uInt16 nTwoLineStack = StackPos[ RES_CHRATR_TWO_LINES ];
bool bTwoLineAct = false;
- const SwTextAttr* pTwoLineAttr = m_aAttrStack[ nTwoLineStack ].Top();
+ const SwTextAttr* pTwoLineAttr = GetTop(nTwoLineStack);
if ( pTwoLineAttr )
{
@@ -614,7 +545,7 @@ void SwAttrHandler::ActivateTop( SwFont& rFnt, const sal_uInt16 nAttr )
// eventually, an rotate attribute has to be activated
const sal_uInt16 nRotateStack = StackPos[ RES_CHRATR_ROTATE ];
- const SwTextAttr* pRotateAttr = m_aAttrStack[ nRotateStack ].Top();
+ const SwTextAttr* pRotateAttr = GetTop(nRotateStack);
if ( pRotateAttr )
{
@@ -682,7 +613,7 @@ void SwAttrHandler::FontChg(const SfxPoolItem& rItem, SwFont& rFnt, bool bPush )
case RES_CHRATR_UNDERLINE :
{
const sal_uInt16 nStackPos = StackPos[ RES_CHRATR_HIDDEN ];
- const SwTextAttr* pTopAt = m_aAttrStack[ nStackPos ].Top();
+ const SwTextAttr* pTopAt = GetTop(nStackPos);
const SfxPoolItem* pTmpItem = pTopAt ?
CharFormat::GetItem( *pTopAt, RES_CHRATR_HIDDEN ) :
@@ -812,14 +743,14 @@ void SwAttrHandler::FontChg(const SfxPoolItem& rItem, SwFont& rFnt, bool bPush )
// 2. top of two line stack ( or default attribute )is an
// deactivated two line attribute
const bool bRuby =
- 0 != m_aAttrStack[ StackPos[ RES_TXTATR_CJK_RUBY ] ].Count();
+ 0 != m_aAttrStack[ StackPos[ RES_TXTATR_CJK_RUBY ] ].size();
if ( bRuby )
break;
const sal_uInt16 nTwoLineStack = StackPos[ RES_CHRATR_TWO_LINES ];
bool bTwoLineAct = false;
- const SwTextAttr* pTwoLineAttr = m_aAttrStack[ nTwoLineStack ].Top();
+ const SwTextAttr* pTwoLineAttr = GetTop(nTwoLineStack);
if ( pTwoLineAttr )
{
@@ -839,7 +770,7 @@ void SwAttrHandler::FontChg(const SfxPoolItem& rItem, SwFont& rFnt, bool bPush )
case RES_CHRATR_TWO_LINES :
{
bool bRuby = 0 !=
- m_aAttrStack[ StackPos[ RES_TXTATR_CJK_RUBY ] ].Count();
+ m_aAttrStack[ StackPos[ RES_TXTATR_CJK_RUBY ] ].size();
// two line is activated, if
// 1. no ruby attribute is set and
@@ -856,7 +787,7 @@ void SwAttrHandler::FontChg(const SfxPoolItem& rItem, SwFont& rFnt, bool bPush )
break;
const sal_uInt16 nRotateStack = StackPos[ RES_CHRATR_ROTATE ];
- const SwTextAttr* pRotateAttr = m_aAttrStack[ nRotateStack ].Top();
+ const SwTextAttr* pRotateAttr = GetTop(nRotateStack);
if ( pRotateAttr )
{