X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/0c545056876c23429f79bec98287be08e3c420f7..bdd6a03de766061057dbd747637446782193afa9:/samples/internat/internat.cpp diff --git a/samples/internat/internat.cpp b/samples/internat/internat.cpp index 6748536e51..c2fa8fcb36 100644 --- a/samples/internat/internat.cpp +++ b/samples/internat/internat.cpp @@ -76,6 +76,7 @@ public: void OnTest1(wxCommandEvent& event); void OnTest2(wxCommandEvent& event); void OnTest3(wxCommandEvent& event); + void OnTestMsgBox(wxCommandEvent& event); DECLARE_EVENT_TABLE() @@ -93,7 +94,8 @@ enum INTERNAT_PLAY, INTERNAT_TEST_1, INTERNAT_TEST_2, - INTERNAT_TEST_3 + INTERNAT_TEST_3, + INTERNAT_TEST_MSGBOX }; // language data @@ -163,6 +165,7 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame) EVT_MENU(INTERNAT_TEST_1, MyFrame::OnTest1) EVT_MENU(INTERNAT_TEST_2, MyFrame::OnTest2) EVT_MENU(INTERNAT_TEST_3, MyFrame::OnTest3) + EVT_MENU(INTERNAT_TEST_MSGBOX, MyFrame::OnTestMsgBox) END_EVENT_TABLE() IMPLEMENT_APP(MyApp) @@ -226,7 +229,7 @@ bool MyApp::OnInit() // don't use wxLOCALE_LOAD_DEFAULT flag so that Init() doesn't return // false just because it failed to load wxstd catalog - if ( !m_locale.Init(m_lang, wxLOCALE_CONV_ENCODING) ) + if ( !m_locale.Init(m_lang, wxLOCALE_DONT_LOAD_DEFAULT) ) { wxLogWarning(_("This language is not supported by the system.")); @@ -240,12 +243,16 @@ bool MyApp::OnInit() wxLocale::AddCatalogLookupPathPrefix("."); // Initialize the catalogs we'll be using + const wxLanguageInfo* pInfo = wxLocale::GetLanguageInfo(m_lang); if (!m_locale.AddCatalog("internat")) - wxLogError(_("Couldn't find/load the 'internat' catalog.")); + { + wxLogError(_("Couldn't find/load the 'internat' catalog for locale '%s'."), + pInfo ? pInfo->GetLocaleName() : _("unknown")); + } // Now try to add wxstd.mo so that loading "NOTEXIST.ING" file will produce // a localized error message: - m_locale.AddCatalog("wxstd.mo"); + m_locale.AddCatalog("wxstd"); // NOTE: it's not an error if we couldn't find it! // this catalog is installed in standard location on Linux systems and @@ -300,6 +307,8 @@ MyFrame::MyFrame(wxLocale& locale) test_menu->Append(INTERNAT_TEST_1, _("&1 _() (gettext)"), _("Tests the _() macro")); test_menu->Append(INTERNAT_TEST_2, _("&2 _N() (ngettext)"), _("Tests the _N() macro")); test_menu->Append(INTERNAT_TEST_3, _("&3 wxTRANSLATE() (gettext_noop)"), _("Tests the wxTRANSLATE() macro")); + test_menu->Append(INTERNAT_TEST_MSGBOX, _("&Message box test"), + _("Tests message box buttons labels translation")); wxMenuBar *menu_bar = new wxMenuBar; menu_bar->Append(file_menu, _("&File")); @@ -330,8 +339,8 @@ void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event)) wxString sysname = m_locale.GetSysName(); wxString canname = m_locale.GetCanonicalName(); - localeInfo.Printf(_("Language: %s\nSystem locale name:\n%s\nCanonical locale name: %s\n"), - locale.c_str(), sysname.c_str(), canname.c_str() ); + localeInfo.Printf(_("Language: %s\nSystem locale name: %s\nCanonical locale name: %s\n"), + locale.c_str(), sysname.c_str(), canname.c_str() ); wxMessageDialog dlg( this, @@ -367,9 +376,9 @@ void MyFrame::OnPlay(wxCommandEvent& WXUNUSED(event)) } else if ( num == 9 ) { - // this message is not translated (not in catalog) because we used _T() + // this message is not translated (not in catalog) because we used wxT() // and not _() around it - str = _T("You've found a bug in this program!"); + str = wxT("You've found a bug in this program!"); } else if ( num == 17 ) { @@ -420,9 +429,13 @@ void MyFrame::OnTestLocaleAvail(wxCommandEvent& WXUNUSED(event)) } if ( wxLocale::IsAvailable(info->Language) ) + { wxLogMessage(_("Locale \"%s\" is available."), s_locale.c_str()); + } else + { wxLogWarning(_("Locale \"%s\" is not available."), s_locale.c_str()); + } } void MyFrame::OnOpen(wxCommandEvent& WXUNUSED(event)) @@ -496,4 +509,17 @@ void MyFrame::OnTest3(wxCommandEvent& WXUNUSED(event)) wxMessageBox(s); } - +void MyFrame::OnTestMsgBox(wxCommandEvent& WXUNUSED(event)) +{ + if ( wxMessageBox + ( + _("Are the labels of the buttons in this message box " + "translated into the current locale language?"), + _("wxWidgets i18n sample"), + wxYES_NO, + this + ) != wxYES ) + { + wxMessageBox(_("Please report the details of your platform to us.")); + } +}