diff options
author | Justin Luth <justin.luth@collabora.com> | 2021-03-25 14:52:01 +0200 |
---|---|---|
committer | Miklos Vajna <vmiklos@collabora.com> | 2021-03-30 12:50:43 +0200 |
commit | 8ef5d0f724b75ef62c20996271e9a6997ff6c3dd (patch) | |
tree | ef40c6fbd82f0fac445d758a7ada82fb1dafebbe /sw/source | |
parent | c6c128b947c8864d6bbd4b0abd1abad16cd0d67e (diff) |
tdf#140336 ms formats export: export NONE background for ParaBackColor
This fixes a regression from LO 4.2 with tdf#88583's
commit 60cdeb2d441a6bf5c55f511f574b2b9dd598fbb8.
It isn't only SOLID that needs to be written,
otherwise there is no way to cancel an inherited background.
And only write out a SOLID if one is specified here.
Do not duplicate a style's SOLID fill into every
sub-style and paragraph. (Yikes)
This fixes DOCX (seriously) and DOC (de-duplication),
but not RTF (which doesn't write out transparent brushes).
Surprisingly, I didn't find any examples
where a NONE was specified that matched an inherited NONE.
But it IS important (probably because of a bug) and also smart
to determine and avoid writing NONE if there is no inheritance.
So then, there is no reason not to do the last step of
checking if the current brush matches the inherited brush.
[That also paves the way for a potential follow-up commit
to try deduplicating SOLID fills as well,
although that likely adds grabbag complications into the mix.
And perhaps deduplication isn't desired either,
in case the user actually wanted to duplicate
(if that is even possible under UI conditions).]
Change-Id: I8958a68c779057d9fc5da74eca50fcf5b41d8b52
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/113105
Tested-by: Jenkins
Reviewed-by: Justin Luth <justin_luth@sil.org>
Reviewed-by: Miklos Vajna <vmiklos@collabora.com>
Diffstat (limited to 'sw/source')
-rw-r--r-- | sw/source/filter/ww8/attributeoutputbase.hxx | 2 | ||||
-rw-r--r-- | sw/source/filter/ww8/docxattributeoutput.cxx | 5 | ||||
-rw-r--r-- | sw/source/filter/ww8/docxattributeoutput.hxx | 2 | ||||
-rw-r--r-- | sw/source/filter/ww8/ww8atr.cxx | 21 |
4 files changed, 22 insertions, 8 deletions
diff --git a/sw/source/filter/ww8/attributeoutputbase.hxx b/sw/source/filter/ww8/attributeoutputbase.hxx index e102b3f7012b..cea47b8e3c60 100644 --- a/sw/source/filter/ww8/attributeoutputbase.hxx +++ b/sw/source/filter/ww8/attributeoutputbase.hxx @@ -666,7 +666,7 @@ public: ( ww8::WW8TableNodeInfoInner const * pTableTextNodeInfoInner, tools::Long& rPageSize, bool& rRelBoxSize ); - virtual void MaybeOutputBrushItem(SfxItemSet const&) { } + virtual bool MaybeOutputBrushItem(SfxItemSet const&) { return false; } /// Exports the definition (image, size) of a single numbering picture bullet. virtual void BulletDefinition(int /*nId*/, const Graphic& /*rGraphic*/, Size /*aSize*/) {} diff --git a/sw/source/filter/ww8/docxattributeoutput.cxx b/sw/source/filter/ww8/docxattributeoutput.cxx index f4688e5f6a01..7e67ffda5590 100644 --- a/sw/source/filter/ww8/docxattributeoutput.cxx +++ b/sw/source/filter/ww8/docxattributeoutput.cxx @@ -6308,14 +6308,14 @@ oox::drawingml::DrawingML& DocxAttributeOutput::GetDrawingML() return m_rDrawingML; } -void DocxAttributeOutput::MaybeOutputBrushItem(SfxItemSet const& rSet) +bool DocxAttributeOutput::MaybeOutputBrushItem(SfxItemSet const& rSet) { const XFillStyleItem* pXFillStyleItem(rSet.GetItem<XFillStyleItem>(XATTR_FILLSTYLE)); if ((pXFillStyleItem && pXFillStyleItem->GetValue() != drawing::FillStyle_NONE) || !m_rExport.SdrExporter().getDMLTextFrameSyntax()) { - return; + return false; } // sw text frames are opaque by default, even with fill none! @@ -6327,6 +6327,7 @@ void DocxAttributeOutput::MaybeOutputBrushItem(SfxItemSet const& rSet) pClone->Put(aSolid); std::unique_ptr<SvxBrushItem> const pBrush(getSvxBrushItemFromSourceSet(*pClone, RES_BACKGROUND)); FormatBackground(*pBrush); + return true; } namespace { diff --git a/sw/source/filter/ww8/docxattributeoutput.hxx b/sw/source/filter/ww8/docxattributeoutput.hxx index 565741bd0afe..7a2826e81ea9 100644 --- a/sw/source/filter/ww8/docxattributeoutput.hxx +++ b/sw/source/filter/ww8/docxattributeoutput.hxx @@ -1031,7 +1031,7 @@ public: virtual css::uno::Reference<css::text::XTextFrame> GetUnoTextFrame( css::uno::Reference<css::drawing::XShape> xShape) override; virtual oox::drawingml::DrawingML& GetDrawingML() override; - virtual void MaybeOutputBrushItem(SfxItemSet const&) override; + virtual bool MaybeOutputBrushItem(SfxItemSet const&) override; void BulletDefinition(int nId, const Graphic& rGraphic, Size aSize) override; diff --git a/sw/source/filter/ww8/ww8atr.cxx b/sw/source/filter/ww8/ww8atr.cxx index 5d3f4b8ae0d2..95b7bab8034b 100644 --- a/sw/source/filter/ww8/ww8atr.cxx +++ b/sw/source/filter/ww8/ww8atr.cxx @@ -352,7 +352,7 @@ void MSWordExportBase::OutputItemSet( const SfxItemSet& rSet, bool bPapFormat, b ExportPoolItemsToCHP(aItems, nScript, nullptr); if ( bPapFormat ) { - AttrOutput().MaybeOutputBrushItem(rSet); + const bool bAlreadyOutputBrushItem = AttrOutput().MaybeOutputBrushItem(rSet); for ( const auto& rItem : aItems ) { @@ -365,12 +365,25 @@ void MSWordExportBase::OutputItemSet( const SfxItemSet& rSet, bool bPapFormat, b } // Has to be called after RES_PARATR_GRABBAG is processed. - const XFillStyleItem* pXFillStyleItem(rSet.GetItem<XFillStyleItem>(XATTR_FILLSTYLE)); - if (pXFillStyleItem && pXFillStyleItem->GetValue() == drawing::FillStyle_SOLID && !rSet.HasItem(RES_BACKGROUND)) + const XFillStyleItem* pFill(rSet.GetItem<XFillStyleItem>(XATTR_FILLSTYLE, false)); + if (!bAlreadyOutputBrushItem && pFill + && (pFill->GetValue() == drawing::FillStyle_SOLID || pFill->GetValue() == drawing::FillStyle_NONE) + && !rSet.GetItem(RES_BACKGROUND, false)) { + const bool bFillStyleNone = pFill->GetValue() == drawing::FillStyle_NONE; + // No need to write out a NONE background if it can't inherit something else, or if it already inherits a NONE. + std::unique_ptr<SvxBrushItem> pInherited; + if (bFillStyleNone) + { + if ( auto pNd = dynamic_cast<const SwContentNode*>(m_pOutFormatNode)) //paragraph + pInherited = getSvxBrushItemFromSourceSet(static_cast<SwTextFormatColl&>(pNd->GetAnyFormatColl()).GetAttrSet(), RES_BACKGROUND); + else if (m_bStyDef && m_pCurrentStyle && m_pCurrentStyle->DerivedFrom()) //style + pInherited = getSvxBrushItemFromSourceSet(m_pCurrentStyle->DerivedFrom()->GetAttrSet(), RES_BACKGROUND); + } // Construct an SvxBrushItem, as expected by the exporters. std::unique_ptr<SvxBrushItem> aBrush(getSvxBrushItemFromSourceSet(rSet, RES_BACKGROUND)); - AttrOutput().OutputItem(*aBrush); + if (!bFillStyleNone || (pInherited && *pInherited != *aBrush)) + AttrOutput().OutputItem(*aBrush); } #if 0 else |