X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/74bde8745fdb770a811fa6157d16c4d0ad413d04..a246ab8b5e30b09705b485b6021c0149c80becda:/src/generic/filepickerg.cpp diff --git a/src/generic/filepickerg.cpp b/src/generic/filepickerg.cpp index 3d5b975a9a..a33a965db0 100644 --- a/src/generic/filepickerg.cpp +++ b/src/generic/filepickerg.cpp @@ -113,46 +113,28 @@ void wxGenericFileDirButton::SetInitialDirectory(const wxString& dir) } // ---------------------------------------------------------------------------- -// wxGenericFileutton +// wxGenericFileButton // ---------------------------------------------------------------------------- -void -wxGenericFileButton::DoSetInitialDirectory(wxFileDialog* dialog, - const wxString& dir) -{ - if ( m_path.find_first_of(wxFileName::GetPathSeparators()) == - wxString::npos ) - { - dialog->SetDirectory(dir); - } -} - wxDialog *wxGenericFileButton::CreateDialog() { - wxFileDialog* const dialog = new wxFileDialog - ( - GetDialogParent(), - m_message, - wxEmptyString, - wxEmptyString, - m_wildcard, - GetDialogStyle() - ); - - // If there is no default file or if it doesn't have any path, use the - // explicitly set initial directory. - // - // Notice that it is important to call this before SetPath() below as if we - // do have m_initialDir and no directory in m_path, we need to interpret - // the path as being relative with respect to m_initialDir. - if ( !m_initialDir.empty() ) - DoSetInitialDirectory(dialog, m_initialDir); - - // This sets both the default file name and the default directory of the - // dialog if m_path contains directory part. - dialog->SetPath(m_path); - - return dialog; + // Determine the initial directory for the dialog: it comes either from the + // default path, if it has it, or from the separately specified initial + // directory that can be set even if the path is e.g. empty. + wxFileName fn(m_path); + wxString initialDir = fn.GetPath(); + if ( initialDir.empty() ) + initialDir = m_initialDir; + + return new wxFileDialog + ( + GetDialogParent(), + m_message, + initialDir, + fn.GetFullName(), + m_wildcard, + GetDialogStyle() + ); } // ----------------------------------------------------------------------------