X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/92980e9076469956e1e2cb94df97d0f8d873114a..ee682a94cb9ea835c9b74a12f17b0fb63f43dcce:/src/common/file.cpp?ds=sidebyside diff --git a/src/common/file.cpp b/src/common/file.cpp index 99582fae28..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; } // ---------------------------------------------------------------------------- @@ -502,9 +506,9 @@ bool wxTempFile::Open(const wxString& strName) #ifdef __UNIX__ // the temp file should have the same permissions as the original one mode_t mode; - + wxStructStat st; - if ( stat(m_strName.fn_str(), &st) == 0 ) + if ( stat( (const char*) m_strName.fn_str(), &st) == 0 ) { mode = st.st_mode; } @@ -517,7 +521,7 @@ bool wxTempFile::Open(const wxString& strName) umask(mask); } - if ( chmod(m_strTemp.mb_str(), mode) == -1 ) + if ( chmod( (const char*) m_strTemp.fn_str(), mode) == -1 ) { wxLogSysError(_("Failed to set temporary file permissions")); }