summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuboš Luňák <l.lunak@collabora.com>2014-08-17 18:12:16 +0200
committerLuboš Luňák <l.lunak@collabora.com>2014-08-17 18:16:42 +0200
commit4a1888a97eab4ead2e0bec76cd1cba410a8e7e13 (patch)
treedb5259d355d07eb7aab107df7ab9c5b7683da34a
parent1bc196059faf2fc53bf0ffce2f634b20da4a4a16 (diff)
fix reading a .doc that has frame anchored to the end of page (bnc#787942)
MSWord, unlike Writer, can anchor even to a page break (i.e. after the last paragraph). When this document was read, what happended was: - the last paragraph was read and the current position PaM was set to point after it - frame was read and anchored to the PaM - page break was read, making everything following be moved to the next page; including whatever ended up at the PaM position Handle this by checking for this case and inserting an extra empty paragraph before the break. This shouldn't affect layout of the page itself anyway, since the break should leave room for it (and MSWord shows a page break there if control characters are enabled, so there is room). Change-Id: Ia2a13bf5cf1c959b5aa228254365019a00a22679
-rw-r--r--sw/qa/extras/ww8import/data/bnc787942.docbin0 -> 24064 bytes
-rw-r--r--sw/qa/extras/ww8import/ww8import.cxx7
-rw-r--r--sw/source/filter/ww8/ww8par.hxx2
-rw-r--r--sw/source/filter/ww8/ww8par6.cxx14
4 files changed, 22 insertions, 1 deletions
diff --git a/sw/qa/extras/ww8import/data/bnc787942.doc b/sw/qa/extras/ww8import/data/bnc787942.doc
new file mode 100644
index 000000000000..06b2c39f2f84
--- /dev/null
+++ b/sw/qa/extras/ww8import/data/bnc787942.doc
Binary files differ
diff --git a/sw/qa/extras/ww8import/ww8import.cxx b/sw/qa/extras/ww8import/ww8import.cxx
index fe4a8fcca05a..463c5aee19e0 100644
--- a/sw/qa/extras/ww8import/ww8import.cxx
+++ b/sw/qa/extras/ww8import/ww8import.cxx
@@ -504,6 +504,13 @@ DECLARE_WW8IMPORT_TEST(testFloatingTableSectionColumns, "floating-table-section-
CPPUNIT_ASSERT( tableWidth.toInt32() > 10000 );
}
+DECLARE_WW8IMPORT_TEST(testBnc787942, "bnc787942.doc")
+{
+ // The frame ended up on the second page instead of first.
+ parseDump("/root/page[1]/body/txt[4]/anchored");
+}
+
+
CPPUNIT_PLUGIN_IMPLEMENT();
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/sw/source/filter/ww8/ww8par.hxx b/sw/source/filter/ww8/ww8par.hxx
index fc0734a5cd64..0f5096961dea 100644
--- a/sw/source/filter/ww8/ww8par.hxx
+++ b/sw/source/filter/ww8/ww8par.hxx
@@ -1383,6 +1383,8 @@ private:
// a document position recorded the after-position of TOC section, managed by Read_F_TOX() and End_Field()
SwPaM* mpPosAfterTOC;
+ boost::scoped_ptr< SwPosition > lastAnchorPos;
+
bool mbCareFirstParaEndInToc;
bool mbCareLastParaEndInToc;
cp_set maTOXEndCps;
diff --git a/sw/source/filter/ww8/ww8par6.cxx b/sw/source/filter/ww8/ww8par6.cxx
index 0a0d14b5975e..fb351947be25 100644
--- a/sw/source/filter/ww8/ww8par6.cxx
+++ b/sw/source/filter/ww8/ww8par6.cxx
@@ -795,6 +795,18 @@ void wwSectionManager::CreateSep(const long nTxtPos, bool /*bMustHaveBreak*/)
if (!pSep)
return;
+ if (!maSegments.empty() && mrReader.lastAnchorPos.get() && *mrReader.lastAnchorPos == *mrReader.pPaM->GetPoint())
+ {
+ bool insert = true;
+ SwPaM pam( *mrReader.lastAnchorPos );
+ if( pam.Move(fnMoveBackward, fnGoNode))
+ if( SwTxtNode* txtNode = pam.GetPoint()->nNode.GetNode().GetTxtNode())
+ if( txtNode->Len() == 0 )
+ insert = false;
+ if( insert )
+ mrReader.AppendTxtNode(*mrReader.pPaM->GetPoint());
+ }
+
ww::WordVersion eVer = mrReader.GetFib().GetFIBVersion();
// M.M. Create a linked section if the WkbPLCF
@@ -1736,7 +1748,6 @@ WW8SwFlyPara::WW8SwFlyPara( SwPaM& rPaM,
const sal_Int32 nIniFlyDx,
const sal_Int32 nIniFlyDy )
{
- (void) rPaM;
(void) nPgLeft;
memset( this, 0, sizeof( WW8SwFlyPara ) ); // Initialisieren
@@ -1804,6 +1815,7 @@ WW8SwFlyPara::WW8SwFlyPara( SwPaM& rPaM,
//#i53725# - absolute positioned objects have to be
// anchored at-paragraph to assure its correct anchor position.
eAnchor = FLY_AT_PARA;
+ rIo.lastAnchorPos.reset( new SwPosition(*rPaM.GetPoint()));
switch (nYBind)
{