1 /////////////////////////////////////////////////////////////////////////////
2 // Name: src/gtk/dirdlg.cpp
3 // Purpose: native implementation of wxDirDialog
4 // Author: Robert Roebling, Zbigniew Zagorski, Mart Raudsepp, Francesco Montorsi
5 // Copyright: (c) 1998 Robert Roebling, 2004 Zbigniew Zagorski, 2005 Mart Raudsepp
6 // Licence: wxWindows licence
7 /////////////////////////////////////////////////////////////////////////////
9 // For compilers that support precompilation, includes "wx.h".
10 #include "wx/wxprec.h"
15 NOTE: the GtkFileChooser interface can be used both for wxFileDialog and for wxDirDialog.
16 Thus following code is very similar (even if not identic) to src/gtk/filedlg.cpp
17 If you find a problem in this code, remember to check also that file !
24 #include "wx/dirdlg.h"
28 #include "wx/filedlg.h"
31 #include "wx/gtk/private.h"
34 static void gtk_dirdialog_response_callback(GtkWidget
* WXUNUSED(w
),
38 if (response
== GTK_RESPONSE_ACCEPT
)
39 dialog
->GTKOnAccept();
40 else // GTK_RESPONSE_CANCEL or GTK_RESPONSE_NONE
41 dialog
->GTKOnCancel();
45 //-----------------------------------------------------------------------------
47 //-----------------------------------------------------------------------------
49 IMPLEMENT_DYNAMIC_CLASS(wxDirDialog
, wxDialog
)
51 wxDirDialog::wxDirDialog(wxWindow
* parent
,
52 const wxString
& title
,
53 const wxString
& defaultPath
,
56 const wxSize
& WXUNUSED(sz
),
57 const wxString
& WXUNUSED(name
))
59 Create(parent
, title
, defaultPath
, style
, pos
);
62 bool wxDirDialog::Create(wxWindow
* parent
,
63 const wxString
& title
,
64 const wxString
& defaultPath
,
67 const wxSize
& WXUNUSED(sz
),
68 const wxString
& WXUNUSED(name
))
72 parent
= GetParentForModalDialog(parent
, style
);
74 if (!PreCreation(parent
, pos
, wxDefaultSize
) ||
75 !CreateBase(parent
, wxID_ANY
, pos
, wxDefaultSize
, style
,
76 wxDefaultValidator
, wxT("dirdialog")))
78 wxFAIL_MSG( wxT("wxDirDialog creation failed") );
82 GtkWindow
* gtk_parent
= NULL
;
84 gtk_parent
= GTK_WINDOW( gtk_widget_get_toplevel(parent
->m_widget
) );
86 m_widget
= gtk_file_chooser_dialog_new(
87 wxGTK_CONV(m_message
),
89 GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER
,
90 GTK_STOCK_CANCEL
, GTK_RESPONSE_CANCEL
,
91 GTK_STOCK_OPEN
, GTK_RESPONSE_ACCEPT
,
93 g_object_ref(m_widget
);
95 gtk_dialog_set_default_response(GTK_DIALOG(m_widget
), GTK_RESPONSE_ACCEPT
);
97 // gtk_widget_hide_on_delete is used here to avoid that Gtk automatically destroys
98 // the dialog when the user press ESC on the dialog: in that case a second call to
99 // ShowModal() would result in a bunch of Gtk-CRITICAL errors...
100 g_signal_connect (m_widget
,
102 G_CALLBACK (gtk_widget_hide_on_delete
),
105 // local-only property could be set to false to allow non-local files to be loaded.
106 // In that case get/set_uri(s) should be used instead of get/set_filename(s) everywhere
107 // and the GtkFileChooserDialog should probably also be created with a backend,
108 // e.g. "gnome-vfs", "default", ... (gtk_file_chooser_dialog_new_with_backend).
109 // Currently local-only is kept as the default - true:
110 // gtk_file_chooser_set_local_only(GTK_FILE_CHOOSER(m_widget), true);
112 g_signal_connect (m_widget
, "response",
113 G_CALLBACK (gtk_dirdialog_response_callback
), this);
115 if ( !defaultPath
.empty() )
116 SetPath(defaultPath
);
121 void wxDirDialog::GTKOnAccept()
123 wxGtkString
str(gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(m_widget
)));
124 m_selectedDirectory
= wxString::FromUTF8(str
);
126 // change to the directory where the user went if asked
127 if (HasFlag(wxDD_CHANGE_DIR
))
129 wxSetWorkingDirectory(m_selectedDirectory
);
135 void wxDirDialog::GTKOnCancel()
137 EndDialog(wxID_CANCEL
);
140 void wxDirDialog::DoSetSize(int x
, int y
, int width
, int height
, int sizeFlags
)
145 wxDirDialogBase::DoSetSize( x
, y
, width
, height
, sizeFlags
);
148 void wxDirDialog::SetPath(const wxString
& dir
)
150 if (wxDirExists(dir
))
152 gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(m_widget
),
157 wxString
wxDirDialog::GetPath() const
159 return m_selectedDirectory
;
162 #endif // wxUSE_DIRDLG