using System;
using System.Globalization;
+using System.Runtime.InteropServices;
using System.Text;
using System.Timers;
using Tizen.Applications.CoreBackend;
/// <since_tizen> 3 </since_tizen>
protected virtual void OnCreate()
{
+ string locale = ULocale.GetDefaultLocale();
+ ChangeCurrentUICultureInfo(locale);
+ ChangeCurrentCultureInfo(locale);
+
Created?.Invoke(this, EventArgs.Empty);
}
/// <since_tizen> 3 </since_tizen>
protected virtual void OnLocaleChanged(LocaleChangedEventArgs e)
{
- ChangeCurrentCultureInfo(e.Locale);
+ ChangeCurrentUICultureInfo(e.Locale);
LocaleChanged?.Invoke(this, e);
}
/// <since_tizen> 3 </since_tizen>
protected virtual void OnRegionFormatChanged(RegionFormatChangedEventArgs e)
{
+ ChangeCurrentCultureInfo(e.Region);
RegionFormatChanged?.Invoke(this, e);
}
base.Dispose(disposing);
}
- private void ChangeCurrentCultureInfo(string locale)
+ private CultureInfo ConvertCultureInfo(string locale)
{
ULocale pLocale = new ULocale(locale);
- CultureInfo currentCultureInfo = null;
try
{
- currentCultureInfo = new CultureInfo(pLocale.Locale.Replace("_", "-"));
+ return new CultureInfo(pLocale.LCID);
+ }
+ catch (ArgumentOutOfRangeException)
+ {
+ return GetFallbackCultureInfo(pLocale);
}
catch (CultureNotFoundException)
{
- currentCultureInfo = GetFallbackCultureInfo(pLocale);
+ return GetFallbackCultureInfo(pLocale);
}
+ }
- CultureInfo.CurrentCulture = currentCultureInfo;
+ private void ChangeCurrentCultureInfo(string locale)
+ {
+ CultureInfo.CurrentCulture = ConvertCultureInfo(locale);
+ }
+
+ private void ChangeCurrentUICultureInfo(string locale)
+ {
+ CultureInfo.CurrentUICulture = ConvertCultureInfo(locale);
+ }
+
+ private bool ExistCultureInfo(string locale)
+ {
+ foreach (var cultureInfo in CultureInfo.GetCultures(CultureTypes.AllCultures))
+ {
+ if (cultureInfo.Name == locale)
+ {
+ return true;
+ }
+ }
+
+ return false;
}
private CultureInfo GetCultureInfo(string locale)
{
- CultureInfo cultureInfo = null;
+ if (!ExistCultureInfo(locale))
+ {
+ return null;
+ }
try
{
- cultureInfo = new CultureInfo(locale);
+ return new CultureInfo(locale);
}
catch (CultureNotFoundException)
{
return null;
}
-
- return cultureInfo;
}
private CultureInfo GetFallbackCultureInfo(ULocale uLocale)
{
- string locale = string.Empty;
- CultureInfo fallbackCultureInfo = null;
+ string locale = uLocale.Locale.Replace("_", "-");
+ CultureInfo fallbackCultureInfo = GetCultureInfo(locale);
- if (uLocale.Script != null && uLocale.Country != null)
+ if (fallbackCultureInfo == null && uLocale.Script != null && uLocale.Country != null)
{
locale = uLocale.Language + "-" + uLocale.Script + "-" + uLocale.Country;
fallbackCultureInfo = GetCultureInfo(locale);
internal class ULocale
{
- private const int ICU_ULOC_FULLNAME_CAPACITY = 157;
- private const int ICU_ULOC_LANG_CAPACITY = 12;
- private const int ICU_ULOC_SCRIPT_CAPACITY = 6;
- private const int ICU_ULOC_COUNTRY_CAPACITY = 4;
- private const int ICU_ULOC_VARIANT_CAPACITY = ICU_ULOC_FULLNAME_CAPACITY;
- private const int ICU_U_ZERO_ERROR = 0;
+ private const int ULOC_FULLNAME_CAPACITY = 157;
+ private const int ULOC_LANG_CAPACITY = 12;
+ private const int ULOC_SCRIPT_CAPACITY = 6;
+ private const int ULOC_COUNTRY_CAPACITY = 4;
+ private const int ULOC_VARIANT_CAPACITY = ULOC_FULLNAME_CAPACITY;
internal ULocale(string locale)
{
Script = GetScript(Locale);
Country = GetCountry(Locale);
Variant = GetVariant(Locale);
+ LCID = GetLCID(Locale);
}
internal string Locale { get; private set; }
internal string Script { get; private set; }
internal string Country { get; private set; }
internal string Variant { get; private set; }
+ internal int LCID { get; private set; }
private string Canonicalize(string localeName)
{
- int err = ICU_U_ZERO_ERROR;
-
// Get the locale name from ICU
- StringBuilder sb = new StringBuilder(ICU_ULOC_FULLNAME_CAPACITY);
- if (Interop.Icu.Canonicalize(localeName, sb, sb.Capacity, out err) <= 0)
+ StringBuilder sb = new StringBuilder(ULOC_FULLNAME_CAPACITY);
+ if (Interop.BaseUtilsi18n.Canonicalize(localeName, sb, sb.Capacity) <= 0)
{
return null;
}
private string GetLanguage(string locale)
{
- int err = ICU_U_ZERO_ERROR;
-
// Get the language name from ICU
- StringBuilder sb = new StringBuilder(ICU_ULOC_LANG_CAPACITY);
- if (Interop.Icu.GetLanguage(locale, sb, sb.Capacity, out err) <= 0)
+ StringBuilder sb = new StringBuilder(ULOC_LANG_CAPACITY);
+ if (Interop.BaseUtilsi18n.GetLanguage(locale, sb, sb.Capacity, out int bufSizeLanguage) != 0)
{
return null;
}
private string GetScript(string locale)
{
- int err = ICU_U_ZERO_ERROR;
-
// Get the script name from ICU
- StringBuilder sb = new StringBuilder(ICU_ULOC_SCRIPT_CAPACITY);
- if (Interop.Icu.GetScript(locale, sb, sb.Capacity, out err) <= 0)
+ StringBuilder sb = new StringBuilder(ULOC_SCRIPT_CAPACITY);
+ if (Interop.BaseUtilsi18n.GetScript(locale, sb, sb.Capacity) <= 0)
{
return null;
}
private string GetCountry(string locale)
{
- int err = ICU_U_ZERO_ERROR;
+ int err = 0;
// Get the country name from ICU
- StringBuilder sb = new StringBuilder(ICU_ULOC_SCRIPT_CAPACITY);
- if (Interop.Icu.GetCountry(locale, sb, sb.Capacity, out err) <= 0)
+ StringBuilder sb = new StringBuilder(ULOC_COUNTRY_CAPACITY);
+ if (Interop.BaseUtilsi18n.GetCountry(locale, sb, sb.Capacity, out err) <= 0)
{
return null;
}
private string GetVariant(string locale)
{
- int err = ICU_U_ZERO_ERROR;
-
// Get the variant name from ICU
- StringBuilder sb = new StringBuilder(ICU_ULOC_VARIANT_CAPACITY);
- if (Interop.Icu.GetVariant(locale, sb, sb.Capacity, out err) <= 0)
+ StringBuilder sb = new StringBuilder(ULOC_VARIANT_CAPACITY);
+ if (Interop.BaseUtilsi18n.GetVariant(locale, sb, sb.Capacity) <= 0)
{
return null;
}
return sb.ToString();
}
+
+ private int GetLCID(string locale)
+ {
+ // Get the LCID from ICU
+ uint lcid = Interop.BaseUtilsi18n.GetLCID(locale);
+ return (int)lcid;
+ }
+
+ internal static string GetDefaultLocale()
+ {
+ IntPtr stringPtr = IntPtr.Zero;
+ if (Interop.BaseUtilsi18n.GetDefault(out stringPtr) != 0)
+ {
+ return string.Empty;
+ }
+
+ if (stringPtr == IntPtr.Zero)
+ {
+ return string.Empty;
+ }
+
+ return Marshal.PtrToStringAnsi(stringPtr);
+ }
}
}