Kaydet (Commit) 57cc8b2e authored tarafından Samuel Mehrbrodt's avatar Samuel Mehrbrodt

Fix svg to base64 conversion

This reverts part of ab14a970 which had
a questionable fix by unconditionally removing the first 8 bytes of the svg
which led to svgs starting with

rsion="1.0" encoding="utf-8"?>

instead of

<?xml version="1.0" encoding="utf-8"?>

Change-Id: I8c4d78db1794473d20ddd77019ae81b88be0bb03
Reviewed-on: https://gerrit.libreoffice.org/54550Tested-by: 's avatarJenkins <ci@libreoffice.org>
Reviewed-by: 's avatarSamuel Mehrbrodt <Samuel.Mehrbrodt@cib.de>
üst 13596e70
......@@ -393,25 +393,7 @@ 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;
::comphelper::Base64::encode(aStrBuffer,aOStmSeq);
OUString aEncodedBase64Image = aStrBuffer.makeStringAndClear();
if( aLink.GetType() == GfxLinkType::NativeSvg )
{
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++;
}
::comphelper::Base64::encode(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;
rOUString = aMimeType + ";base64," + aStrBuffer.makeStringAndClear();
return true;
}
......
......@@ -280,7 +280,7 @@ DECLARE_HTMLEXPORT_TEST(testExportImageBulletList, "tdf66822.odt")
// 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();");
assertXPath(pDoc, "/html/body/ul", "style", "list-style-image: url();");
}
DECLARE_HTMLEXPORT_TEST(testTdf83890, "tdf83890.odt")
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment