+ if (m_extraControl)
+ {
+ // get chooser to drop its reference right now, allowing wxWindow dtor
+ // to verify that ref count drops to zero
+ gtk_file_chooser_set_extra_widget(
+ GTK_FILE_CHOOSER(m_widget), NULL);
+ }
+}
+
+void wxFileDialog::OnFakeOk(wxCommandEvent& WXUNUSED(event))
+{
+ EndDialog(wxID_OK);
+}
+
+int wxFileDialog::ShowModal()
+{
+ WX_TESTING_SHOW_MODAL_HOOK();
+
+ CreateExtraControl();
+
+ return wxDialog::ShowModal();
+}
+
+void wxFileDialog::DoSetSize(int WXUNUSED(x), int WXUNUSED(y),
+ int WXUNUSED(width), int WXUNUSED(height),
+ int WXUNUSED(sizeFlags))
+{
+}
+
+void wxFileDialog::OnSize(wxSizeEvent&)
+{
+ // avoid calling DoLayout(), which will set the (wrong) size of
+ // m_extraControl, its size is managed by GtkFileChooser
+}
+
+wxString wxFileDialog::GetPath() const
+{
+ return m_fc.GetPath();
+}
+
+void wxFileDialog::GetFilenames(wxArrayString& files) const
+{
+ m_fc.GetFilenames( files );
+}
+
+void wxFileDialog::GetPaths(wxArrayString& paths) const
+{
+ m_fc.GetPaths( paths );
+}
+
+void wxFileDialog::SetMessage(const wxString& message)
+{
+ m_message = message;
+ SetTitle(message);
+}
+
+void wxFileDialog::SetPath(const wxString& path)
+{
+ wxFileDialogBase::SetPath(path);
+
+ // Don't do anything if no path is specified, in particular don't set the
+ // path to m_dir below as this would result in opening the dialog in the
+ // parent directory of this one instead of m_dir itself.
+ if ( path.empty() )
+ return;
+
+ // we need an absolute path for GTK native chooser so ensure that we have
+ // it: use the initial directory if it was set or just CWD otherwise (this
+ // is the default behaviour if m_dir is empty)
+ wxFileName fn(path);
+ fn.MakeAbsolute(m_dir);
+ m_fc.SetPath(fn.GetFullPath());
+}
+
+void wxFileDialog::SetDirectory(const wxString& dir)
+{
+ wxFileDialogBase::SetDirectory(dir);
+
+ m_fc.SetDirectory(dir);
+}
+
+wxString wxFileDialog::GetDirectory() const
+{
+ wxString currentDir( m_fc.GetDirectory() );
+ if (currentDir.empty())
+ {
+ // m_fc.GetDirectory() will return empty until the dialog has been shown
+ // in which case use any previously provided value
+ currentDir = m_dir;
+ }
+ return currentDir;
+}