X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c6603ac2ffa78093bbe9a4938b481abff1987c77..70ddb200c10bb6f1075f4a39452fdcf77f84fdf5:/src/msw/filedlg.cpp?ds=sidebyside diff --git a/src/msw/filedlg.cpp b/src/msw/filedlg.cpp index 249f674d4e..0de0f976be 100644 --- a/src/msw/filedlg.cpp +++ b/src/msw/filedlg.cpp @@ -5,7 +5,7 @@ // Modified by: // Created: 01/02/97 // RCS-ID: $Id$ -// Copyright: (c) Julian Smart and Markus Holzem +// Copyright: (c) Julian Smart // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// @@ -35,6 +35,7 @@ #include "wx/msgdlg.h" #include "wx/dialog.h" #include "wx/filedlg.h" + #include "wx/filefn.h" #include "wx/intl.h" #include "wx/log.h" #include "wx/app.h" @@ -42,7 +43,7 @@ #include "wx/msw/private.h" -#if !defined(__WIN32__) || defined(__SALFORDC__) || defined(__WXWINE__) +#if !defined(__WIN32__) || defined(__SALFORDC__) #include #endif @@ -61,7 +62,7 @@ // ---------------------------------------------------------------------------- #ifdef __WIN32__ -# define wxMAXPATH 4096 +# define wxMAXPATH 65534 #else # define wxMAXPATH 1024 #endif @@ -197,9 +198,13 @@ wxString wxFileSelectorEx(const wxChar *title, return filename; } -wxFileDialog::wxFileDialog(wxWindow *parent, const wxString& message, - const wxString& defaultDir, const wxString& defaultFileName, const wxString& wildCard, - long style, const wxPoint& WXUNUSED(pos)) +wxFileDialog::wxFileDialog(wxWindow *parent, + const wxString& message, + const wxString& defaultDir, + const wxString& defaultFileName, + const wxString& wildCard, + long style, + const wxPoint& WXUNUSED(pos)) { m_message = message; m_dialogStyle = style; @@ -228,6 +233,14 @@ void wxFileDialog::GetPaths(wxArrayString& paths) const } } +void wxFileDialog::SetPath(const wxString& path) +{ + wxString ext; + wxSplitPath(path, &m_dir, &m_fileName, &ext); + if ( !ext.empty() ) + m_fileName << _T('.') << ext; +} + int wxFileDialog::ShowModal() { HWND hWnd = 0; @@ -259,12 +272,13 @@ int wxFileDialog::ShowModal() { msw_flags |= OFN_NOCHANGEDIR; } - +/* chris elliott for some reason this does not work usefully if no extension + is given, as it test for junk instead of junk.ext if ( m_dialogStyle & wxOVERWRITE_PROMPT ) { msw_flags |= OFN_OVERWRITEPROMPT; } - +*/ OPENFILENAME of; wxZeroMemory(of); @@ -309,8 +323,11 @@ int wxFileDialog::ShowModal() if ( chNext != _T('\\') && chNext != _T('/') ) break; - // ignore the next one - i++; + // ignore the next one, unless it is at the start of a UNC path + if (i > 0) + i++; + else + break; } // fall through @@ -398,24 +415,6 @@ int wxFileDialog::ShowModal() : (GetOpenFileName(&of) != 0); } } - -#if wxUSE_UNICODE_MSLU && defined(OFN_EXPLORER) - // VS: these's a bug in unicows.dll - when multiple files are - // selected, of.nFileOffset doesn't point to the first - // filename but rather to the last component of directory - // name. Let's try to fix it: - if ( (m_dialogStyle & wxMULTIPLE) && - (fileNameBuffer[of.nFileOffset-1] != wxT('\0')) && - wxGetOsVersion() == wxWIN95 /*using unicows.dll*/) - { - if ( wxDirExists(fileNameBuffer) ) - { - // 1st component is dir => multiple files selected - of.nFileOffset = wxStrlen(fileNameBuffer)+1; - } - } -#endif // wxUSE_UNICODE_MSLU - #endif // __WIN32__ if ( success ) @@ -471,6 +470,17 @@ int wxFileDialog::ShowModal() { // User has typed a filename without an extension: + // A filename can end in a "." here ("abc."), this means it + // does not have an extension. Because later on a "." with + // the default extension is appended we remove the "." if + // filename ends with one (We don't want files called + // "abc..ext") + int idx = wxStrlen(fileNameBuffer) - 1; + if ( fileNameBuffer[idx] == wxT('.') ) + { + fileNameBuffer[idx] = wxT('\0'); + } + int maxFilter = (int)(of.nFilterIndex*2L-1L); extension = filterBuffer; @@ -499,6 +509,18 @@ int wxFileDialog::ShowModal() m_fileNames.Add(m_fileName); m_dir = wxPathOnly(fileNameBuffer); } + //=== Simulating the wxOVERWRITE_PROMPT >>============================ + //should we also test for file save style ?? + if ( (m_dialogStyle & wxOVERWRITE_PROMPT) && + ::wxFileExists( fileNameBuffer ) ) + { + wxString messageText; + messageText.Printf(_("File '%s' already exists.\nDo you want to replace it?"), fileNameBuffer); + if ( wxMessageBox(messageText, wxT("Save File As"), wxYES_NO | wxICON_EXCLAMATION ) != wxYES ) + { + success = FALSE; + } + } } else {