From 2d67f5fcd6607b11974f42f33eb44427b1154aba Mon Sep 17 00:00:00 2001 From: Adrien Destugues Date: Tue, 20 Jul 2010 17:44:14 +0000 Subject: [PATCH] Locale preflet : make the 12/24hr switching system more robust and lossless * When selecting chinese, the AM/PM stays at the beginning of the string * When clicking multiple times on the 12 hours button, the AM/PM indicator is added only once. * Only regression : the default format for cherokee (US) uses a 12hour clock without AM/PM indicator, so it is not possible to switch it to a 24Hr clock scheme. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@37628 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- src/kits/locale/LocaleRoster.cpp | 4 +- .../locale/TimeFormatSettingsView.cpp | 80 ++++++++++++------- .../locale/TimeFormatSettingsView.h | 4 + 3 files changed, 55 insertions(+), 33 deletions(-) diff --git a/src/kits/locale/LocaleRoster.cpp b/src/kits/locale/LocaleRoster.cpp index f612cc1878..4ec66d89aa 100644 --- a/src/kits/locale/LocaleRoster.cpp +++ b/src/kits/locale/LocaleRoster.cpp @@ -617,8 +617,8 @@ BLocaleRoster::GetInstalledLanguages(BMessage *languages) const status_t -BLocaleRoster::GetInstalledCatalogs(BMessage * languageList, const char* sigPattern, - const char* langPattern, int32 fingerprint) const +BLocaleRoster::GetInstalledCatalogs(BMessage * languageList, + const char* sigPattern, const char* langPattern, int32 fingerprint) const { if (languageList == NULL) return B_BAD_VALUE; diff --git a/src/preferences/locale/TimeFormatSettingsView.cpp b/src/preferences/locale/TimeFormatSettingsView.cpp index 5d6f6323d7..0494b32783 100644 --- a/src/preferences/locale/TimeFormatSettingsView.cpp +++ b/src/preferences/locale/TimeFormatSettingsView.cpp @@ -30,6 +30,8 @@ #include #include +#include + #undef B_TRANSLATE_CONTEXT #define B_TRANSLATE_CONTEXT "TimeFormatSettings" @@ -181,12 +183,15 @@ FormatView::FormatView(BCountry* country) f12HrRadioButton = new BRadioButton("", B_TRANSLATE("12 hour"), new BMessage(kClockFormatChange)); - BString timeFormat; - fCountry->TimeFormat(timeFormat, false); - if (timeFormat.FindFirst("a") != B_ERROR) - f12HrRadioButton->SetValue(1); - else - f24HrRadioButton->SetValue(1); + fCountry->TimeFormat(fOriginalTimeFormat, false); + fCountry->TimeFormat(fOriginalLongTimeFormat, true); + if (fOriginalTimeFormat.FindFirst("a") != B_ERROR) { + f12HrRadioButton->SetValue(B_CONTROL_ON); + fCountryIs24Hr = false; + } else { + f24HrRadioButton->SetValue(B_CONTROL_ON); + fCountryIs24Hr = true; + } float spacing = be_control_look->DefaultItemSpacing(); @@ -376,11 +381,11 @@ FormatView::MessageReceived(BMessage* message) { // Update one of the dropdown menus void* pointerFromMessage; - message->FindPointer("dest",&pointerFromMessage); + message->FindPointer("dest", &pointerFromMessage); BMenuField* menuField = static_cast(pointerFromMessage); BString format; - message->FindString("format",&format); + message->FindString("format", &format); for (int i = 0; i < 4; i++) { if (fLongDateMenu[i]==menuField) { @@ -437,30 +442,37 @@ FormatView::MessageReceived(BMessage* message) case kClockFormatChange: { BString timeFormat; - fCountry->TimeFormat(timeFormat, false); + timeFormat = fOriginalTimeFormat; if (f24HrRadioButton->Value() == 1) { - timeFormat.ReplaceAll("k", "h"); - timeFormat.ReplaceAll("K", "H"); - timeFormat.RemoveAll(" a"); + if (!fCountryIs24Hr) { + timeFormat.ReplaceAll("h", "H"); + timeFormat.ReplaceAll("k", "K"); + timeFormat.RemoveAll(" a"); + timeFormat.RemoveAll("a"); + } } else { - timeFormat.ReplaceAll("h", "k"); - timeFormat.ReplaceAll("H", "K"); - timeFormat.Append(" a"); - f12HrRadioButton->SetValue(true); + if (fCountryIs24Hr && timeFormat.FindFirst("a") == B_ERROR) { + timeFormat.ReplaceAll("K", "k"); + timeFormat.ReplaceAll("H", "h"); + timeFormat.Append(" a"); + } } fCountry->SetTimeFormat(timeFormat.String(), false); - timeFormat.Truncate(0); - - fCountry->TimeFormat(timeFormat, true); + timeFormat = fOriginalLongTimeFormat; if (f24HrRadioButton->Value() == 1) { - timeFormat.ReplaceAll("k", "h"); - timeFormat.ReplaceAll("K", "H"); - timeFormat.RemoveAll(" a"); + if (!fCountryIs24Hr) { + timeFormat.ReplaceAll("h", "H"); + timeFormat.ReplaceAll("k", "K"); + timeFormat.RemoveAll(" a"); + timeFormat.RemoveAll("a"); + } } else { - timeFormat.ReplaceAll("h", "k"); - timeFormat.ReplaceAll("H", "K"); - timeFormat.Append(" a"); + if (fCountryIs24Hr && timeFormat.FindFirst("a") == B_ERROR) { + timeFormat.ReplaceAll("K", "k"); + timeFormat.ReplaceAll("H", "h"); + timeFormat.Append(" a"); + } } fCountry->SetTimeFormat(timeFormat.String(), true); _UpdateExamples(); @@ -528,12 +540,18 @@ FormatView::SetCountry(BCountry* country) delete fCountry; fCountry = country; - BString timeFormat; - fCountry->TimeFormat(timeFormat, false); - if (timeFormat.FindFirst("a") != B_ERROR) - f12HrRadioButton->SetValue(1); - else - f24HrRadioButton->SetValue(1); + fOriginalTimeFormat.Truncate(0); + fCountry->TimeFormat(fOriginalTimeFormat, false); + fOriginalLongTimeFormat.Truncate(0); + fCountry->TimeFormat(fOriginalLongTimeFormat, true); + + if (fOriginalTimeFormat.FindFirst("a") != B_ERROR) { + f12HrRadioButton->SetValue(B_CONTROL_ON); + fCountryIs24Hr = false; + } else { + f24HrRadioButton->SetValue(B_CONTROL_ON); + fCountryIs24Hr = true; + } /* FormatSeparator separator = settings.TimeFormatSeparator(); diff --git a/src/preferences/locale/TimeFormatSettingsView.h b/src/preferences/locale/TimeFormatSettingsView.h index 36385cbd4f..d036bdd092 100644 --- a/src/preferences/locale/TimeFormatSettingsView.h +++ b/src/preferences/locale/TimeFormatSettingsView.h @@ -77,6 +77,10 @@ private: FormatSeparator fSeparator; BString fDateFormat; + BString fOriginalTimeFormat; + BString fOriginalLongTimeFormat; + bool fCountryIs24Hr; + BCountry* fCountry; BBox* fDateBox;