summaryrefslogtreecommitdiffstats
path: root/Modules/zipimport.c
diff options
context:
space:
mode:
authorGregory P. Smith <greg@krypto.org>2012-01-30 23:17:33 (GMT)
committerGregory P. Smith <greg@krypto.org>2012-01-30 23:17:33 (GMT)
commitab32066e65f67e14b3af4ed61333ed083446b225 (patch)
tree5d0624df4bc9444632fcb8f130d28774ee43d608 /Modules/zipimport.c
parent2652d2570ea2d34fc790ef99ebd0c3c321fb86cb (diff)
downloadcpython-ab32066e65f67e14b3af4ed61333ed083446b225.zip
cpython-ab32066e65f67e14b3af4ed61333ed083446b225.tar.gz
cpython-ab32066e65f67e14b3af4ed61333ed083446b225.tar.bz2
Fix zip_import.c's read_directory() to use appropriate types for the values
being read from the header vs the values being used by fseek and ftell (Py_ssize_t for those) and how they are computed. Py_ssize_t is used for actual file offsets so that files greater than 2gigs could be supported. Updates the Py_BuildValue format string to match (including several existing wrong 'i's that should have been 'l's).
Diffstat (limited to 'Modules/zipimport.c')
-rw-r--r--Modules/zipimport.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/Modules/zipimport.c b/Modules/zipimport.c
index 11c3904..d8c3d8a 100644
--- a/Modules/zipimport.c
+++ b/Modules/zipimport.c
@@ -714,15 +714,16 @@ read_directory(PyObject *archive_obj)
PyObject *files = NULL;
FILE *fp;
unsigned short flags;
- long compress, crc, data_size, file_size, file_offset, date, time;
- long header_offset, name_size, header_size, header_position;
+ short compress, time, date, name_size;
+ long crc, data_size, file_size, header_size;
+ Py_ssize_t file_offset, header_position, header_offset;
long i, l, count;
size_t length;
Py_UNICODE path[MAXPATHLEN + 5];
char name[MAXPATHLEN + 5];
PyObject *nameobj = NULL;
char *p, endof_central_dir[22];
- long arc_offset; /* offset from beginning of file to start of zip-archive */
+ Py_ssize_t arc_offset; /* Absolute offset to start of the zip-archive. */
PyObject *pathobj;
const char *charset;
int bootstrap;
@@ -832,7 +833,7 @@ read_directory(PyObject *archive_obj)
pathobj = PyUnicode_FromUnicode(path, Py_UNICODE_strlen(path));
if (pathobj == NULL)
goto error;
- t = Py_BuildValue("Niiiiiii", pathobj, compress, data_size,
+ t = Py_BuildValue("Nhllnhhl", pathobj, compress, data_size,
file_size, file_offset, time, date, crc);
if (t == NULL)
goto error;