diff options
author | Patrick Jaap <patrick.jaap@tu-dresden.de> | 2019-01-23 10:01:36 +0100 |
---|---|---|
committer | Miklos Vajna <vmiklos@collabora.com> | 2019-02-11 18:08:41 +0100 |
commit | 7ed962571df02d1d7b286e7af534fadd717a8003 (patch) | |
tree | a7eec19f106b3a3a1c589311ed8516fc1c5a558c | |
parent | Resolves: tdf#123320 non-existing drop caps char style (diff) | |
download | core-7ed962571df02d1d7b286e7af534fadd717a8003.tar.gz core-7ed962571df02d1d7b286e7af534fadd717a8003.zip |
tdf#122878: enable wrap for flys in footer
This patch removes the check for a footer node,
intoduced by
23f698ecee033612ac3a9f5cfd7674b08bb3ccd1
preserving the behaviour for the connected bug reports
i13832 and i24135.
Without this check, the wraping becomes enabled for footer
objects, too.
With this enhencement, the commits
7df33caac85ac90c26e97dedbc201f46dc9e4cb4
d3db6ff43a531ecf1afc858a0a8832353d091644
are directly affected and therefore the unit test is edited.
Change-Id: I093add9e251ac97859a66cb8b8563010ef734c2d
Reviewed-on: https://gerrit.libreoffice.org/67069
Tested-by: Jenkins
Reviewed-by: Miklos Vajna <vmiklos@collabora.com>
(cherry picked from commit 8e3afdb5989d571410350f1d43fcf26492a4eaff)
Reviewed-on: https://gerrit.libreoffice.org/67671
-rw-r--r-- | sw/qa/extras/layout/data/tdf116989.docx | bin | 15538 -> 0 bytes | |||
-rw-r--r-- | sw/qa/extras/layout/data/tdf122878.docx | bin | 0 -> 17740 bytes | |||
-rw-r--r-- | sw/qa/extras/layout/layout.cxx | 14 | ||||
-rw-r--r-- | sw/source/core/text/txtfly.cxx | 1 | ||||
-rw-r--r-- | writerfilter/source/dmapper/DomainMapperTableHandler.cxx | 3 |
5 files changed, 8 insertions, 10 deletions
diff --git a/sw/qa/extras/layout/data/tdf116989.docx b/sw/qa/extras/layout/data/tdf116989.docx Binary files differdeleted file mode 100644 index 498b60dbf345..000000000000 --- a/sw/qa/extras/layout/data/tdf116989.docx +++ /dev/null diff --git a/sw/qa/extras/layout/data/tdf122878.docx b/sw/qa/extras/layout/data/tdf122878.docx Binary files differnew file mode 100644 index 000000000000..f42e92ea2641 --- /dev/null +++ b/sw/qa/extras/layout/data/tdf122878.docx diff --git a/sw/qa/extras/layout/layout.cxx b/sw/qa/extras/layout/layout.cxx index 3b470ff8c2a6..8c132693e68b 100644 --- a/sw/qa/extras/layout/layout.cxx +++ b/sw/qa/extras/layout/layout.cxx @@ -64,7 +64,7 @@ public: void testTdf120287(); void testTdf120287b(); void testTdf120287c(); - void testTdf116989(); + void testTdf122878(); void testTdf115094(); CPPUNIT_TEST_SUITE(SwLayoutWriter); @@ -102,7 +102,7 @@ public: CPPUNIT_TEST(testTdf120287); CPPUNIT_TEST(testTdf120287b); CPPUNIT_TEST(testTdf120287c); - CPPUNIT_TEST(testTdf116989); + CPPUNIT_TEST(testTdf122878); CPPUNIT_TEST(testTdf115094); CPPUNIT_TEST_SUITE_END(); @@ -2652,17 +2652,17 @@ void SwLayoutWriter::testTdf120287c() assertXPath(pXmlDoc, "/root/page/body/txt[1]/LineBreak", 3); } -void SwLayoutWriter::testTdf116989() +void SwLayoutWriter::testTdf122878() { - createDoc("tdf116989.docx"); + createDoc("tdf122878.docx"); xmlDocPtr pXmlDoc = parseLayoutDump(); // FIXME: the XPath should be adjusted when the proper floating table would be imported const sal_Int32 nTblTop - = getXPath(pXmlDoc, "/root/page[1]/footer/tab/infos/bounds", "top").toInt32(); + = getXPath(pXmlDoc, "/root/page[1]/footer/txt/anchored/fly/tab/infos/bounds", "top") + .toInt32(); const sal_Int32 nFirstPageParaCount = getXPathContent(pXmlDoc, "count(/root/page[1]/body/txt)").toInt32(); - // FIXME: should be exactly 30, when proper floating tables in footers are supported - CPPUNIT_ASSERT_GREATEREQUAL(sal_Int32(30), nFirstPageParaCount); + CPPUNIT_ASSERT_EQUAL(sal_Int32(30), nFirstPageParaCount); for (sal_Int32 i = 1; i <= nFirstPageParaCount; ++i) { const OString xPath = "/root/page[1]/body/txt[" + OString::number(i) + "]/infos/bounds"; diff --git a/sw/source/core/text/txtfly.cxx b/sw/source/core/text/txtfly.cxx index 31f04c376233..e16cd878ce75 100644 --- a/sw/source/core/text/txtfly.cxx +++ b/sw/source/core/text/txtfly.cxx @@ -803,7 +803,6 @@ bool SwTextFly::GetTop( const SwAnchoredObject* _pAnchoredObj, // #i13832#, #i24135# wrap around objects in page header ( !pIDSA->get(DocumentSettingId::USE_FORMER_TEXT_WRAPPING) && nullptr != ( pHeader = pTmp->FindFooterOrHeader() ) && - !pHeader->IsFooterFrame() && m_pCurrFrame->IsInDocBody()))) { if( pHeader || RndStdIds::FLY_AT_FLY == rNewA.GetAnchorId() ) diff --git a/writerfilter/source/dmapper/DomainMapperTableHandler.cxx b/writerfilter/source/dmapper/DomainMapperTableHandler.cxx index 04fd361b7e36..01c7f59fc314 100644 --- a/writerfilter/source/dmapper/DomainMapperTableHandler.cxx +++ b/writerfilter/source/dmapper/DomainMapperTableHandler.cxx @@ -1176,8 +1176,7 @@ void DomainMapperTableHandler::endTable(unsigned int nestedTableLevel, bool bTab m_aTableProperties->getValue(TablePropertyMap::TABLE_WIDTH_TYPE, nTableWidthType); if (m_rDMapper_Impl.GetSectionContext() && nestedTableLevel <= 1 && !m_rDMapper_Impl.IsInHeaderFooter()) m_rDMapper_Impl.m_aPendingFloatingTables.emplace_back(xStart, xEnd, comphelper::containerToSequence(aFrameProperties), nTableWidth, nTableWidthType); - else if (!m_rDMapper_Impl.IsInFooter()) // FIXME: tdf#116989 floating objects anchored - //to footer cannot have proper wrapping + else { // m_xText points to the body text, get the current xText from m_rDMapper_Impl, in case e.g. we would be in a header. uno::Reference<text::XTextAppendAndConvert> xTextAppendAndConvert(m_rDMapper_Impl.GetTopTextAppend(), uno::UNO_QUERY); |