diff options
author | Jan Holesovsky <kendy@collabora.com> | 2017-07-28 14:15:07 +0200 |
---|---|---|
committer | Jan Holesovsky <kendy@collabora.com> | 2017-07-28 14:38:35 +0200 |
commit | 587d6e13df7bb9c8f78ce605ebb8f8fd34b85a2c (patch) | |
tree | a42386ffc682d8b0c6ae79dafe67b1f0dc096208 | |
parent | 74c8d4a8128056a35fb2c67b7f663b259665e193 (diff) |
sw htmlexport: Avoid unnecessary conversion to base64 + unit tests.
Change-Id: Ifdd86590f4258c84006f7ca94ea06058e600db1e
-rw-r--r-- | sw/qa/extras/htmlexport/htmlexport.cxx | 21 | ||||
-rw-r--r-- | sw/source/filter/html/htmlflywriter.cxx | 20 |
2 files changed, 31 insertions, 10 deletions
diff --git a/sw/qa/extras/htmlexport/htmlexport.cxx b/sw/qa/extras/htmlexport/htmlexport.cxx index 63435cee780a..1ea03e880de7 100644 --- a/sw/qa/extras/htmlexport/htmlexport.cxx +++ b/sw/qa/extras/htmlexport/htmlexport.cxx @@ -46,6 +46,8 @@ private: { if (getTestName().indexOf("SkipImages") != -1) setFilterOptions("SkipImages"); + else if (getTestName().indexOf("EmbedImages") != -1) + setFilterOptions("EmbedImages"); else setFilterOptions(""); @@ -285,6 +287,25 @@ DECLARE_HTMLEXPORT_TEST(testExtbChars, "extb.html") CPPUNIT_ASSERT_EQUAL(aExpected, xTextRange2->getString()); } +DECLARE_HTMLEXPORT_TEST(testNormalImageExport, "textAndImage.docx") +{ + htmlDocPtr pDoc = parseHtml(maTempFile); + CPPUNIT_ASSERT(pDoc); + + assertXPath(pDoc, "/html/body", 1); + OUString imgSrc = getXPath(pDoc, "/html/body/p/img", "src"); + CPPUNIT_ASSERT(imgSrc.endsWith(".png")); +} + +DECLARE_HTMLEXPORT_TEST(testEmbedImagesEnabled, "textAndImage.docx") +{ + htmlDocPtr pDoc = parseHtml(maTempFile); + CPPUNIT_ASSERT(pDoc); + + assertXPath(pDoc, "/html/body", 1); + assertXPath(pDoc, "/html/body/p/img", "src", ""); +} + CPPUNIT_PLUGIN_IMPLEMENT(); /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sw/source/filter/html/htmlflywriter.cxx b/sw/source/filter/html/htmlflywriter.cxx index 725d4db2c2fd..b02c441a31e3 100644 --- a/sw/source/filter/html/htmlflywriter.cxx +++ b/sw/source/filter/html/htmlflywriter.cxx @@ -1358,19 +1358,19 @@ Writer& OutHTML_Image( Writer& rWrt, const SwFrameFormat &rFrameFormat, aHtml.start(OOO_STRING_SVTOOLS_HTML_image); - OUString aGraphicInBase64; - if ( !XOutBitmap::GraphicToBase64(rGraphic, aGraphicInBase64) ) - { - rHTMLWrt.m_nWarn = ErrCode(WARN_SWG_POOR_LOAD | WARN_SW_WRITE_BASE); - } - OStringBuffer sBuffer; if(rHTMLWrt.mbEmbedImages) { - sBuffer.append(OOO_STRING_SVTOOLS_HTML_O_data); - sBuffer.append(":"); - sBuffer.append(OUStringToOString(aGraphicInBase64, RTL_TEXTENCODING_UTF8)); - aHtml.attribute(OOO_STRING_SVTOOLS_HTML_O_src, sBuffer.makeStringAndClear().getStr()); + OUString aGraphicInBase64; + if (XOutBitmap::GraphicToBase64(rGraphic, aGraphicInBase64)) + { + sBuffer.append(OOO_STRING_SVTOOLS_HTML_O_data); + sBuffer.append(":"); + sBuffer.append(OUStringToOString(aGraphicInBase64, RTL_TEXTENCODING_UTF8)); + aHtml.attribute(OOO_STRING_SVTOOLS_HTML_O_src, sBuffer.makeStringAndClear().getStr()); + } + else + rHTMLWrt.m_nWarn = ErrCode(WARN_SWG_POOR_LOAD | WARN_SW_WRITE_BASE); } else { |