X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c848b2f955851cbaf8c8a6685890490b21f1ae8e..a9249b2eb2a40d8c71f828669045c4ddaa8dc5ff:/src/common/filename.cpp diff --git a/src/common/filename.cpp b/src/common/filename.cpp index d5fcbb5495..aae38ea3ef 100644 --- a/src/common/filename.cpp +++ b/src/common/filename.cpp @@ -34,7 +34,7 @@ (although :filename works as well). Since the volume is just part of the file path, it is not treated like a separate entity as it is done under DOS and - VMS, it is just treated as another dir. + VMS, it is just treated as another dir. wxPATH_VMS: VMS native format, absolute file names have the form :[dir1.dir2.dir3]file.txt @@ -61,19 +61,20 @@ // ---------------------------------------------------------------------------- #ifdef __GNUG__ - #pragma implementation "filename.h" +#pragma implementation "filename.h" #endif // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" #ifdef __BORLANDC__ - #pragma hdrstop +#pragma hdrstop #endif #ifndef WX_PRECOMP - #include "wx/intl.h" - #include "wx/log.h" +#include "wx/intl.h" +#include "wx/log.h" +#include "wx/file.h" #endif #include "wx/filename.h" @@ -81,36 +82,32 @@ #include "wx/config.h" // for wxExpandEnvVars #include "wx/utils.h" #include "wx/file.h" - -#if wxUSE_DYNLIB_CLASS - #include "wx/dynlib.h" -#endif +//#include "wx/dynlib.h" // see GetLongPath below, code disabled. // For GetShort/LongPathName #ifdef __WIN32__ - #include - - #include "wx/msw/winundef.h" +#include +#include "wx/msw/winundef.h" #endif // utime() is POSIX so should normally be available on all Unices #ifdef __UNIX_LIKE__ - #include - #include - #include - #include +#include +#include +#include +#include #endif #ifdef __MWERKS__ - #include - #include - #include +#include +#include +#include #endif #ifdef __WATCOMC__ - #include - #include - #include +#include +#include +#include #endif #ifdef __VISAGECPP__ @@ -237,13 +234,13 @@ void wxFileName::Assign(const wxString& volume, { wxPathFormat my_format = GetFormat( format ); wxString my_path = path; - + m_dirs.Clear(); - + if (!my_path.empty()) { // 1) Determine if the path is relative or absolute. - + switch (my_format) { case wxPATH_MAC: @@ -251,7 +248,7 @@ void wxFileName::Assign(const wxString& volume, // We then remove a leading ":". The reason is in our // storage form for relative paths: // ":dir:file.txt" actually means "./dir/file.txt" in - // DOS notation and should get stored as + // DOS notation and should get stored as // (relative) (dir) (file.txt) // "::dir:file.txt" actually means "../dir/file.txt" // stored as (relative) (..) (dir) (file.txt) @@ -275,11 +272,11 @@ void wxFileName::Assign(const wxString& volume, wxFAIL_MSG( wxT("error") ); break; } - + // 2) Break up the path into its members. If the original path // was just "/" or "\\", m_dirs will be empty. We know from // the m_relative field, if this means "nothing" or "root dir". - + wxStringTokenizer tn( my_path, GetPathSeparators(my_format) ); while ( tn.HasMoreTokens() ) @@ -523,7 +520,7 @@ wxFileName::CreateTempFileName(const wxString& prefix, wxFile *fileTemp) #ifndef __WATCOMC__ ::DosCreateDir(wxStringBuffer(path, MAX_PATH), NULL); #endif - + #else // !Windows, !OS/2 if ( dir.empty() ) { @@ -628,7 +625,16 @@ wxFileName::CreateTempFileName(const wxString& prefix, wxFile *fileTemp) { // open the file - of course, there is a race condition here, this is // why we always prefer using mkstemp()... - if ( !fileTemp->Open(path, wxFile::write_excl, wxS_IRUSR | wxS_IWUSR) ) + // + // NB: GetTempFileName() under Windows creates the file, so using + // write_excl there would fail + if ( !fileTemp->Open(path, +#if defined(__WINDOWS__) && !defined(__WXMICROWIN__) + wxFile::write, +#else + wxFile::write_excl, +#endif + wxS_IRUSR | wxS_IWUSR) ) { // FIXME: If !ok here should we loop and try again with another // file name? That is the standard recourse if open(O_EXCL) @@ -870,7 +876,7 @@ bool wxFileName::MakeRelativeTo(const wxString& pathBase, wxPathFormat format) { m_dirs.Insert(wxT(".."), 0u); } - + m_relative = TRUE; // we were modified @@ -1037,7 +1043,7 @@ wxString wxFileName::GetPath( bool add_separator, wxPathFormat format ) const if (!m_relative) fullpath += wxFILE_SEP_PATH_UNIX; } - + // then concatenate all the path components using the path separator size_t dirCount = m_dirs.GetCount(); if ( dirCount ) @@ -1123,7 +1129,7 @@ wxString wxFileName::GetFullPath( wxPathFormat format ) const // else ignore } } - + // the leading character if ( format == wxPATH_MAC && m_relative ) { @@ -1139,7 +1145,7 @@ wxString wxFileName::GetFullPath( wxPathFormat format ) const if (!m_relative) fullpath += wxFILE_SEP_PATH_UNIX; } - + // then concatenate all the path components using the path separator size_t dirCount = m_dirs.GetCount(); if ( dirCount ) @@ -1238,7 +1244,7 @@ wxString wxFileName::GetLongPath() const bool success = FALSE; // VZ: this code was disabled, why? -#if 0 // wxUSE_DYNLIB_CLASS +#if 0 // wxUSE_DYNAMIC_LOADER typedef DWORD (*GET_LONG_PATH_NAME)(const wxChar *, wxChar *, DWORD); static bool s_triedToLoad = FALSE; @@ -1286,7 +1292,7 @@ wxString wxFileName::GetLongPath() const } if (success) return pathOut; -#endif // wxUSE_DYNLIB_CLASS +#endif // wxUSE_DYNAMIC_LOADER if (!success) {