[Libreoffice-commits] core.git: Branch 'libreoffice-4-4' - filter/qa filter/source
Caolán McNamara
caolanm at redhat.com
Tue Aug 25 01:07:54 PDT 2015
filter/qa/cppunit/data/pbm/fail/crash-1.pbm | 6 ++++++
filter/source/graphicfilter/ipbm/ipbm.cxx | 11 ++++++-----
2 files changed, 12 insertions(+), 5 deletions(-)
New commits:
commit 84df27c093b4a52df92bef570cde96dcebdf35c9
Author: Caolán McNamara <caolanm at redhat.com>
Date: Mon Aug 24 20:43:37 2015 +0100
in reality we are limited to max sal_Int32 here
so accept that and test if the values were accepted or limited
Change-Id: Iaed5ebc2f12b52055506147c71117a2ad88d28ac
(cherry picked from commit 0a76c1fd6875bd094ebe2bfbed3d01c98dc0c19e)
Reviewed-on: https://gerrit.libreoffice.org/17973
Reviewed-by: David Tardon <dtardon at redhat.com>
Tested-by: David Tardon <dtardon at redhat.com>
diff --git a/filter/qa/cppunit/data/pbm/fail/crash-1.pbm b/filter/qa/cppunit/data/pbm/fail/crash-1.pbm
new file mode 100644
index 0000000..9ddcddf
--- /dev/null
+++ b/filter/qa/cppunit/data/pbm/fail/crash-1.pbm
@@ -0,0 +1,6 @@
+P3
+30000000000000000000000000000000 1
+255
+103 79 59
+ 95 7P 55
+ 87 67 51
diff --git a/filter/source/graphicfilter/ipbm/ipbm.cxx b/filter/source/graphicfilter/ipbm/ipbm.cxx
index 720bc9f..231b0e6 100644
--- a/filter/source/graphicfilter/ipbm/ipbm.cxx
+++ b/filter/source/graphicfilter/ipbm/ipbm.cxx
@@ -37,7 +37,7 @@ private:
sal_uLong mnMode; // 0->PBM, 1->PGM, 2->PPM
Bitmap maBmp;
BitmapWriteAccess* mpAcc;
- sal_uLong mnWidth, mnHeight; // dimensions in pixel
+ sal_Int32 mnWidth, mnHeight; // dimensions in pixel
sal_uLong mnCol;
sal_uLong mnMaxVal; // max value in the <missing comment>
bool ImplCallback( sal_uInt16 nPercent );
@@ -99,7 +99,7 @@ bool PBMReader::ReadPBM(Graphic & rGraphic )
if ( ( mbStatus = ImplReadHeader() ) == false )
return false;
- if ( ( mnMaxVal == 0 ) || ( mnWidth == 0 ) || ( mnHeight == 0 ) )
+ if ( ( mnMaxVal == 0 ) || ( mnWidth <= 0 ) || ( mnHeight <= 0 ) )
return false;
// 0->PBM, 1->PGM, 2->PPM
@@ -107,7 +107,8 @@ bool PBMReader::ReadPBM(Graphic & rGraphic )
{
case 0 :
maBmp = Bitmap( Size( mnWidth, mnHeight ), 1 );
- if ( ( mpAcc = maBmp.AcquireWriteAccess() ) == 0 )
+ mpAcc = maBmp.AcquireWriteAccess();
+ if (!mpAcc || mpAcc->Width() != mnWidth || mpAcc->Height() != mnHeight)
return false;
mpAcc->SetPaletteEntryCount( 2 );
mpAcc->SetPaletteColor( 0, BitmapColor( 0xff, 0xff, 0xff ) );
@@ -258,8 +259,8 @@ bool PBMReader::ImplReadBody()
bool bPara, bFinished = false;
sal_uInt8 nDat = 0, nCount;
sal_uLong nGrey, nRGB[3];
- sal_uLong nWidth = 0;
- sal_uLong nHeight = 0;
+ sal_Int32 nWidth = 0;
+ sal_Int32 nHeight = 0;
if ( mbRaw )
{
More information about the Libreoffice-commits
mailing list