[Libreoffice-commits] core.git: sw/qa sw/source
Szymon Kłos
szymon.klos at collabora.com
Thu May 4 11:54:37 UTC 2017
sw/qa/extras/uiwriter/data/autotext-dotm.dotm |binary
sw/qa/extras/uiwriter/uiwriter.cxx | 18 ++++++++++++++++++
sw/source/filter/docx/swdocxreader.cxx | 6 +++++-
3 files changed, 23 insertions(+), 1 deletion(-)
New commits:
commit f7f7621cce0d9b91bec2807ddd0134e8b25957bb
Author: Szymon Kłos <szymon.klos at collabora.com>
Date: Thu May 4 11:57:20 2017 +0200
AutoText: fix dotm support
+ dotm files don't contain additional empty paragraphs
at the end of AutoText entry
+ added test for dotm import
Change-Id: I336145dcf8a5dd69aa9ed82318a0f05a6f62596c
Reviewed-on: https://gerrit.libreoffice.org/37230
Tested-by: Jenkins <ci at libreoffice.org>
Reviewed-by: Szymon Kłos <szymon.klos at collabora.com>
diff --git a/sw/qa/extras/uiwriter/data/autotext-dotm.dotm b/sw/qa/extras/uiwriter/data/autotext-dotm.dotm
new file mode 100644
index 000000000000..4909296d2117
Binary files /dev/null and b/sw/qa/extras/uiwriter/data/autotext-dotm.dotm differ
diff --git a/sw/qa/extras/uiwriter/uiwriter.cxx b/sw/qa/extras/uiwriter/uiwriter.cxx
index c64e8b124f2e..62958cfbac8e 100644
--- a/sw/qa/extras/uiwriter/uiwriter.cxx
+++ b/sw/qa/extras/uiwriter/uiwriter.cxx
@@ -122,6 +122,7 @@ public:
void testExportRTF();
void testDOCXAutoTextEmpty();
void testDOCXAutoTextMultiple();
+ void testDOTMAutoText();
void testTdf67238();
void testFdo75110();
void testFdo75898();
@@ -252,6 +253,7 @@ public:
CPPUNIT_TEST(testExportRTF);
CPPUNIT_TEST(testDOCXAutoTextEmpty);
CPPUNIT_TEST(testDOCXAutoTextMultiple);
+ CPPUNIT_TEST(testDOTMAutoText);
CPPUNIT_TEST(testTdf67238);
CPPUNIT_TEST(testFdo75110);
CPPUNIT_TEST(testFdo75898);
@@ -806,6 +808,22 @@ void SwUiWriterTest::testDOCXAutoTextMultiple()
CPPUNIT_ASSERT_EQUAL(OUString("complex"), rLastNode.GetTextNode()->GetText());
}
+void SwUiWriterTest::testDOTMAutoText()
+{
+ // this is dotm file difference is that in the dotm
+ // there are no empty paragraphs at the end of each entry
+ SwTextBlocks* pGlossary = readDOCXAutotext("autotext-dotm.dotm");
+
+ SwDoc* pDoc = pGlossary->GetDoc();
+ CPPUNIT_ASSERT(pDoc != nullptr);
+
+ // check if content is correct
+ SwNodeIndex aDocEnd(pDoc->GetNodes().GetEndOfContent());
+ SwNodeIndex aStart(*aDocEnd.GetNode().StartOfSectionNode(), 1);
+ SwNode& rNode = aStart.GetNode();
+ CPPUNIT_ASSERT_EQUAL(OUString("paragraph"), rNode.GetTextNode()->GetText());
+}
+
void SwUiWriterTest::testFdo74981()
{
// create a document with an input field
diff --git a/sw/source/filter/docx/swdocxreader.cxx b/sw/source/filter/docx/swdocxreader.cxx
index 7558b4dfba10..b72253c0b57a 100644
--- a/sw/source/filter/docx/swdocxreader.cxx
+++ b/sw/source/filter/docx/swdocxreader.cxx
@@ -139,7 +139,11 @@ bool SwDOCXReader::MakeEntries( SwDoc *pD, SwTextBlocks &rBlocks )
aPam.SetMark();
{
SwNodeIndex& rIdx = aPam.GetPoint()->nNode;
- rIdx = aStart.GetNode().EndOfSectionIndex() - 2;
+ rIdx = aStart.GetNode().EndOfSectionIndex() - 1;
+ // don't add extra empty text node if exist (.dotx but not .dotm)
+ if( rIdx.GetNode().GetTextNode() &&
+ rIdx.GetNode().GetTextNode()->GetText().isEmpty() )
+ rIdx = aStart.GetNode().EndOfSectionIndex() - 2;
if( ( nullptr == ( pCNd = rIdx.GetNode().GetContentNode() ) ) )
{
++rIdx;
More information about the Libreoffice-commits
mailing list