From 4f53da07bf79b98c4131fcb9a49e6987298973a7 Mon Sep 17 00:00:00 2001 From: Guido van Rossum Date: Thu, 1 Mar 2001 18:26:53 +0000 Subject: [PATCH] Two improvements to large file support: - In _portable_ftell(), try fgetpos() before ftello() and ftell64(). I ran into a situation on a 64-bit capable Linux where the C library's ftello() and ftell64() returned negative numbers despite fpos_t and off_t both being 64-bit types; fgetpos() did the right thing. - Define a new typedef, Py_off_t, which is either fpos_t or off_t, depending on which one is 64 bits. This removes the need for a lot of #ifdefs later on. (XXX Should this be moved to pyport.h? That file currently seems oblivious to large fille support, so for now I'll leave it here where it's needed.) --- Objects/fileobject.c | 48 +++++++++++++++++--------------------------- 1 file changed, 18 insertions(+), 30 deletions(-) diff --git a/Objects/fileobject.c b/Objects/fileobject.c index 7d3287928ab..27e21de154b 100644 --- a/Objects/fileobject.c +++ b/Objects/fileobject.c @@ -212,14 +212,18 @@ file_close(PyFileObject *f, PyObject *args) } +/* An 8-byte off_t-like type */ +#if defined(HAVE_LARGEFILE_SUPPORT) && SIZEOF_OFF_T < 8 && SIZEOF_FPOS_T >= 8 +typedef fpos_t Py_off_t; +#else +typedef off_t Py_off_t; +#endif + + /* a portable fseek() function return 0 on success, non-zero on failure (with errno set) */ int -#if defined(HAVE_LARGEFILE_SUPPORT) && SIZEOF_OFF_T < 8 && SIZEOF_FPOS_T >= 8 -_portable_fseek(FILE *fp, fpos_t offset, int whence) -#else -_portable_fseek(FILE *fp, off_t offset, int whence) -#endif +_portable_fseek(FILE *fp, Py_off_t offset, int whence) { #if defined(HAVE_FSEEKO) return fseeko(fp, offset, whence); @@ -253,22 +257,18 @@ _portable_fseek(FILE *fp, off_t offset, int whence) /* a portable ftell() function Return -1 on failure with errno set appropriately, current file position on success */ -#if defined(HAVE_LARGEFILE_SUPPORT) && SIZEOF_OFF_T < 8 && SIZEOF_FPOS_T >= 8 -fpos_t -#else -off_t -#endif +Py_off_t _portable_ftell(FILE* fp) { -#if defined(HAVE_FTELLO) && defined(HAVE_LARGEFILE_SUPPORT) - return ftello(fp); -#elif defined(HAVE_FTELL64) && defined(HAVE_LARGEFILE_SUPPORT) - return ftell64(fp); -#elif SIZEOF_FPOS_T >= 8 && defined(HAVE_LARGEFILE_SUPPORT) +#if SIZEOF_FPOS_T >= 8 && defined(HAVE_LARGEFILE_SUPPORT) fpos_t pos; if (fgetpos(fp, &pos) != 0) return -1; return pos; +#elif defined(HAVE_FTELLO) && defined(HAVE_LARGEFILE_SUPPORT) + return ftello(fp); +#elif defined(HAVE_FTELL64) && defined(HAVE_LARGEFILE_SUPPORT) + return ftell64(fp); #else return ftell(fp); #endif @@ -280,11 +280,7 @@ file_seek(PyFileObject *f, PyObject *args) { int whence; int ret; -#if defined(HAVE_LARGEFILE_SUPPORT) && SIZEOF_OFF_T < 8 && SIZEOF_FPOS_T >= 8 - fpos_t offset, pos; -#else - off_t offset; -#endif /* !MS_WIN64 */ + Py_off_t offset; PyObject *offobj; if (f->f_fp == NULL) @@ -321,11 +317,7 @@ static PyObject * file_truncate(PyFileObject *f, PyObject *args) { int ret; -#if defined(HAVE_LARGEFILE_SUPPORT) && SIZEOF_OFF_T < 8 && SIZEOF_FPOS_T >= 8 - fpos_t newsize; -#else - off_t newsize; -#endif + Py_off_t newsize; PyObject *newsizeobj; if (f->f_fp == NULL) @@ -396,11 +388,7 @@ file_truncate(PyFileObject *f, PyObject *args) static PyObject * file_tell(PyFileObject *f, PyObject *args) { -#if defined(HAVE_LARGEFILE_SUPPORT) && SIZEOF_OFF_T < 8 && SIZEOF_FPOS_T >= 8 - fpos_t pos; -#else - off_t pos; -#endif + Py_off_t pos; if (f->f_fp == NULL) return err_closed();