summaryrefslogtreecommitdiff
path: root/svtools
diff options
context:
space:
mode:
authorCaolán McNamara <caolanm@redhat.com>2012-07-26 16:35:43 +0100
committerPetr Mladek <pmladek@suse.cz>2012-07-27 10:41:51 +0200
commit6ef2f2503b5a2d52c2ee9cb1b9415acc696fca41 (patch)
treec0c07f86204505e40c462fb907c3b728c56bdd8f /svtools
parenta7f82f201e1b2653ac03e1833e273c6752868641 (diff)
discard broken embedded object previews
Change-Id: I4f632545d383c4887342aa2959987d4ac3638eb4 Signed-off-by: Petr Mladek <pmladek@suse.cz>
Diffstat (limited to 'svtools')
-rw-r--r--svtools/source/misc/embedhlp.cxx25
1 files changed, 17 insertions, 8 deletions
diff --git a/svtools/source/misc/embedhlp.cxx b/svtools/source/misc/embedhlp.cxx
index 6325a76c4ec3..135ad3055500 100644
--- a/svtools/source/misc/embedhlp.cxx
+++ b/svtools/source/misc/embedhlp.cxx
@@ -560,16 +560,25 @@ SvStream* EmbeddedObjectRef::GetGraphicStream( sal_Bool bUpdate ) const
{
const sal_Int32 nConstBufferSize = 32000;
SvStream *pStream = new SvMemoryStream( 32000, 32000 );
- sal_Int32 nRead=0;
- uno::Sequence < sal_Int8 > aSequence ( nConstBufferSize );
- do
+ try
+ {
+ sal_Int32 nRead=0;
+ uno::Sequence < sal_Int8 > aSequence ( nConstBufferSize );
+ do
+ {
+ nRead = xStream->readBytes ( aSequence, nConstBufferSize );
+ pStream->Write( aSequence.getConstArray(), nRead );
+ }
+ while ( nRead == nConstBufferSize );
+ pStream->Seek(0);
+ return pStream;
+ }
+ catch (const uno::Exception& ex)
{
- nRead = xStream->readBytes ( aSequence, nConstBufferSize );
- pStream->Write( aSequence.getConstArray(), nRead );
+ SAL_WARN("svtools", "discarding broken embedded object preview: " << ex.Message);
+ delete pStream;
+ xStream.clear();
}
- while ( nRead == nConstBufferSize );
- pStream->Seek(0);
- return pStream;
}
}