X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/44b7211689ec6c63c8e98c73a7ecd13994328ba7..038c99477c8cd14013cef892517012717c47df35:/src/common/filepickercmn.cpp diff --git a/src/common/filepickercmn.cpp b/src/common/filepickercmn.cpp index 49abded37f..5923767f2d 100644 --- a/src/common/filepickercmn.cpp +++ b/src/common/filepickercmn.cpp @@ -44,8 +44,8 @@ const char wxDirPickerWidgetNameStr[] = "dirpickerwidget"; const char wxFilePickerWidgetLabel[] = wxTRANSLATE("Browse"); const char wxDirPickerWidgetLabel[] = wxTRANSLATE("Browse"); -wxDEFINE_EVENT( wxEVT_COMMAND_FILEPICKER_CHANGED, wxFileDirPickerEvent ); -wxDEFINE_EVENT( wxEVT_COMMAND_DIRPICKER_CHANGED, wxFileDirPickerEvent ); +wxDEFINE_EVENT( wxEVT_FILEPICKER_CHANGED, wxFileDirPickerEvent ); +wxDEFINE_EVENT( wxEVT_DIRPICKER_CHANGED, wxFileDirPickerEvent ); IMPLEMENT_DYNAMIC_CLASS(wxFileDirPickerEvent, wxCommandEvent) // ---------------------------------------------------------------------------- @@ -63,8 +63,6 @@ bool wxFileDirPickerCtrlBase::CreateBase(wxWindow *parent, const wxValidator& validator, const wxString &name ) { - wxASSERT_MSG(path.empty() || CheckPath(path), wxT("Invalid initial path!")); - if (!wxPickerBase::CreateBase(parent, id, path, pos, size, style, validator, name)) return false; @@ -119,8 +117,13 @@ void wxFileDirPickerCtrlBase::UpdatePickerFromTextCtrl() // string otherwise we would generate a wxFileDirPickerEvent when changing // from e.g. /home/user to /home/user/ and we want to avoid it ! wxString newpath(GetTextCtrlValue()); - if (!CheckPath(newpath)) - return; // invalid user input + + // Notice that we use to check here whether the current path is valid, i.e. + // if the corresponding file or directory exists for the controls with + // wxFLP_FILE_MUST_EXIST or wxDIRP_DIR_MUST_EXIST flag, however we don't do + // this any more as we still must notify the program about any changes in + // the control, otherwise its view of it would be different from what is + // actually shown on the screen, resulting in very confusing UI. if (m_pickerIface->GetPath() != newpath) { @@ -199,15 +202,6 @@ bool wxFilePickerCtrl::Create(wxWindow *parent, return true; } -bool wxFilePickerCtrl::CheckPath(const wxString& path) const -{ - // if wxFLP_SAVE was given or wxFLP_FILE_MUST_EXIST has NOT been given we - // must accept any path - return HasFlag(wxFLP_SAVE) || - !HasFlag(wxFLP_FILE_MUST_EXIST) || - wxFileName::FileExists(path); -} - wxString wxFilePickerCtrl::GetTextCtrlValue() const { // filter it through wxFileName to remove any spurious path separator @@ -246,12 +240,6 @@ bool wxDirPickerCtrl::Create(wxWindow *parent, return true; } -bool wxDirPickerCtrl::CheckPath(const wxString& path) const -{ - // if wxDIRP_DIR_MUST_EXIST has NOT been given we must accept any path - return !HasFlag(wxDIRP_DIR_MUST_EXIST) || wxFileName::DirExists(path); -} - wxString wxDirPickerCtrl::GetTextCtrlValue() const { // filter it through wxFileName to remove any spurious path separator