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
This commit is contained in:
Vadim Zeitlin
2002-09-12 19:32:29 +00:00
parent 58071ea008
commit 4ea2c29f51
2 changed files with 31 additions and 29 deletions

View File

@@ -71,8 +71,6 @@
#endif #endif
#elif (defined(__WXPM__)) #elif (defined(__WXPM__))
#include <io.h> #include <io.h>
#define W_OK 2
#define R_OK 4
#elif (defined(__WXSTUBS__)) #elif (defined(__WXSTUBS__))
// Have to ifdef this for different environments // Have to ifdef this for different environments
#include <io.h> #include <io.h>
@@ -84,8 +82,6 @@
#endif #endif
char* mktemp( char * path ) { return path ;} char* mktemp( char * path ) { return path ;}
#include <stat.h> #include <stat.h>
#define W_OK 2
#define R_OK 4
#include <unistd.h> #include <unistd.h>
#else #else
#error "Please specify the header with file functions declarations." #error "Please specify the header with file functions declarations."
@@ -94,18 +90,21 @@
#include <stdio.h> // SEEK_xxx constants #include <stdio.h> // SEEK_xxx constants
#include <fcntl.h> // O_RDONLY &c #include <fcntl.h> // O_RDONLY &c
#ifndef __MWERKS__ #if !defined(__MWERKS__) || defined(__WXMSW__)
#include <sys/types.h> // needed for stat
#include <sys/stat.h> // stat
#elif ( defined(__MWERKS__) && defined(__WXMSW__) )
#include <sys/types.h> // needed for stat #include <sys/types.h> // needed for stat
#include <sys/stat.h> // stat #include <sys/stat.h> // stat
#endif #endif
#if defined(__BORLANDC__) || defined(_MSC_VER) // Windows compilers don't have these constants
#define W_OK 2 #ifndef W_OK
#define R_OK 4 enum
#endif {
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 // 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 // O_BINARY as 0 if the system headers don't do it already
@@ -138,6 +137,7 @@
#include "wx/filename.h" #include "wx/filename.h"
#include "wx/file.h" #include "wx/file.h"
#include "wx/filefn.h"
#ifdef __WXMSW__ #ifdef __WXMSW__
#include "wx/msw/mslu.h" #include "wx/msw/mslu.h"
@@ -150,19 +150,22 @@
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// static functions // static functions
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
bool wxFile::Exists(const wxChar *name) bool wxFile::Exists(const wxChar *name)
{ {
wxStructStat st; return wxFileExists(name);
return !wxAccess(name, 0) &&
!wxStat(name, &st) &&
(st.st_mode & S_IFREG);
} }
bool wxFile::Access(const wxChar *name, OpenMode mode) 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: case read:
how = R_OK; how = R_OK;
break; break;
@@ -171,11 +174,12 @@ bool wxFile::Access(const wxChar *name, OpenMode mode)
how = W_OK; how = W_OK;
break; break;
default: case read_write:
wxFAIL_MSG(wxT("bad wxFile::Access mode parameter.")); how = R_OK | W_OK;
break;
} }
return wxAccess( name, how) == 0; return wxAccess(name, how) == 0;
} }
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------

View File

@@ -326,18 +326,16 @@ wxString wxPathList::FindAbsoluteValidPath (const wxString& file)
bool bool
wxFileExists (const wxString& filename) 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__) #if defined(__WIN32__) && !defined(__WXMICROWIN__)
// GetFileAttributes can copy with network paths unlike stat()
DWORD ret = ::GetFileAttributes(filename); DWORD ret = ::GetFileAttributes(filename);
return (ret != (DWORD)-1) && !(ret & FILE_ATTRIBUTE_DIRECTORY); return (ret != (DWORD)-1) && !(ret & FILE_ATTRIBUTE_DIRECTORY);
#else #else // !__WIN32__
wxStructStat stbuf; wxStructStat st;
if ( !filename.empty() && wxStat( filename, &stbuf) == 0 ) return wxStat(filename, &st) == 0 && (st.st_mode & S_IFREG);
return TRUE; #endif // __WIN32__/!__WIN32__
return FALSE;
#endif
} }
bool bool