Files
loongoffice/sw/source/core/attr/BorderCacheOwner.cxx
Bjoern Michaelsen d77552970a remove SwCache bookkeeping from SwModify
- only very few classes (SwNode, SwFormat) are the "owners"
  of SwBorderAttrs in the SwCache
- this bookkeeping should not be in such a fundamental class of writer
- also: encapsulate most of the interaction with the cache in the new
  sw::BorderCacheOwner. This is mostly to protect the innocent user:
  * As interacting with the SwCache directly is very errorprone, because
    its glorious idea of using void* of the "owners" as keys to the
    entries.
  * In C++, reinterpret_cast<void*>(this) might be different along the
    class heirachy. This might easily slip under the radar of a casual
    user.

Change-Id: I0da774b47885abf52f63aab8d93ebbf41dcf8040
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/110112
Tested-by: Jenkins
Reviewed-by: Bjoern Michaelsen <bjoern.michaelsen@libreoffice.org>
2021-01-29 23:10:59 +01:00

46 lines
1.1 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
#include <BorderCacheOwner.hxx>
#include <hintids.hxx>
#include <frame.hxx>
#include <swcache.hxx>
using namespace sw;
BorderCacheOwner::~BorderCacheOwner()
{
if (m_bInCache)
SwFrame::GetCache().Delete(this);
}
void BorderCacheOwner::InvalidateInSwCache(const sal_uInt16 nWhich)
{
switch (nWhich)
{
case RES_OBJECTDYING:
case RES_FMT_CHG:
case RES_ATTRSET_CHG:
case RES_UL_SPACE:
case RES_LR_SPACE:
case RES_BOX:
case RES_SHADOW:
case RES_FRM_SIZE:
case RES_KEEP:
case RES_BREAK:
if (m_bInCache)
{
SwFrame::GetCache().Delete(this);
m_bInCache = false;
}
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */