X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/9b82d31bdd6c4f21d9475b52444e57fc1ab94cde..5f8047a69b6396744c726ae52a388d898eab27d9:/src/gtk/aboutdlg.cpp diff --git a/src/gtk/aboutdlg.cpp b/src/gtk/aboutdlg.cpp index 16fb5d14fa..c5c7355563 100644 --- a/src/gtk/aboutdlg.cpp +++ b/src/gtk/aboutdlg.cpp @@ -22,6 +22,7 @@ #if wxUSE_ABOUTDLG && defined(__WXGTK26__) #ifndef WX_PRECOMP + #include "wx/utils.h" // for wxLaunchDefaultBrowser() #endif //WX_PRECOMP #include "wx/aboutdlg.h" @@ -37,7 +38,7 @@ class GtkStr : public wxGtkString { public: GtkStr(const wxString& s) - : wxGtkString(wx_const_cast(char *, wxGTK_CONV_SYS(s).data())) + : wxGtkString(wx_const_cast(char *, wxGTK_CONV_SYS(s).release())) { } }; @@ -81,6 +82,20 @@ 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)); +} + void wxAboutBox(const wxAboutDialogInfo& info) { if ( !gtk_check_version(2,6,0) ) @@ -102,6 +117,11 @@ void wxAboutBox(const wxAboutDialogInfo& info) if ( info.HasWebSite() ) { + // NB: must be called before gtk_about_dialog_set_website() as + // otherwise it has no effect (although GTK+ docs don't mention + // this...) + gtk_about_dialog_set_url_hook(wxGtkAboutDialogOnLink, NULL, NULL); + gtk_about_dialog_set_website(dlg, GtkStr(info.GetWebSiteURL())); gtk_about_dialog_set_website_label ( @@ -116,14 +136,27 @@ void wxAboutBox(const wxAboutDialogInfo& info) gtk_about_dialog_set_documenters(dlg, GtkArray(info.GetDocWriters())); if ( info.HasArtists() ) gtk_about_dialog_set_artists(dlg, GtkArray(info.GetArtists())); + + wxString transCredits; if ( info.HasTranslators() ) { - gtk_about_dialog_set_translator_credits - ( - dlg, - GtkStr(_("translator-credits")) - ); + const wxArrayString& translators = info.GetTranslators(); + const size_t count = translators.size(); + for ( size_t n = 0; n < count; n++ ) + { + transCredits << translators[n] << _T('\n'); + } } + else // no translators explicitely specified + { + // maybe we have translator credits in the message catalog? + transCredits = _("translator-credits"); + } + + 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;