From 03c0fc660317ee8ddbd80c5f2564bce68c0d9593 Mon Sep 17 00:00:00 2001 From: =?utf8?q?V=C3=A1clav=20Slav=C3=ADk?= Date: Mon, 29 Apr 2002 18:38:17 +0000 Subject: [PATCH] fixed wxZipInputStream::OnSysSeek wrt memory requirements and malloc(0) (will backport to 2.2) git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@15305 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- src/common/zipstrm.cpp | 37 ++++++++++++++++++++++++++----------- 1 file changed, 26 insertions(+), 11 deletions(-) diff --git a/src/common/zipstrm.cpp b/src/common/zipstrm.cpp index fb191d35c3..9fbff10320 100644 --- a/src/common/zipstrm.cpp +++ b/src/common/zipstrm.cpp @@ -24,6 +24,7 @@ #include "wx/stream.h" #include "wx/wfstream.h" #include "wx/zipstrm.h" +#include "wx/utils.h" /* Not the right solution (paths in makefiles) but... */ #ifdef __BORLANDC__ @@ -106,10 +107,14 @@ size_t wxZipInputStream::OnSysRead(void *buffer, size_t bufsize) off_t wxZipInputStream::OnSysSeek(off_t seek, wxSeekMode mode) { + // NB: since ZIP files don't natively support seeking, we have to + // implement a brute force workaround -- reading all the data + // between current and the new position (or between beginning of + // the file and new position...) + off_t nextpos; - void *buf; - switch (mode) + switch ( mode ) { case wxFromCurrent : nextpos = seek + m_Pos; break; case wxFromStart : nextpos = seek; break; @@ -117,23 +122,33 @@ off_t wxZipInputStream::OnSysSeek(off_t seek, wxSeekMode mode) default : nextpos = m_Pos; break; /* just to fool compiler, never happens */ } - // cheated seeking : - if (nextpos > m_Pos) + size_t toskip = 0; + if ( nextpos > m_Pos ) { - buf = malloc(nextpos - m_Pos); - unzReadCurrentFile((unzFile)m_Archive, buf, nextpos - m_Pos); - free(buf); + toskip = nextpos - m_Pos; } - else if (nextpos < m_Pos) { + else + { unzCloseCurrentFile((unzFile)m_Archive); if (unzOpenCurrentFile((unzFile)m_Archive) != UNZ_OK) { m_lasterror = wxStream_READ_ERR; return m_Pos; } - buf = malloc(nextpos); - unzReadCurrentFile((unzFile)m_Archive, buf, nextpos); - free(buf); + toskip = nextpos; + } + + if ( toskip > 0 ) + { + const size_t BUFSIZE = 4096; + size_t sz; + char buffer[BUFSIZE]; + while ( toskip > 0 ) + { + sz = wxMin(toskip, BUFSIZE); + unzReadCurrentFile((unzFile)m_Archive, buffer, sz); + toskip -= sz; + } } m_Pos = nextpos; -- 2.45.2