summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--vcl/source/gdi/pdfwriter_impl.cxx258
1 files changed, 151 insertions, 107 deletions
diff --git a/vcl/source/gdi/pdfwriter_impl.cxx b/vcl/source/gdi/pdfwriter_impl.cxx
index 9250204581bc..7fc600c40d0f 100644
--- a/vcl/source/gdi/pdfwriter_impl.cxx
+++ b/vcl/source/gdi/pdfwriter_impl.cxx
@@ -1795,9 +1795,6 @@ bool PDFWriterImpl::updateObject( sal_Int32 n )
return aError == osl::File::E_None;
}
-#define CHECK_RETURN( x ) if( !(x) ) return 0
-#define CHECK_RETURN2( x ) if( !(x) ) return
-
sal_Int32 PDFWriterImpl::emitStructParentTree( sal_Int32 nObject )
{
if( nObject > 0 )
@@ -1815,8 +1812,10 @@ sal_Int32 PDFWriterImpl::emitStructParentTree( sal_Int32 nObject )
+ "\n" );
}
aLine.append( "]>>\nendobj\n\n" );
- CHECK_RETURN( updateObject( nObject ) );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!updateObject(nObject))
+ return 0;
+ if (!writeBuffer(aLine))
+ return 0;
}
return nObject;
}
@@ -1852,8 +1851,8 @@ sal_Int32 PDFWriterImpl::emitStructIDTree(sal_Int32 const nObject)
}
buf.append("] >>\nendobj\n\n");
- CHECK_RETURN( updateObject(nObject) );
- CHECK_RETURN( writeBuffer(buf) );
+ if (!updateObject(nObject)) return 0;
+ if (!writeBuffer(buf)) return 0;
return nObject;
}
@@ -2132,7 +2131,8 @@ sal_Int32 PDFWriterImpl::emitStructure( PDFStructureElement& rEle )
if( rEle.m_nOwnElement == rEle.m_nParentElement )
{
nParentTree = createObject();
- CHECK_RETURN( nParentTree );
+ if (!nParentTree)
+ return 0;
aLine.append( "/StructTreeRoot\n"
"/ParentTree "
+ OString::number(nParentTree)
@@ -2279,11 +2279,11 @@ sal_Int32 PDFWriterImpl::emitStructure( PDFStructureElement& rEle )
}
aLine.append( ">>\nendobj\n\n" );
- CHECK_RETURN( updateObject( rEle.m_nObject ) );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!updateObject(rEle.m_nObject)) return 0;
+ if (!writeBuffer(aLine)) return 0;
- CHECK_RETURN( emitStructParentTree( nParentTree ) );
- CHECK_RETURN( emitStructIDTree(nIDTree) );
+ if (!emitStructParentTree(nParentTree)) return 0;
+ if (!emitStructIDTree(nIDTree)) return 0;
return rEle.m_nObject;
}
@@ -2403,7 +2403,8 @@ sal_Int32 PDFWriterImpl::emitBuildinFont(const pdf::BuildinFontFace* pFD, sal_In
if( nFontObject <= 0 )
nFontObject = createObject();
- CHECK_RETURN( updateObject( nFontObject ) );
+ if (!updateObject(nFontObject))
+ return 0;
aLine.append(
OString::number(nFontObject)
+ " 0 obj\n"
@@ -2413,7 +2414,8 @@ sal_Int32 PDFWriterImpl::emitBuildinFont(const pdf::BuildinFontFace* pFD, sal_In
if( rBuildinFont.m_eCharSet == RTL_TEXTENCODING_MS_1252 )
aLine.append( "/Encoding/WinAnsiEncoding\n" );
aLine.append( ">>\nendobj\n\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine))
+ return 0;
return nFontObject;
}
@@ -2913,8 +2915,8 @@ sal_Int32 PDFWriterImpl::createToUnicodeCMap( sal_uInt8 const * pEncoding,
return 0;
sal_Int32 nStream = createObject();
- CHECK_RETURN( updateObject( nStream ) );
-
+ if (!updateObject(nStream))
+ return 0;
OStringBuffer aContents( 1024 );
aContents.append(
"/CIDInit/ProcSet findresource begin\n"
@@ -2988,21 +2990,21 @@ sal_Int32 PDFWriterImpl::createToUnicodeCMap( sal_uInt8 const * pEncoding,
else
aLine.append( aContents.getLength() );
aLine.append( ">>\nstream\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine)) return 0;
checkAndEnableStreamEncryption( nStream );
if (!g_bDebugDisableCompression)
{
- CHECK_RETURN( writeBufferBytes( aStream.GetData(), nLen ) );
+ if(!writeBufferBytes(aStream.GetData(), nLen)) return 0;
}
else
{
- CHECK_RETURN( writeBuffer( aContents ) );
+ if (!writeBuffer(aContents)) return 0;
}
disableStreamEncryption();
aLine.setLength( 0 );
aLine.append( "\nendstream\n"
"endobj\n\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine)) return 0;
return nStream;
}
@@ -3023,7 +3025,7 @@ sal_Int32 PDFWriterImpl::emitFontDescriptor( const vcl::font::PhysicalFontFace*
nFontFlags |= (1 << 1);
sal_Int32 nFontDescriptor = createObject();
- CHECK_RETURN( updateObject( nFontDescriptor ) );
+ if (!updateObject(nFontDescriptor)) return 0;
aLine.setLength( 0 );
aLine.append(
OString::number(nFontDescriptor)
@@ -3081,7 +3083,7 @@ sal_Int32 PDFWriterImpl::emitFontDescriptor( const vcl::font::PhysicalFontFace*
}
aLine.append( ">>\n"
"endobj\n\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine)) return 0;
return nFontDescriptor;
}
@@ -3322,25 +3324,30 @@ bool PDFWriterImpl::emitFonts()
sal_Int32 PDFWriterImpl::emitResources()
{
// emit shadings
- if( ! m_aGradients.empty() )
- CHECK_RETURN( emitGradients() );
+ if (!m_aGradients.empty())
+ {
+ if (!emitGradients()) return 0;
+ }
// emit tilings
- if( ! m_aTilings.empty() )
- CHECK_RETURN( emitTilings() );
+ if (!m_aTilings.empty())
+ {
+ if(!emitTilings()) return 0;
+ }
// emit font dict
- CHECK_RETURN( emitFonts() );
+ if (!emitFonts()) return 0;
// emit Resource dict
OStringBuffer aLine( 512 );
sal_Int32 nResourceDict = getResourceDictObj();
- CHECK_RETURN( updateObject( nResourceDict ) );
+ if (!updateObject(nResourceDict))
+ return 0;
aLine.setLength( 0 );
aLine.append( OString::number(nResourceDict)
+ " 0 obj\n" );
m_aGlobalResourceDict.append( aLine, getFontDictObject() );
aLine.append( "endobj\n\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine)) return 0;
return nResourceDict;
}
@@ -3427,7 +3434,8 @@ sal_Int32 PDFWriterImpl::emitOutline()
PDFOutlineEntry& rItem = m_aOutline[i];
OStringBuffer aLine( 1024 );
- CHECK_RETURN( updateObject( rItem.m_nObject ) );
+ if (!updateObject(rItem.m_nObject))
+ return 0;
aLine.append( OString::number(rItem.m_nObject)
+ " 0 obj\n"
"<<" );
@@ -3474,15 +3482,13 @@ sal_Int32 PDFWriterImpl::emitOutline()
}
}
aLine.append( ">>\nendobj\n\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine))
+ return 0;
}
return m_aOutline[0].m_nObject;
}
-#undef CHECK_RETURN
-#define CHECK_RETURN( x ) if( !x ) return false
-
bool PDFWriterImpl::appendDest( sal_Int32 nDestID, OStringBuffer& rBuffer )
{
if( nDestID < 0 || o3tl::make_unsigned(nDestID) >= m_aDests.size() )
@@ -3578,13 +3584,16 @@ bool PDFWriterImpl::emitScreenAnnotations()
aLine.append("<< /Type /EmbeddedFile /Length ");
aLine.append(static_cast<sal_Int64>(aMemoryStream.GetSize()));
aLine.append(" >>\nstream\n");
- CHECK_RETURN(writeBuffer(aLine));
+ if (!writeBuffer(aLine))
+ return false;
aLine.setLength(0);
- CHECK_RETURN(writeBufferBytes(aMemoryStream.GetData(), aMemoryStream.GetSize()));
+ if (!writeBufferBytes(aMemoryStream.GetData(), aMemoryStream.GetSize()))
+ return false;
aLine.append("\nendstream\nendobj\n\n");
- CHECK_RETURN(writeBuffer(aLine));
+ if (!writeBuffer(aLine))
+ return false;
aLine.setLength(0);
}
@@ -3674,7 +3683,8 @@ bool PDFWriterImpl::emitScreenAnnotations()
aLine.append("/P "
+ OString::number(m_aPages[rScreen.m_nPage].m_nPageObject)
+ " 0 R\n>>\nendobj\n\n");
- CHECK_RETURN(writeBuffer(aLine));
+ if (!writeBuffer(aLine))
+ return false;
}
return true;
@@ -3907,7 +3917,8 @@ we check in the following sequence:
aLine.append( rLink.m_nStructParent );
}
aLine.append( ">>\nendobj\n\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine))
+ return false;
}
return true;
@@ -4656,7 +4667,8 @@ bool PDFWriterImpl::emitAppearances( PDFWidget& rWidget, OStringBuffer& rAnnotDi
sal_Int64 nStreamLen = pAppearanceStream->TellEnd();
pAppearanceStream->Seek( STREAM_SEEK_TO_BEGIN );
sal_Int32 nObject = createObject();
- CHECK_RETURN( updateObject( nObject ) );
+ if (!updateObject(nObject))
+ return false;
if (g_bDebugDisableCompression)
{
emitComment( "PDFWriterImpl::emitAppearances" );
@@ -4681,11 +4693,11 @@ bool PDFWriterImpl::emitAppearances( PDFWidget& rWidget, OStringBuffer& rAnnotDi
if( bDeflate )
aLine.append( "/Filter/FlateDecode\n" );
aLine.append( ">>\nstream\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine)) return false;
checkAndEnableStreamEncryption( nObject );
- CHECK_RETURN( writeBufferBytes( pAppearanceStream->GetData(), nStreamLen ) );
+ if (!writeBufferBytes( pAppearanceStream->GetData(), nStreamLen)) return false;
disableStreamEncryption();
- CHECK_RETURN( writeBuffer( "\nendstream\nendobj\n\n" ) );
+ if (!writeBuffer("\nendstream\nendobj\n\n")) return false;
if( bUseSubDict )
{
@@ -5104,12 +5116,12 @@ bool PDFWriterImpl::emitWidgetAnnotations()
aLine.append( ">>\n" );
}
- CHECK_RETURN( emitAppearances( rWidget, aLine ) );
+ if (!emitAppearances(rWidget, aLine)) return false;
aLine.append( ">>\n"
"endobj\n\n" );
- CHECK_RETURN( updateObject( rWidget.m_nObject ) );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!updateObject(rWidget.m_nObject)) return false;
+ if (!writeBuffer(aLine)) return false;
}
return true;
}
@@ -5119,10 +5131,10 @@ bool PDFWriterImpl::emitAnnotations()
if( m_aPages.empty() )
return false;
- CHECK_RETURN( emitLinkAnnotations() );
- CHECK_RETURN(emitScreenAnnotations());
- CHECK_RETURN( emitNoteAnnotations() );
- CHECK_RETURN( emitWidgetAnnotations() );
+ if (!emitLinkAnnotations()) return false;
+ if (!emitScreenAnnotations()) return false;
+ if (!emitNoteAnnotations()) return false;
+ if (!emitWidgetAnnotations()) return false;
return true;
}
@@ -5174,7 +5186,7 @@ bool PDFWriterImpl::emitEmbeddedFiles()
appendObjectReference(nParamsObject, aLine);
aLine.append(">>\nstream\n");
checkAndEnableStreamEncryption(rEmbeddedFile.m_nObject);
- CHECK_RETURN(writeBuffer(aLine));
+ if (!writeBuffer(aLine)) return false;
disableStreamEncryption();
aLine.setLength(0);
@@ -5182,7 +5194,8 @@ bool PDFWriterImpl::emitEmbeddedFiles()
if (!rEmbeddedFile.m_aDataContainer.isEmpty())
{
nSize = rEmbeddedFile.m_aDataContainer.getSize();
- CHECK_RETURN(writeBufferBytes(rEmbeddedFile.m_aDataContainer.getData(), rEmbeddedFile.m_aDataContainer.getSize()));
+ if (!writeBufferBytes(rEmbeddedFile.m_aDataContainer.getData(), rEmbeddedFile.m_aDataContainer.getSize()))
+ return false;
}
else if (rEmbeddedFile.m_pStream)
{
@@ -5194,7 +5207,7 @@ bool PDFWriterImpl::emitEmbeddedFiles()
nSize = sal_Int64(getCurrentFilePosition() - nBegin);
}
aLine.append("\nendstream\nendobj\n\n");
- CHECK_RETURN(writeBuffer(aLine));
+ if (!writeBuffer(aLine)) return false;
aLine.setLength(0);
if (!updateObject(nSizeObject))
@@ -5222,9 +5235,6 @@ bool PDFWriterImpl::emitEmbeddedFiles()
return true;
}
-#undef CHECK_RETURN
-#define CHECK_RETURN( x ) if( !x ) return false
-
bool PDFWriterImpl::emitCatalog()
{
// build page tree
@@ -5234,7 +5244,7 @@ bool PDFWriterImpl::emitCatalog()
sal_Int32 nTreeNode = createObject();
// emit global resource dictionary (page emit needs it)
- CHECK_RETURN( emitResources() );
+ if (!emitResources()) return false;
// emit all pages
for (auto & page : m_aPages)
@@ -5291,11 +5301,11 @@ bool PDFWriterImpl::emitCatalog()
aLine.append( static_cast<sal_Int32>(m_aPages.size()) );
aLine.append( ">>\n"
"endobj\n\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine)) return false;
// emit annotation objects
- CHECK_RETURN( emitAnnotations() );
- CHECK_RETURN( emitEmbeddedFiles() );
+ if (!emitAnnotations()) return false;
+ if (!emitEmbeddedFiles()) return false;
// emit attached files
for (auto & rAttachedFile : m_aDocumentAttachedFiles)
@@ -5325,7 +5335,7 @@ bool PDFWriterImpl::emitCatalog()
appendObjectReference(rAttachedFile.mnEmbeddedFileObjectId, aLine);
aLine.append(">>");
aLine.append(">>\nendobj\n\n");
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine)) return false;
}
// emit Catalog
@@ -5585,7 +5595,8 @@ bool PDFWriterImpl::emitSignature()
aLine.append("<</Contents <" );
sal_uInt64 nOffset = ~0U;
- CHECK_RETURN( (osl::File::E_None == m_aFile.getPos(nOffset) ) );
+ if (osl::File::E_None != m_aFile.getPos(nOffset))
+ return false;
m_nSignatureContentOffset = nOffset + aLine.getLength();
@@ -5651,25 +5662,29 @@ bool PDFWriterImpl::finalizeSignature()
// 1- calculate last ByteRange value
sal_uInt64 nOffset = ~0U;
- CHECK_RETURN( (osl::File::E_None == m_aFile.getPos(nOffset) ) );
+ if (osl::File::E_None != m_aFile.getPos(nOffset))
+ return false;
sal_Int64 nLastByteRangeNo = nOffset - (m_nSignatureContentOffset + MAX_SIGNATURE_CONTENT_LENGTH + 1);
// 2- overwrite the value to the m_nSignatureLastByteRangeNoOffset position
sal_uInt64 nWritten = 0;
- CHECK_RETURN( (osl::File::E_None == m_aFile.setPos(osl_Pos_Absolut, m_nSignatureLastByteRangeNoOffset) ) );
+ if (osl::File::E_None != m_aFile.setPos(osl_Pos_Absolut, m_nSignatureLastByteRangeNoOffset))
+ return false;
OString aByteRangeNo = OString::number( nLastByteRangeNo ) + " ]";
if (m_aFile.write(aByteRangeNo.getStr(), aByteRangeNo.getLength(), nWritten) != osl::File::E_None)
{
- CHECK_RETURN( (osl::File::E_None == m_aFile.setPos(osl_Pos_Absolut, nOffset)) );
+ if (osl::File::E_None != m_aFile.setPos(osl_Pos_Absolut, nOffset))
+ return false;
return false;
}
// 3- create the PKCS#7 object using NSS
// Prepare buffer and calculate PDF file digest
- CHECK_RETURN( (osl::File::E_None == m_aFile.setPos(osl_Pos_Absolut, 0)) );
+ if (osl::File::E_None != m_aFile.setPos(osl_Pos_Absolut, 0))
+ return false;
std::unique_ptr<char[]> buffer1(new char[m_nSignatureContentOffset + 1]);
sal_uInt64 bytesRead1;
@@ -5709,7 +5724,8 @@ bool PDFWriterImpl::finalizeSignature()
// Set file pointer to the m_nSignatureContentOffset, we're ready to overwrite PKCS7 object
nWritten = 0;
- CHECK_RETURN( (osl::File::E_None == m_aFile.setPos(osl_Pos_Absolut, m_nSignatureContentOffset)) );
+ if (osl::File::E_None != m_aFile.setPos(osl_Pos_Absolut, m_nSignatureContentOffset))
+ return false;
m_aFile.write(aCMSHexBuffer.getStr(), aCMSHexBuffer.getLength(), nWritten);
return osl::File::E_None == m_aFile.setPos(osl_Pos_Absolut, nOffset);
@@ -6057,8 +6073,10 @@ bool PDFWriterImpl::emitTrailer()
// emit xref table
// remember start
sal_uInt64 nXRefOffset = 0;
- CHECK_RETURN( (osl::File::E_None == m_aFile.getPos(nXRefOffset )) );
- CHECK_RETURN( writeBuffer( "xref\n" ) );
+ if (osl::File::E_None != m_aFile.getPos(nXRefOffset))
+ return false;
+ if (!writeBuffer("xref\n"))
+ return false;
sal_Int32 nObjects = m_aObjects.size();
OStringBuffer aLine;
@@ -6066,7 +6084,8 @@ bool PDFWriterImpl::emitTrailer()
aLine.append( static_cast<sal_Int32>(nObjects+1) );
aLine.append( "\n" );
aLine.append( "0000000000 65535 f \n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine))
+ return false;
for( sal_Int32 i = 0; i < nObjects; i++ )
{
@@ -6077,7 +6096,8 @@ bool PDFWriterImpl::emitTrailer()
aLine.append( aOffset );
aLine.append( " 00000 n \n" );
SAL_WARN_IF( aLine.getLength() != 20, "vcl.pdfwriter", "invalid xref entry" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine))
+ return false;
}
// prepare document checksum
@@ -6278,7 +6298,8 @@ bool PDFWriterImpl::emit()
#endif
// emit catalog
- CHECK_RETURN( emitCatalog() );
+ if (!emitCatalog())
+ return false;
#if HAVE_FEATURE_NSS
if (m_nSignatureObject != -1) // if document is signed, emit sigdict
@@ -6292,7 +6313,8 @@ bool PDFWriterImpl::emit()
#endif
// emit trailer
- CHECK_RETURN( emitTrailer() );
+ if (!emitTrailer())
+ return false;
#if HAVE_FEATURE_NSS
if (m_nSignatureObject != -1) // finalize the signature
@@ -8755,7 +8777,8 @@ void PDFWriterImpl::drawPixel( const Point& rPoint, const Color& rColor )
void PDFWriterImpl::writeTransparentObject( TransparencyEmit& rObject )
{
- CHECK_RETURN2( updateObject( rObject.m_nObject ) );
+ if (!updateObject(rObject.m_nObject))
+ return;
bool bFlateFilter = compressStream( rObject.m_pContentStream.get() );
sal_uInt64 nSize = rObject.m_pContentStream->TellEnd();
@@ -8765,7 +8788,8 @@ void PDFWriterImpl::writeTransparentObject( TransparencyEmit& rObject )
emitComment( "PDFWriterImpl::writeTransparentObject" );
}
OStringBuffer aLine( 512 );
- CHECK_RETURN2( updateObject( rObject.m_nObject ) );
+ if (!updateObject(rObject.m_nObject))
+ return;
aLine.append( rObject.m_nObject );
aLine.append( " 0 obj\n"
"<</Type/XObject\n"
@@ -8796,15 +8820,18 @@ void PDFWriterImpl::writeTransparentObject( TransparencyEmit& rObject )
aLine.append( "/Filter/FlateDecode\n" );
aLine.append( ">>\n"
"stream\n" );
- CHECK_RETURN2( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine))
+ return;
checkAndEnableStreamEncryption( rObject.m_nObject );
- CHECK_RETURN2( writeBufferBytes( rObject.m_pContentStream->GetData(), nSize ) );
+ if (!writeBufferBytes(rObject.m_pContentStream->GetData(), nSize))
+ return;
disableStreamEncryption();
aLine.setLength( 0 );
aLine.append( "\n"
"endstream\n"
"endobj\n\n" );
- CHECK_RETURN2( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine))
+ return;
// write ExtGState dict for this XObject
aLine.setLength( 0 );
@@ -8829,8 +8856,8 @@ void PDFWriterImpl::writeTransparentObject( TransparencyEmit& rObject )
aLine.append( ">>\n"
"endobj\n\n" );
- CHECK_RETURN2( updateObject( rObject.m_nExtGStateObject ) );
- CHECK_RETURN2( writeBuffer( aLine ) );
+ if (!updateObject(rObject.m_nExtGStateObject)) return;
+ if (!writeBuffer(aLine)) return;
}
bool PDFWriterImpl::writeGradientFunction( GradientEmit const & rObject )
@@ -8842,7 +8869,8 @@ bool PDFWriterImpl::writeGradientFunction( GradientEmit const & rObject )
// [t=0:colorEnd, t=0.5:colorStart, t=1:colorEnd]
// * other styles: function shading with aSize.Width() * aSize.Height() samples
sal_Int32 nFunctionObject = createObject();
- CHECK_RETURN( updateObject( nFunctionObject ) );
+ if (!updateObject(nFunctionObject))
+ return false;
ScopedVclPtrInstance< VirtualDevice > aDev;
aDev->SetOutputSizePixel( rObject.m_aSize );
@@ -8905,10 +8933,12 @@ bool PDFWriterImpl::writeGradientFunction( GradientEmit const & rObject )
aLine.append( " 0 R\n"
">>\n"
"stream\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine))
+ return false;
sal_uInt64 nStartStreamPos = 0;
- CHECK_RETURN( (osl::File::E_None == m_aFile.getPos(nStartStreamPos)) );
+ if (osl::File::E_None != m_aFile.getPos(nStartStreamPos))
+ return false;
checkAndEnableStreamEncryption( nFunctionObject );
beginCompression();
@@ -8919,19 +8949,22 @@ bool PDFWriterImpl::writeGradientFunction( GradientEmit const & rObject )
aCol[0] = rObject.m_aGradient.GetEndColor().GetRed();
aCol[1] = rObject.m_aGradient.GetEndColor().GetGreen();
aCol[2] = rObject.m_aGradient.GetEndColor().GetBlue();
- CHECK_RETURN( writeBufferBytes( aCol, 3 ) );
+ if (!writeBufferBytes(aCol, 3))
+ return false;
[[fallthrough]];
case css::awt::GradientStyle_LINEAR:
{
aCol[0] = rObject.m_aGradient.GetStartColor().GetRed();
aCol[1] = rObject.m_aGradient.GetStartColor().GetGreen();
aCol[2] = rObject.m_aGradient.GetStartColor().GetBlue();
- CHECK_RETURN( writeBufferBytes( aCol, 3 ) );
+ if (!writeBufferBytes(aCol, 3))
+ return false;
aCol[0] = rObject.m_aGradient.GetEndColor().GetRed();
aCol[1] = rObject.m_aGradient.GetEndColor().GetGreen();
aCol[2] = rObject.m_aGradient.GetEndColor().GetBlue();
- CHECK_RETURN( writeBufferBytes( aCol, 3 ) );
+ if (!writeBufferBytes(aCol, 3))
+ return false;
break;
}
default:
@@ -8943,7 +8976,8 @@ bool PDFWriterImpl::writeGradientFunction( GradientEmit const & rObject )
aCol[0] = aColor.GetRed();
aCol[1] = aColor.GetGreen();
aCol[2] = aColor.GetBlue();
- CHECK_RETURN( writeBufferBytes( aCol, 3 ) );
+ if (!writeBufferBytes(aCol, 3))
+ return false;
}
}
}
@@ -8951,22 +8985,23 @@ bool PDFWriterImpl::writeGradientFunction( GradientEmit const & rObject )
disableStreamEncryption();
sal_uInt64 nEndStreamPos = 0;
- CHECK_RETURN( (osl::File::E_None == m_aFile.getPos(nEndStreamPos)) );
+ if (osl::File::E_None != m_aFile.getPos(nEndStreamPos))
+ return false;
aLine.setLength( 0 );
aLine.append( "\nendstream\nendobj\n\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine)) return false;
// write stream length
- CHECK_RETURN( updateObject( nStreamLengthObject ) );
+ if (!updateObject(nStreamLengthObject)) return false;
aLine.setLength( 0 );
aLine.append( nStreamLengthObject );
aLine.append( " 0 obj\n" );
aLine.append( static_cast<sal_Int64>(nEndStreamPos-nStartStreamPos) );
aLine.append( "\nendobj\n\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine)) return false;
- CHECK_RETURN( updateObject( rObject.m_nObject ) );
+ if (!updateObject(rObject.m_nObject)) return false;
aLine.setLength( 0 );
aLine.append( rObject.m_nObject );
aLine.append( " 0 obj\n");
@@ -9055,8 +9090,8 @@ void PDFWriterImpl::writeJPG( const JPGEmit& rObject )
return;
}
- CHECK_RETURN2( rObject.m_pStream );
- CHECK_RETURN2( updateObject( rObject.m_nObject ) );
+ if (!rObject.m_pStream) return;
+ if (!updateObject(rObject.m_nObject)) return;
sal_uInt64 nLength = rObject.m_pStream->TellEnd();
rObject.m_pStream->Seek( STREAM_SEEK_TO_BEGIN );
@@ -9101,14 +9136,17 @@ void PDFWriterImpl::writeJPG( const JPGEmit& rObject )
aLine.append( " 0 R " );
}
aLine.append( ">>\nstream\n" );
- CHECK_RETURN2( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine))
+ return;
checkAndEnableStreamEncryption( rObject.m_nObject );
- CHECK_RETURN2( writeBufferBytes( rObject.m_pStream->GetData(), nLength ) );
+ if (!writeBufferBytes(rObject.m_pStream->GetData(), nLength))
+ return;
disableStreamEncryption();
aLine.setLength( 0 );
- CHECK_RETURN2( writeBuffer( "\nendstream\nendobj\n\n" ) );
+ if (!writeBuffer("\nendstream\nendobj\n\n"))
+ return;
if( nMaskObject )
{
@@ -9474,7 +9512,8 @@ void PDFWriterImpl::writeReferenceXObject(const ReferenceXObjectEmit& rEmit)
disableStreamEncryption();
aLine.append("\nendstream\nendobj\n\n");
- CHECK_RETURN2(writeBuffer(aLine));
+ if (!writeBuffer(aLine))
+ return;
}
bool PDFWriterImpl::writeBitmapObject( const BitmapEmit& rObject, bool bMask )
@@ -9485,7 +9524,8 @@ bool PDFWriterImpl::writeBitmapObject( const BitmapEmit& rObject, bool bMask )
return true;
}
- CHECK_RETURN( updateObject( rObject.m_nObject ) );
+ if (!updateObject(rObject.m_nObject))
+ return false;
Bitmap aBitmap;
bool bWriteMask = false;
@@ -9673,9 +9713,10 @@ bool PDFWriterImpl::writeBitmapObject( const BitmapEmit& rObject, bool bMask )
aLine.append( ">>\n"
"stream\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine)) return false;
sal_uInt64 nStartPos = 0;
- CHECK_RETURN( (osl::File::E_None == m_aFile.getPos(nStartPos)) );
+ if (osl::File::E_None != m_aFile.getPos(nStartPos))
+ return false;
checkAndEnableStreamEncryption( rObject.m_nObject );
if (!g_bDebugDisableCompression && nBitsPerComponent == 1)
@@ -9692,7 +9733,8 @@ bool PDFWriterImpl::writeBitmapObject( const BitmapEmit& rObject, bool bMask )
for( tools::Long i = 0; i < pAccess->Height(); i++ )
{
- CHECK_RETURN( writeBufferBytes( pAccess->GetScanline( i ), nScanLineBytes ) );
+ if (!writeBufferBytes(pAccess->GetScanline(i), nScanLineBytes))
+ return false;
}
}
else
@@ -9708,7 +9750,8 @@ bool PDFWriterImpl::writeBitmapObject( const BitmapEmit& rObject, bool bMask )
xCol[3*x+1] = aColor.GetGreen();
xCol[3*x+2] = aColor.GetBlue();
}
- CHECK_RETURN(writeBufferBytes(xCol.get(), nScanLineBytes));
+ if (!writeBufferBytes(xCol.get(), nScanLineBytes))
+ return false;
}
}
endCompression();
@@ -9716,17 +9759,18 @@ bool PDFWriterImpl::writeBitmapObject( const BitmapEmit& rObject, bool bMask )
disableStreamEncryption();
sal_uInt64 nEndPos = 0;
- CHECK_RETURN( (osl::File::E_None == m_aFile.getPos(nEndPos)) );
+ if (osl::File::E_None != m_aFile.getPos(nEndPos))
+ return false;
aLine.setLength( 0 );
aLine.append( "\nendstream\nendobj\n\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
- CHECK_RETURN( updateObject( nStreamLengthObject ) );
+ if (!writeBuffer(aLine)) return false;
+ if (!updateObject(nStreamLengthObject)) return false;
aLine.setLength( 0 );
aLine.append( nStreamLengthObject );
aLine.append( " 0 obj\n" );
aLine.append( static_cast<sal_Int64>(nEndPos-nStartPos) );
aLine.append( "\nendobj\n\n" );
- CHECK_RETURN( writeBuffer( aLine ) );
+ if (!writeBuffer(aLine)) return false;
if( nMaskObject )
{