summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiklos Vajna <vmiklos@collabora.com>2021-05-04 21:11:10 +0200
committerMiklos Vajna <vmiklos@collabora.com>2021-05-05 08:30:31 +0200
commitc01e7f199bf0ed8e01f596034df79c5c16df69e5 (patch)
tree298c0e1a95b4375d9abfcb42355492de13710bb8
parentb43ab86df783c7816deb5810d89d52e2c3a93b5a (diff)
Introduce SwPageFrameInvFlags to replace magic numbers in ...
... SwPageFrame::SwClientNotify() SwPageFrame::UpdateAttr_() is not yet updated to produce these. Change-Id: Id45162b11ca9bf60f0f0ae43fc22cc2086e0fd67 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/115114 Tested-by: Jenkins Reviewed-by: Miklos Vajna <vmiklos@collabora.com>
-rw-r--r--sw/source/core/inc/pagefrm.hxx18
-rw-r--r--sw/source/core/layout/pagechg.cxx42
2 files changed, 38 insertions, 22 deletions
diff --git a/sw/source/core/inc/pagefrm.hxx b/sw/source/core/inc/pagefrm.hxx
index c5ad094e46a8..7156bec34157 100644
--- a/sw/source/core/inc/pagefrm.hxx
+++ b/sw/source/core/inc/pagefrm.hxx
@@ -36,6 +36,22 @@ namespace vcl { class Font; }
class SwSortedObjs;
class SwAnchoredObject;
+enum class SwPageFrameInvFlags : sal_uInt8
+{
+ NONE = 0x00,
+ InvalidatePrt = 0x01,
+ SetCompletePaint = 0x02,
+ InvalidateNextPos = 0x04,
+ PrepareHeader = 0x08,
+ PrepareFooter = 0x10,
+ CheckGrid = 0x20,
+ InvalidateGrid = 0x40,
+};
+
+namespace o3tl {
+ template<> struct typed_flags<SwPageFrameInvFlags> : is_typed_flags<SwPageFrameInvFlags, 0x007f> {};
+}
+
/// A page of the document layout. Upper frame is expected to be an SwRootFrame
/// instance. At least an SwBodyFrame lower is expected.
class SAL_DLLPUBLIC_RTTI SwPageFrame final: public SwFootnoteBossFrame
@@ -65,7 +81,7 @@ class SAL_DLLPUBLIC_RTTI SwPageFrame final: public SwFootnoteBossFrame
static const sal_Int8 snShadowPxWidth;
- void UpdateAttr_( const SfxPoolItem*, const SfxPoolItem*, sal_uInt8 &,
+ void UpdateAttr_( const SfxPoolItem*, const SfxPoolItem*, SwPageFrameInvFlags &,
SwAttrSetChg *pa = nullptr, SwAttrSetChg *pb = nullptr );
/// Adapt the max. footnote height in each single column
diff --git a/sw/source/core/layout/pagechg.cxx b/sw/source/core/layout/pagechg.cxx
index 5d1d5ec8462d..6f1992cd5a2a 100644
--- a/sw/source/core/layout/pagechg.cxx
+++ b/sw/source/core/layout/pagechg.cxx
@@ -514,7 +514,7 @@ void SwPageFrame::SwClientNotify(const SwModify& rModify, const SfxHint& rHint)
if(auto pSh = getRootFrame()->GetCurrShell())
pSh->SetFirstVisPageInvalid();
- sal_uInt8 nInvFlags = 0;
+ SwPageFrameInvFlags eInvFlags = SwPageFrameInvFlags::NONE;
if(pLegacy->m_pNew && RES_ATTRSET_CHG == pLegacy->m_pNew->Which())
{
auto& rOldSetChg = *static_cast<const SwAttrSetChg*>(pLegacy->m_pOld);
@@ -527,7 +527,7 @@ void SwPageFrame::SwClientNotify(const SwModify& rModify, const SfxHint& rHint)
SwAttrSetChg aNewSet(rNewSetChg);
do
{
- UpdateAttr_(pOItem, pNItem, nInvFlags, &aOldSet, &aNewSet);
+ UpdateAttr_(pOItem, pNItem, eInvFlags, &aOldSet, &aNewSet);
pOItem = aOIter.NextItem();
pNItem = aNIter.NextItem();
} while(pNItem);
@@ -535,30 +535,30 @@ void SwPageFrame::SwClientNotify(const SwModify& rModify, const SfxHint& rHint)
SwLayoutFrame::SwClientNotify(rModify, sw::LegacyModifyHint(&aOldSet, &aNewSet));
}
else
- UpdateAttr_(pLegacy->m_pOld, pLegacy->m_pNew, nInvFlags);
+ UpdateAttr_(pLegacy->m_pOld, pLegacy->m_pNew, eInvFlags);
- if (nInvFlags == 0)
+ if (eInvFlags == SwPageFrameInvFlags::NONE)
return;
InvalidatePage( this );
- if(nInvFlags & 0x01)
+ if(eInvFlags & SwPageFrameInvFlags::InvalidatePrt)
InvalidatePrt_();
- if(nInvFlags & 0x02)
+ if(eInvFlags & SwPageFrameInvFlags::SetCompletePaint)
SetCompletePaint();
- if(nInvFlags & 0x04 && GetNext() )
+ if(eInvFlags & SwPageFrameInvFlags::InvalidateNextPos && GetNext() )
GetNext()->InvalidatePos();
- if(nInvFlags & 0x08)
+ if(eInvFlags & SwPageFrameInvFlags::PrepareHeader)
PrepareHeader();
- if(nInvFlags & 0x10)
+ if(eInvFlags & SwPageFrameInvFlags::PrepareFooter)
PrepareFooter();
- if(nInvFlags & 0x20)
- CheckGrid(nInvFlags & 0x40);
+ if(eInvFlags & SwPageFrameInvFlags::CheckGrid)
+ CheckGrid(bool(eInvFlags & SwPageFrameInvFlags::InvalidateGrid));
} else
SwFrame::SwClientNotify(rModify, rHint);
}
void SwPageFrame::UpdateAttr_( const SfxPoolItem *pOld, const SfxPoolItem *pNew,
- sal_uInt8 &rInvFlags,
+ SwPageFrameInvFlags &rInvFlags,
SwAttrSetChg *pOldSet, SwAttrSetChg *pNewSet )
{
bool bClear = true;
@@ -602,19 +602,19 @@ void SwPageFrame::UpdateAttr_( const SfxPoolItem *pOld, const SfxPoolItem *pNew,
SwLayoutFrame *pB = FindBodyCont();
assert(pB && "Page without Body.");
pB->ChgColumns( rOldCol, rNewCol );
- rInvFlags |= 0x20;
+ rInvFlags |= static_cast<SwPageFrameInvFlags>(0x20);
}
// 2. header and footer:
const SwFormatHeader &rOldH = pOldFormat->GetHeader();
const SwFormatHeader &rNewH = pNewFormat->GetHeader();
if( rOldH != rNewH )
- rInvFlags |= 0x08;
+ rInvFlags |= static_cast<SwPageFrameInvFlags>(0x08);
const SwFormatFooter &rOldF = pOldFormat->GetFooter();
const SwFormatFooter &rNewF = pNewFormat->GetFooter();
if( rOldF != rNewF )
- rInvFlags |= 0x10;
+ rInvFlags |= static_cast<SwPageFrameInvFlags>(0x10);
CheckDirChange();
[[fallthrough]];
@@ -665,9 +665,9 @@ void SwPageFrame::UpdateAttr_( const SfxPoolItem *pOld, const SfxPoolItem *pNew,
IsLeftShadowNeeded(), IsRightShadowNeeded(), bRightSidebar );
pSh->InvalidateWindows( aOldRectWithBorderAndShadow );
}
- rInvFlags |= 0x03;
+ rInvFlags |= static_cast<SwPageFrameInvFlags>(0x03);
if ( aOldPageFrameRect.Height() != getFrameArea().Height() )
- rInvFlags |= 0x04;
+ rInvFlags |= static_cast<SwPageFrameInvFlags>(0x04);
}
break;
@@ -678,19 +678,19 @@ void SwPageFrame::UpdateAttr_( const SfxPoolItem *pOld, const SfxPoolItem *pNew,
SwLayoutFrame *pB = FindBodyCont();
assert(pB); //page without body
pB->ChgColumns( *static_cast<const SwFormatCol*>(pOld), *static_cast<const SwFormatCol*>(pNew) );
- rInvFlags |= 0x22;
+ rInvFlags |= static_cast<SwPageFrameInvFlags>(0x22);
}
break;
case RES_HEADER:
- rInvFlags |= 0x08;
+ rInvFlags |= static_cast<SwPageFrameInvFlags>(0x08);
break;
case RES_FOOTER:
- rInvFlags |= 0x10;
+ rInvFlags |= static_cast<SwPageFrameInvFlags>(0x10);
break;
case RES_TEXTGRID:
- rInvFlags |= 0x60;
+ rInvFlags |= static_cast<SwPageFrameInvFlags>(0x60);
break;
case RES_FRAMEDIR :
CheckDirChange();