X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/79fa23744b2c622ebe9ff89a3ee8c8ec8017ee3b..42a3aedbcee394eba28bc8bd1e9400f1efc42ef8:/src/common/imagbmp.cpp diff --git a/src/common/imagbmp.cpp b/src/common/imagbmp.cpp index c9b3a3a554..71b32dcaef 100644 --- a/src/common/imagbmp.cpp +++ b/src/common/imagbmp.cpp @@ -750,7 +750,7 @@ bool wxBMPHandler::DoLoadDib(wxImage * image, int width, int height, image->SetMask(FALSE); - return stream.IsOk(); + return ( stream.LastError() == wxSTREAM_NO_ERROR || stream.LastError() == wxSTREAM_EOF ); } bool wxBMPHandler::LoadDib(wxImage *image, wxInputStream& stream, @@ -879,8 +879,6 @@ bool wxBMPHandler::DoCanRead(wxInputStream& stream) if ( !stream.Read(hdr, WXSIZEOF(hdr)) ) return FALSE; - stream.SeekI(-WXSIZEOF(hdr), wxFromCurrent); - // do we have the BMP file signature? return hdr[0] == 'B' && hdr[1] == 'M'; } @@ -1200,13 +1198,13 @@ int wxICOHandler::GetImageCount(wxInputStream& stream) bool wxICOHandler::DoCanRead(wxInputStream& stream) { + stream.SeekI(0); unsigned char hdr[4]; - off_t iPos = stream.TellI(); - stream.SeekI (0); - stream.Read(hdr, 4); - stream.SeekI(iPos); - //hdr[2] is one for an icon and two for a cursor - return (hdr[0] == '\0' && hdr[1] == '\0' && hdr[2] == '\1' && hdr[3] == '\0'); + if ( !stream.Read(hdr, WXSIZEOF(hdr)) ) + return FALSE; + + // hdr[2] is one for an icon and two for a cursor + return hdr[0] == '\0' && hdr[1] == '\0' && hdr[2] == '\1' && hdr[3] == '\0'; } @@ -1219,13 +1217,13 @@ IMPLEMENT_DYNAMIC_CLASS(wxCURHandler, wxICOHandler) bool wxCURHandler::DoCanRead(wxInputStream& stream) { + stream.SeekI(0); unsigned char hdr[4]; - off_t iPos = stream.TellI(); - stream.SeekI (0); - stream.Read(hdr, 4); - stream.SeekI(iPos); - //hdr[2] is one for an icon and two for a cursor - return (hdr[0] == '\0' && hdr[1] == '\0' && hdr[2] == '\2' && hdr[3] == '\0'); + if ( !stream.Read(hdr, WXSIZEOF(hdr)) ) + return FALSE; + + // hdr[2] is one for an icon and two for a cursor + return hdr[0] == '\0' && hdr[1] == '\0' && hdr[2] == '\2' && hdr[3] == '\0'; } //----------------------------------------------------------------------------- @@ -1260,6 +1258,8 @@ bool wxANIHandler::LoadFile(wxImage *image, wxInputStream& stream, // we always have a data size stream.Read(&datalen, 4); datalen = wxINT32_SWAP_ON_BE(datalen) ; + //data should be padded to make even number of bytes + if (datalen % 2 == 1) datalen ++ ; //now either data or a FCC if ( (FCC1 == *riff32) || (FCC1 == *list32) ) { @@ -1298,7 +1298,9 @@ bool wxANIHandler::DoCanRead(wxInputStream& stream) wxInt32 *anih32 = (wxInt32 *) anihtxt; stream.SeekI(0); - stream.Read(&FCC1, 4); + if ( !stream.Read(&FCC1, 4) ) + return FALSE; + if ( FCC1 != *riff32 ) return FALSE; @@ -1310,6 +1312,8 @@ bool wxANIHandler::DoCanRead(wxInputStream& stream) // we always have a data size: stream.Read(&datalen, 4); datalen = wxINT32_SWAP_ON_BE(datalen) ; + //data should be padded to make even number of bytes + if (datalen % 2 == 1) datalen ++ ; // now either data or a FCC: if ( (FCC1 == *riff32) || (FCC1 == *list32) ) { @@ -1354,6 +1358,8 @@ int wxANIHandler::GetImageCount(wxInputStream& stream) // we always have a data size: stream.Read(&datalen, 4); datalen = wxINT32_SWAP_ON_BE(datalen) ; + //data should be padded to make even number of bytes + if (datalen % 2 == 1) datalen ++ ; // now either data or a FCC: if ( (FCC1 == *riff32) || (FCC1 == *list32) ) {