// macros
// ----------------------------------------------------------------------------
-// we need to translate Mac filenames before passing them to OS functions
+// translate the filenames before passing them to OS functions
#define OS_FILENAME(s) (s.fn_str())
// ============================================================================
// implementation
// ============================================================================
+// ----------------------------------------------------------------------------
+// wrappers around standard POSIX functions
+// ----------------------------------------------------------------------------
+
#ifdef wxNEED_WX_UNISTD_H
WXDLLEXPORT int wxStat( const wxChar *file_name, wxStructStat *buf )
return stat( wxConvFile.cWX2MB( file_name ), buf );
}
+WXDLLEXPORT int wxLstat( const wxChar *file_name, wxStructStat *buf )
+{
+ return lstat( wxConvFile.cWX2MB( file_name ), buf );
+}
+
WXDLLEXPORT int wxAccess( const wxChar *pathname, int mode )
{
return access( wxConvFile.cWX2MB( pathname ), mode );
return open( wxConvFile.cWX2MB( pathname ), flags, mode );
}
-#endif
- // wxNEED_WX_UNISTD_H
+#endif // wxNEED_WX_UNISTD_H
// ----------------------------------------------------------------------------
// wxPathList
return wxMacCFStringHolder(cfMutableString).AsString() ;
}
+#ifndef __LP64__
+
wxString wxMacFSSpec2MacFilename( const FSSpec *spec )
{
FSRef fsRef ;
wxMacPathToFSRef( path , &fsRef ) ;
err = FSRefMakeFSSpec( &fsRef , spec ) ;
}
+#endif
#endif // __WXMAC__
#if defined(__WINDOWS__) || defined(__OS2__)
// Windows fails to find directory named "c:\dir\" even if "c:\dir" exists,
// so remove all trailing backslashes from the path - but don't do this for
- // the pathes "d:\" (which are different from "d:") nor for just "\"
+ // the paths "d:\" (which are different from "d:") nor for just "\"
while ( wxEndsWithPathSeparator(strPath) )
{
size_t len = strPath.length();
// Get a temporary filename, opening and closing the file.
wxChar *wxGetTempFileName(const wxString& prefix, wxChar *buf)
{
-#if wxUSE_FILE
- wxString filename = wxFileName::CreateTempFileName(prefix);
- if ( filename.empty() )
+ wxString filename;
+ if ( !wxGetTempFileName(prefix, filename) )
return NULL;
if ( buf )
buf = MYcopystring(filename);
return buf;
-#else
- wxUnusedVar(prefix);
- wxUnusedVar(buf);
- // wxFileName::CreateTempFileName needs wxFile class enabled
- return NULL;
-#endif
}
bool wxGetTempFileName(const wxString& prefix, wxString& buf)
{
- buf = wxGetTempFileName(prefix);
+#if wxUSE_FILE
+ buf = wxFileName::CreateTempFileName(prefix);
return !buf.empty();
+#else // !wxUSE_FILE
+ wxUnusedVar(prefix);
+ wxUnusedVar(buf);
+
+ return false;
+#endif // wxUSE_FILE/!wxUSE_FILE
}
// Get first file name matching given wild card.
}
#if defined( __WINDOWS__ )
-bool wxCheckGenericPermission(const wxString &path, DWORD access)
+static bool wxCheckWin32Permission(const wxString& path, DWORD access)
{
// quoting the MSDN: "To obtain a handle to a directory, call the
- // CreateFile function with the FILE_FLAG_BACKUP_SEMANTICS flag"
- wxWinVersion ver = wxGetWinVersion();
+ // CreateFile function with the FILE_FLAG_BACKUP_SEMANTICS flag", but this
+ // doesn't work under Win9x/ME but then it's not needed there anyhow
bool isdir = wxDirExists(path);
- if (isdir && (ver == wxWinVersion_95 || ver == wxWinVersion_98 || ver == wxWinVersion_ME))
+ if ( isdir && wxGetOsVersion() == wxOS_WINDOWS_9X )
{
- // however Win95/98/ME do not support FILE_FLAG_BACKUP_SEMANTICS...
- if (access == GENERIC_READ)
- {
- WIN32_FILE_ATTRIBUTE_DATA data;
- if (GetFileAttributesEx(path.c_str(), GetFileExInfoStandard, &data) == 0)
- return false; // cannot query attributes
- return (data.dwFileAttributes & FILE_ATTRIBUTE_READONLY) == 0;
- }
-
- // FIXME: is it true that directories are always writable & executable on Win9X family ?
+ // FAT directories always allow all access, even if they have the
+ // readonly flag set
return true;
}
- else
- {
- HANDLE h = CreateFile(path.c_str(), access,
- FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE, NULL,
- OPEN_EXISTING, isdir ? FILE_FLAG_BACKUP_SEMANTICS : 0, NULL);
- if (h != INVALID_HANDLE_VALUE)
- CloseHandle(h);
- return h != INVALID_HANDLE_VALUE;
- }
+ HANDLE h = ::CreateFile
+ (
+ path.c_str(),
+ access,
+ FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE,
+ NULL,
+ OPEN_EXISTING,
+ isdir ? FILE_FLAG_BACKUP_SEMANTICS : 0,
+ NULL
+ );
+ if ( h != INVALID_HANDLE_VALUE )
+ CloseHandle(h);
+
+ return h != INVALID_HANDLE_VALUE;
}
-#endif
+#endif // __WINDOWS__
bool wxIsWritable(const wxString &path)
{
-#if defined( __UNIX__ )
+#if defined( __UNIX__ ) || defined(__OS2__)
// access() will take in count also symbolic links
return access(wxConvFile.cWX2MB(path), W_OK) == 0;
#elif defined( __WINDOWS__ )
- return wxCheckGenericPermission(path, GENERIC_WRITE);
+ return wxCheckWin32Permission(path, GENERIC_WRITE);
#else
wxUnusedVar(path);
// TODO
bool wxIsReadable(const wxString &path)
{
-#if defined( __UNIX__ )
+#if defined( __UNIX__ ) || defined(__OS2__)
// access() will take in count also symbolic links
return access(wxConvFile.cWX2MB(path), R_OK) == 0;
#elif defined( __WINDOWS__ )
- return wxCheckGenericPermission(path, GENERIC_READ);
+ return wxCheckWin32Permission(path, GENERIC_READ);
#else
wxUnusedVar(path);
// TODO
bool wxIsExecutable(const wxString &path)
{
-#if defined( __UNIX__ )
+#if defined( __UNIX__ ) || defined(__OS2__)
// access() will take in count also symbolic links
return access(wxConvFile.cWX2MB(path), X_OK) == 0;
#elif defined( __WINDOWS__ )
- return wxCheckGenericPermission(path, GENERIC_EXECUTE);
+ return wxCheckWin32Permission(path, GENERIC_EXECUTE);
#else
wxUnusedVar(path);
// TODO