Add support for large stdio files for VC 8+. What versions of the other Windows

compilers?


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@62974 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Michael Wetherell
2009-12-22 21:22:59 +00:00
parent 3e6d8c3118
commit 224d978ffb
3 changed files with 32 additions and 19 deletions

View File

@@ -172,7 +172,9 @@ enum wxFileKind
defined(__BORLANDC__) \ defined(__BORLANDC__) \
) )
// temporary defines just used immediately below
#undef wxHAS_HUGE_FILES #undef wxHAS_HUGE_FILES
#undef wxHAS_HUGE_STDIO_FILES
// detect compilers which have support for huge files // detect compilers which have support for huge files
#if defined(__VISUALC__) #if defined(__VISUALC__)
@@ -183,6 +185,13 @@ enum wxFileKind
#define wxHAS_HUGE_FILES 1 #define wxHAS_HUGE_FILES 1
#endif #endif
// detect compilers which have support for huge stdio files
#if wxCHECK_VISUALC_VERSION(8)
#define wxHAS_HUGE_STDIO_FILES
#define wxFseek _fseeki64
#define wxFtell _ftelli64
#endif
// other Windows compilers (DMC, Watcom, Metrowerks and Borland) don't have // other Windows compilers (DMC, Watcom, Metrowerks and Borland) don't have
// huge file support (or at least not all functions needed for it by wx) // huge file support (or at least not all functions needed for it by wx)
// currently // currently
@@ -397,16 +406,19 @@ enum wxFileKind
#endif // wxHAS_UNDERSCORES_IN_POSIX_IDENTS #endif // wxHAS_UNDERSCORES_IN_POSIX_IDENTS
#ifdef wxHAS_HUGE_FILES #ifdef wxHAS_HUGE_FILES
// wxFile is present and supports large files. Currently wxFFile // wxFile is present and supports large files.
// doesn't have large file support with any Windows compiler (even
// Win64 ones).
#if wxUSE_FILE #if wxUSE_FILE
#define wxHAS_LARGE_FILES #define wxHAS_LARGE_FILES
#endif #endif
// wxFFile is present and supports large files
#if wxUSE_FFILE && defined wxHAS_HUGE_STDIO_FILES
#define wxHAS_LARGE_FFILES
#endif
#endif #endif
// it's a private define, undefine it so that nobody gets tempted to use it // private defines, undefine so that nobody gets tempted to use
#undef wxHAS_HUGE_FILES #undef wxHAS_HUGE_FILES
#undef wxHAS_HUGE_STDIO_FILES
#elif defined (__WXPALMOS__) #elif defined (__WXPALMOS__)
typedef off_t wxFileOffset; typedef off_t wxFileOffset;
#ifdef _LARGE_FILES #ifdef _LARGE_FILES
@@ -458,6 +470,10 @@ enum wxFileKind
#if wxUSE_FFILE && (SIZEOF_LONG == 8 || defined HAVE_FSEEKO) #if wxUSE_FFILE && (SIZEOF_LONG == 8 || defined HAVE_FSEEKO)
#define wxHAS_LARGE_FFILES #define wxHAS_LARGE_FFILES
#endif #endif
#ifdef HAVE_FSEEKO
#define wxFseek fseeko
#define wxFtell ftello
#endif
#else #else
#define wxFileOffsetFmtSpec wxT("") #define wxFileOffsetFmtSpec wxT("")
#endif #endif
@@ -491,6 +507,15 @@ enum wxFileKind
#define wxCRT_Lstat wxCRT_Stat #define wxCRT_Lstat wxCRT_Stat
#endif #endif
// define wxFseek/wxFtell to large file versions if available (done above) or
// to fseek/ftell if not, to save ifdefs in using code
#ifndef wxFseek
#define wxFseek fseek
#endif
#ifndef wxFtell
#define wxFtell ftell
#endif
inline int wxAccess(const wxString& path, mode_t mode) inline int wxAccess(const wxString& path, mode_t mode)
{ return wxCRT_Access(path.fn_str(), mode); } { return wxCRT_Access(path.fn_str(), mode); }
inline int wxOpen(const wxString& path, int flags, mode_t mode) inline int wxOpen(const wxString& path, int flags, mode_t mode)

View File

@@ -42,18 +42,6 @@
// implementation // implementation
// ============================================================================ // ============================================================================
// ----------------------------------------------------------------------------
// seek and tell with large file support if available
// ----------------------------------------------------------------------------
#ifdef HAVE_FSEEKO
# define wxFseek fseeko
# define wxFtell ftello
#else
# define wxFseek fseek
# define wxFtell ftell
#endif
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// opening the file // opening the file
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
@@ -215,7 +203,7 @@ bool wxFFile::Seek(wxFileOffset ofs, wxSeekMode mode)
break; break;
} }
#ifndef HAVE_FSEEKO #ifndef wxHAS_LARGE_FFILES
if ((long)ofs != ofs) if ((long)ofs != ofs)
{ {
wxLogError(_("Seek error on file '%s' (large files not supported by stdio)"), m_name.c_str()); wxLogError(_("Seek error on file '%s' (large files not supported by stdio)"), m_name.c_str());

View File

@@ -268,8 +268,8 @@ wxOutputStream *LargeFileTest_wxFFile::MakeOutStream(const wxString& name) const
bool LargeFileTest_wxFFile::HasLFS() const bool LargeFileTest_wxFFile::HasLFS() const
{ {
#ifdef HAVE_FSEEKO #ifdef wxHAS_LARGE_FFILES
return (wxFileOffset)0xffffffff > 0; return true;
#else #else
return false; return false;
#endif #endif