101 lines
3.0 KiB
Diff
101 lines
3.0 KiB
Diff
Patch from OpenSUSE
|
|
https://build.opensuse.org/package/view_file/LibreOffice:Factory/libreoffice/poppler-22-04-0.patch?expand=1&rev=45e176f964509ebe3560d0dbf1ec8be9
|
|
Index: libreoffice-7.3.3.1/sdext/source/pdfimport/xpdfwrapper/pdfioutdev_gpl.cxx
|
|
===================================================================
|
|
--- libreoffice-7.3.3.1.orig/sdext/source/pdfimport/xpdfwrapper/pdfioutdev_gpl.cxx
|
|
+++ libreoffice-7.3.3.1/sdext/source/pdfimport/xpdfwrapper/pdfioutdev_gpl.cxx
|
|
@@ -474,12 +474,21 @@ int PDFOutDev::parseFont( long long nNew
|
|
{
|
|
// TODO(P3): Unfortunately, need to read stream twice, since
|
|
// we must write byte count to stdout before
|
|
+#if POPPLER_CHECK_VERSION(22, 04, 0) // readEmbFontFile signature changed
|
|
+ auto pBuf = gfxFont->readEmbFontFile( m_pDoc->getXRef());
|
|
+ if ( pBuf )
|
|
+ {
|
|
+ aNewFont.isEmbedded = true;
|
|
+ nSize = pBuf->size();
|
|
+ }
|
|
+#else
|
|
char* pBuf = gfxFont->readEmbFontFile( m_pDoc->getXRef(), &nSize );
|
|
if( pBuf )
|
|
{
|
|
aNewFont.isEmbedded = true;
|
|
gfree(pBuf);
|
|
}
|
|
+#endif
|
|
}
|
|
|
|
m_aFontMap[ nNewId ] = aNewFont;
|
|
@@ -492,21 +501,35 @@ void PDFOutDev::writeFontFile( GfxFont*
|
|
return;
|
|
|
|
int nSize = 0;
|
|
+#if POPPLER_CHECK_VERSION(22, 04, 0) // readEmbFontFile signature changed
|
|
+ auto pBuf = gfxFont->readEmbFontFile( m_pDoc->getXRef());
|
|
+ if ( !pBuf )
|
|
+ return;
|
|
+ nSize = pBuf->size();
|
|
+#else
|
|
char* pBuf = gfxFont->readEmbFontFile( m_pDoc->getXRef(), &nSize );
|
|
if( !pBuf )
|
|
return;
|
|
+#endif
|
|
|
|
// ---sync point--- see SYNC STREAMS above
|
|
fflush(stdout);
|
|
|
|
+#if POPPLER_CHECK_VERSION(22, 04, 0) // readEmbFontFile signature changed
|
|
+ if( fwrite(pBuf->data(), sizeof(unsigned char), nSize, g_binary_out) != static_cast<size_t>(nSize) )
|
|
+ {
|
|
+#else
|
|
if( fwrite(pBuf, sizeof(char), nSize, g_binary_out) != static_cast<size_t>(nSize) )
|
|
{
|
|
gfree(pBuf);
|
|
+#endif
|
|
exit(1); // error
|
|
}
|
|
// ---sync point--- see SYNC STREAMS above
|
|
fflush(g_binary_out);
|
|
+#if !POPPLER_CHECK_VERSION(22, 04, 0) // readEmbFontFile signature changed
|
|
gfree(pBuf);
|
|
+#endif
|
|
}
|
|
|
|
#if POPPLER_CHECK_VERSION(0, 83, 0)
|
|
@@ -759,7 +782,11 @@ void PDFOutDev::updateFont(GfxState *sta
|
|
{
|
|
assert(state);
|
|
|
|
+#if POPPLER_CHECK_VERSION(22, 04, 0)
|
|
+ std::shared_ptr<GfxFont> gfxFont = state->getFont();
|
|
+#else
|
|
GfxFont *gfxFont = state->getFont();
|
|
+#endif
|
|
if( !gfxFont )
|
|
return;
|
|
|
|
@@ -776,7 +803,11 @@ void PDFOutDev::updateFont(GfxState *sta
|
|
m_aFontMap.find( fontID );
|
|
if( it == m_aFontMap.end() )
|
|
{
|
|
+#if POPPLER_CHECK_VERSION(22, 04, 0)
|
|
+ nEmbedSize = parseFont( fontID, gfxFont.get(), state );
|
|
+#else
|
|
nEmbedSize = parseFont( fontID, gfxFont, state );
|
|
+#endif
|
|
it = m_aFontMap.find( fontID );
|
|
}
|
|
|
|
@@ -806,7 +837,11 @@ void PDFOutDev::updateFont(GfxState *sta
|
|
|
|
if (nEmbedSize)
|
|
{
|
|
+#if POPPLER_CHECK_VERSION(22, 04, 0)
|
|
+ writeFontFile(gfxFont.get());
|
|
+#else
|
|
writeFontFile(gfxFont);
|
|
+#endif
|
|
}
|
|
}
|
|
|