tdf#66822 - refactor HTML export of image bullet list

removed garbage in svg-base64, added svg close tag, fixed ul tag.
Added test case for the added code.

Change-Id: I4f07036300031e1e97b118466ebf75d8b9c46e01
Reviewed-on: https://gerrit.libreoffice.org/21218
Tested-by: jan iversen <jani@documentfoundation.org>
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: jan iversen <jani@documentfoundation.org>
This commit is contained in:
susobhang70
2016-01-07 22:08:33 +05:30
committed by jan iversen
parent 08f6107edf
commit ab14a9708d
4 changed files with 30 additions and 2 deletions

View File

@@ -364,7 +364,25 @@ bool XOutBitmap::GraphicToBase64(const Graphic& rGraphic, OUString& rOUString)
css::uno::Sequence<sal_Int8> aOStmSeq( static_cast<sal_Int8 const *>(aOStm.GetData()),aOStm.Tell() );
OUStringBuffer aStrBuffer;
::sax::Converter::encodeBase64(aStrBuffer,aOStmSeq);
rOUString = aMimeType + ";base64," + aStrBuffer.makeStringAndClear();
OUString aEncodedBase64Image = aStrBuffer.makeStringAndClear();
if( aLink.GetType() == GFX_LINK_TYPE_NATIVE_SVG )
{
sal_Int32 ite(8);
sal_Int32 nBufferLength(aOStmSeq.getLength());
const sal_Int8* pBuffer = aOStmSeq.getConstArray();
css::uno::Sequence<sal_Int8> newTempSeq = aOStmSeq; // creates new Sequence to remove front 8 bits of garbage and encodes in base64
sal_Int8 *pOutBuffer = newTempSeq.getArray();
while(ite < nBufferLength)
{
*pOutBuffer++ = pBuffer[ite];
ite++;
}
::sax::Converter::encodeBase64(aStrBuffer, newTempSeq);
aEncodedBase64Image = aStrBuffer.makeStringAndClear();
sal_Int32 SVGFixLength = aEncodedBase64Image.getLength();
aEncodedBase64Image = aEncodedBase64Image.replaceAt(SVGFixLength - 12, SVGFixLength, "") + "PC9zdmc+Cg=="; // removes rear 12 bits of garbage and adds svg closing tag in base64
}
rOUString = aMimeType + ";base64," + aEncodedBase64Image;
return true;
}

Binary file not shown.

View File

@@ -254,6 +254,16 @@ DECLARE_HTMLEXPORT_TEST(testExportInternalUrl, "tdf90905.odt")
assertXPath(pDoc, "/html/body/p[2]/a", "href", "#bookmark");
}
DECLARE_HTMLEXPORT_TEST(testExportImageBulletList, "tdf66822.odt")
{
htmlDocPtr pDoc = parseHtml(maTempFile);
CPPUNIT_ASSERT(pDoc);
// Encoded base64 SVG bullet should match and render on browser
assertXPath(pDoc, "/html/body/ul", 1);
assertXPath(pDoc, "/html/body/ul", "style", "list-style-image: url();");
}
CPPUNIT_PLUGIN_IMPLEMENT();
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */

View File

@@ -266,7 +266,7 @@ Writer& OutHTML_NumBulListStart( SwHTMLWriter& rWrt,
}
}
if (!sOut.isEmpty())
if (!sOut.isEmpty() && SVX_NUM_BITMAP != eType) // second condition to avoid adding extra ul, already done before.
rWrt.Strm().WriteOString( sOut );
if( rWrt.m_bCfgOutStyles )