X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6225e6e111b461d54abad7db78ceff2c6398ad9b..621b83d9b34572321873cf3d54920a7749b2f53c:/src/gtk/aboutdlg.cpp diff --git a/src/gtk/aboutdlg.cpp b/src/gtk/aboutdlg.cpp index 5f83dc37fd..d8058f0336 100644 --- a/src/gtk/aboutdlg.cpp +++ b/src/gtk/aboutdlg.cpp @@ -82,12 +82,18 @@ private: // implementation // ============================================================================ +extern "C" void +wxGtkAboutDialogOnClose(GtkAboutDialog *about) +{ + gtk_widget_destroy(GTK_WIDGET(about)); +} + extern "C" void wxGtkAboutDialogOnLink(GtkAboutDialog * WXUNUSED(about), const gchar *link, gpointer WXUNUSED(data)) { - wxLaunchDefaultBrowser(wxGTK_CONV_BACK(link)); + wxLaunchDefaultBrowser(wxGTK_CONV_BACK_SYS(link)); } void wxAboutBox(const wxAboutDialogInfo& info) @@ -144,10 +150,23 @@ void wxAboutBox(const wxAboutDialogInfo& info) else // no translators explicitely specified { // maybe we have translator credits in the message catalog? - transCredits = _("translator-credits"); + wxString translator = _("translator-credits"); + + // gtk_about_dialog_set_translator_credits() is smart enough to + // detect if "translator-credits" is untranslated and hide the + // translators tab in that case, however it will still show the + // "credits" button, (at least GTK 2.10.6) even if there are no + // credits informations at all, so we still need to do the check + // ourselves + if ( translator != wxT("translator-credits") ) // untranslated! + transCredits = translator; } - gtk_about_dialog_set_translator_credits(dlg, GtkStr(transCredits)); + if ( !transCredits.empty() ) + gtk_about_dialog_set_translator_credits(dlg, GtkStr(transCredits)); + + g_signal_connect(dlg, "response", + G_CALLBACK(wxGtkAboutDialogOnClose), NULL); gtk_widget_show(GTK_WIDGET(dlg)); return;