From: Vadim Zeitlin Date: Thu, 12 Sep 2002 19:32:29 +0000 (+0000) Subject: make wxFile::Exists() use wxFileExists(): this avoids code duplication and should... X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/4ea2c29f51d358c9a9bbc37edda1541073c71364?hp=58071ea0089e929db5899d27072b10d79ed57f10 make wxFile::Exists() use wxFileExists(): this avoids code duplication and should make wxFile::Exists() work with UNC paths git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@17152 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/src/common/file.cpp b/src/common/file.cpp index d5a136e704..5c5dd58c9d 100644 --- a/src/common/file.cpp +++ b/src/common/file.cpp @@ -71,8 +71,6 @@ #endif #elif (defined(__WXPM__)) #include - #define W_OK 2 - #define R_OK 4 #elif (defined(__WXSTUBS__)) // Have to ifdef this for different environments #include @@ -84,8 +82,6 @@ #endif char* mktemp( char * path ) { return path ;} #include - #define W_OK 2 - #define R_OK 4 #include #else #error "Please specify the header with file functions declarations." @@ -94,18 +90,21 @@ #include // SEEK_xxx constants #include // O_RDONLY &c -#ifndef __MWERKS__ - #include // needed for stat - #include // stat -#elif ( defined(__MWERKS__) && defined(__WXMSW__) ) +#if !defined(__MWERKS__) || defined(__WXMSW__) #include // needed for stat #include // stat #endif -#if defined(__BORLANDC__) || defined(_MSC_VER) - #define W_OK 2 - #define R_OK 4 -#endif +// Windows compilers don't have these constants +#ifndef W_OK + enum + { + F_OK = 0, // test for existence + X_OK = 1, // execute permission + W_OK = 2, // write + R_OK = 4 // read + }; +#endif // W_OK // there is no distinction between text and binary files under Unix, so define // O_BINARY as 0 if the system headers don't do it already @@ -138,6 +137,7 @@ #include "wx/filename.h" #include "wx/file.h" +#include "wx/filefn.h" #ifdef __WXMSW__ #include "wx/msw/mslu.h" @@ -150,19 +150,22 @@ // ---------------------------------------------------------------------------- // static functions // ---------------------------------------------------------------------------- + bool wxFile::Exists(const wxChar *name) { - wxStructStat st; - return !wxAccess(name, 0) && - !wxStat(name, &st) && - (st.st_mode & S_IFREG); + return wxFileExists(name); } bool wxFile::Access(const wxChar *name, OpenMode mode) { - int how = 0; + int how; + + switch ( mode ) + { + default: + wxFAIL_MSG(wxT("bad wxFile::Access mode parameter.")); + // fall through - switch ( mode ) { case read: how = R_OK; break; @@ -171,11 +174,12 @@ bool wxFile::Access(const wxChar *name, OpenMode mode) how = W_OK; break; - default: - wxFAIL_MSG(wxT("bad wxFile::Access mode parameter.")); + case read_write: + how = R_OK | W_OK; + break; } - return wxAccess( name, how) == 0; + return wxAccess(name, how) == 0; } // ---------------------------------------------------------------------------- diff --git a/src/common/filefn.cpp b/src/common/filefn.cpp index 59d875f298..935fa8608c 100644 --- a/src/common/filefn.cpp +++ b/src/common/filefn.cpp @@ -326,18 +326,16 @@ wxString wxPathList::FindAbsoluteValidPath (const wxString& file) bool wxFileExists (const wxString& filename) { + // we must use GetFileAttributes() instead of the ANSI C functions because + // it can cope with network (UNC) paths unlike them #if defined(__WIN32__) && !defined(__WXMICROWIN__) - // GetFileAttributes can copy with network paths unlike stat() DWORD ret = ::GetFileAttributes(filename); return (ret != (DWORD)-1) && !(ret & FILE_ATTRIBUTE_DIRECTORY); -#else - wxStructStat stbuf; - if ( !filename.empty() && wxStat( filename, &stbuf) == 0 ) - return TRUE; - - return FALSE; -#endif +#else // !__WIN32__ + wxStructStat st; + return wxStat(filename, &st) == 0 && (st.st_mode & S_IFREG); +#endif // __WIN32__/!__WIN32__ } bool