1 // System.Globalization.CultureInfo
3 // Miguel de Icaza (miguel@ximian.com)
5 // (C) Ximian, Inc. 2001 (http://www.ximian.com)
7 using System.Threading;
9 namespace System.Globalization
11 public class CultureInfo
13 static CultureInfo invariant_culture_info;
16 bool use_user_override;
17 NumberFormatInfo number_format;
18 DateTimeFormatInfo datetime_format;
20 private static readonly string MSG_READONLY = "This instance is read only";
23 // Returns the Invariant Culture Information ("iv")
25 static public CultureInfo InvariantCulture {
27 if (invariant_culture_info != null)
28 return invariant_culture_info;
30 invariant_culture_info = new CultureInfo (0x07f, false);
31 invariant_culture_info.is_read_only = true;
33 return invariant_culture_info;
38 // Initializes the CultureInfo object for the specific culture_id
40 void InitializeByID (int culture_id, bool use_user_override)
43 case 0x0001: // ar Arabic
44 case 0x0401: // ar-SA Arabic (Saudi Arabia)
45 case 0x0801: // ar-IQ Arabic (Iraq)
46 case 0x0C01: // ar-EG Arabic (Egypt)
47 case 0x1001: // ar-LY Arabic (Libya)
48 case 0x1401: // ar-DZ Arabic (Algeria)
49 case 0x1801: // ar-MA Arabic (Morocco)
50 case 0x1C01: // ar-TN Arabic (Tunisia)
51 case 0x2001: // ar-OM Arabic (Oman)
52 case 0x2401: // ar-YE Arabic (Yemen)
53 case 0x2801: // ar-SY Arabic (Syria)
54 case 0x2C01: // ar-JO Arabic (Jordan)
55 case 0x3001: // ar-LB Arabic (Lebanon)
56 case 0x3401: // ar-KW Arabic (Kuwait)
57 case 0x3801: // ar-AE Arabic (U.A.E.)
58 case 0x3C01: // ar-BH Arabic (Bahrain)
59 case 0x4001: // ar-QA Arabic (Qatar)
60 case 0x0002: // bg Bulgarian
61 case 0x0402: // bg-BG Bulgarian (Bulgaria)
62 case 0x0003: // ca Catalan
63 case 0x0403: // ca-ES Catalan (Spain)
64 case 0x0004: // zh-CHS Chinese (Simplified)
65 case 0x0404: // zh-TW Chinese (Taiwan)
66 case 0x0804: // zh-CN Chinese (People's Republic of China)
67 case 0x0C04: // zh-HK Chinese (Hong Kong S.A.R.)
68 case 0x1004: // zh-SG Chinese (Singapore)
69 case 0x1404: // zh-MO Chinese (Macau S.A.R.)
70 case 0x7C04: // zh-CHT Chinese (Traditional)
71 case 0x0005: // cs Czech
72 case 0x0405: // cs-CZ Czech (Czech Republic)
73 case 0x0006: // da Danish
74 case 0x0406: // da-DK Danish (Denmark)
75 case 0x0007: // de German
76 case 0x0407: // de-DE German (Germany)
77 case 0x0807: // de-CH German (Switzerland)
78 case 0x0C07: // de-AT German (Austria)
79 case 0x1007: // de-LU German (Luxembourg)
80 case 0x1407: // de-LI German (Liechtenstein)
81 case 0x0008: // el Greek
82 case 0x0408: // el-GR Greek (Greece)
83 case 0x0009: // en English
84 case 0x0409: // en-US English (United States)
85 case 0x0809: // en-GB English (United Kingdom)
86 case 0x0C09: // en-AU English (Australia)
87 case 0x1009: // en-CA English (Canada)
88 case 0x1409: // en-NZ English (New Zealand)
89 case 0x1809: // en-IE English (Ireland)
90 case 0x1C09: // en-ZA English (South Africa)
91 case 0x2009: // en-JM English (Jamaica)
92 case 0x2409: // en-CB English (Caribbean)
93 case 0x2809: // en-BZ English (Belize)
94 case 0x2C09: // en-TT English (Trinidad and Tobago)
95 case 0x3009: // en-ZW English (Zimbabwe)
96 case 0x3409: // en-PH English (Republic of the Philippines)
97 case 0x000A: // es Spanish
98 case 0x080A: // es-MX Spanish (Mexico)
99 case 0x0C0A: // es-ES Spanish (Spain)
100 case 0x100A: // es-GT Spanish (Guatemala)
101 case 0x140A: // es-CR Spanish (Costa Rica)
102 case 0x180A: // es-PA Spanish (Panama)
103 case 0x1C0A: // es-DO Spanish (Dominican Republic)
104 case 0x200A: // es-VE Spanish (Venezuela)
105 case 0x240A: // es-CO Spanish (Colombia)
106 case 0x280A: // es-PE Spanish (Peru)
107 case 0x2C0A: // es-AR Spanish (Argentina)
108 case 0x300A: // es-EC Spanish (Ecuador)
109 case 0x340A: // es-CL Spanish (Chile)
110 case 0x380A: // es-UY Spanish (Uruguay)
111 case 0x3C0A: // es-PY Spanish (Paraguay)
112 case 0x400A: // es-BO Spanish (Bolivia)
113 case 0x440A: // es-SV Spanish (El Salvador)
114 case 0x480A: // es-HN Spanish (Honduras)
115 case 0x4C0A: // es-NI Spanish (Nicaragua)
116 case 0x500A: // es-PR Spanish (Puerto Rico)
117 case 0x000B: // fi Finnish
118 case 0x040B: // fi-FI Finnish (Finland)
119 case 0x000C: // fr French
120 case 0x040C: // fr-FR French (France)
121 case 0x080C: // fr-BE French (Belgium)
122 case 0x0C0C: // fr-CA French (Canada)
123 case 0x100C: // fr-CH French (Switzerland)
124 case 0x140C: // fr-LU French (Luxembourg)
125 case 0x180C: // fr-MC French (Principality of Monaco)
126 case 0x000D: // he Hebrew
127 case 0x040D: // he-IL Hebrew (Israel)
128 case 0x000E: // hu Hungarian
129 case 0x040E: // hu-HU Hungarian (Hungary)
130 case 0x000F: // is Icelandic
131 case 0x040F: // is-IS Icelandic (Iceland)
132 case 0x0010: // it Italian
133 case 0x0410: // it-IT Italian (Italy)
134 case 0x0810: // it-CH Italian (Switzerland)
135 case 0x0011: // ja Japanese
136 case 0x0411: // ja-JP Japanese (Japan)
137 case 0x0012: // ko Korean
138 case 0x0412: // ko-KR Korean (Korea)
139 case 0x0013: // nl Dutch
140 case 0x0413: // nl-NL Dutch (Netherlands)
141 case 0x0813: // nl-BE Dutch (Belgium)
142 case 0x0014: // no Norwegian
143 case 0x0414: // nb-NO Norwegian (Bokmål) (Norway)
144 case 0x0814: // nn-NO Norwegian (Nynorsk) (Norway)
145 case 0x0015: // pl Polish
146 case 0x0415: // pl-PL Polish (Poland)
147 case 0x0016: // pt Portuguese
148 case 0x0416: // pt-BR Portuguese (Brazil)
149 case 0x0816: // pt-PT Portuguese (Portugal)
150 case 0x0018: // ro Romanian
151 case 0x0418: // ro-RO Romanian (Romania)
152 case 0x0019: // ru Russian
153 case 0x0419: // ru-RU Russian (Russia)
154 case 0x001A: // hr Croatian
155 case 0x041A: // hr-HR Croatian (Croatia)
156 case 0x081A: // Lt-sr-SP Serbian (Latin) (Serbia)
157 case 0x0C1A: // Cy-sr-SP Serbian (Cyrillic) (Serbia)
158 case 0x001B: // sk Slovak
159 case 0x041B: // sk-SK Slovak (Slovakia)
160 case 0x001C: // sq Albanian
161 case 0x041C: // sq-AL Albanian (Albania)
162 case 0x001D: // sv Swedish
163 case 0x041D: // sv-SE Swedish (Sweden)
164 case 0x081D: // sv-FI Swedish (Finland)
165 case 0x001E: // th Thai
166 case 0x041E: // th-TH Thai (Thailand)
167 case 0x001F: // tr Turkish
168 case 0x041F: // tr-TR Turkish (Turkey)
169 case 0x0020: // ur Urdu
170 case 0x0420: // ur-PK Urdu (Islamic Republic of Pakistan)
171 case 0x0021: // id Indonesian
172 case 0x0421: // id-ID Indonesian (Indonesia)
173 case 0x0022: // uk Ukrainian
174 case 0x0422: // uk-UA Ukrainian (Ukraine)
175 case 0x0023: // be Belarusian
176 case 0x0423: // be-BY Belarusian (Belarus)
177 case 0x0024: // sl Slovenian
178 case 0x0424: // sl-SI Slovenian (Slovenia)
179 case 0x0025: // et Estonian
180 case 0x0425: // et-EE Estonian (Estonia)
181 case 0x0026: // lv Latvian
182 case 0x0426: // lv-LV Latvian (Latvia)
183 case 0x0027: // lt Lithuanian
184 case 0x0427: // lt-LT Lithuanian (Lithuania)
185 case 0x0029: // fa Farsi
186 case 0x0429: // fa-IR Farsi (Iran)
187 case 0x002A: // vi Vietnamese
188 case 0x042A: // vi-VN Vietnamese (Viet Nam)
189 case 0x002B: // hy Armenian
190 case 0x042B: // hy-AM Armenian (Armenia)
191 case 0x002C: // az Azeri
192 case 0x042C: // Lt-az-AZ Azeri (Latin) (Azerbaijan)
193 case 0x082C: // Cy-az-AZ Azeri (Cyrillic) (Azerbaijan)
194 case 0x002D: // eu Basque
195 case 0x042D: // eu-ES Basque (Spain)
196 case 0x002F: // mk FYRO Macedonian
197 case 0x042F: // mk-MK FYRO Macedonian (Former Yugoslav Republic of Macedonia)
198 case 0x0036: // af Afrikaans
199 case 0x0436: // af-ZA Afrikaans (South Africa)
200 case 0x0037: // ka Georgian
201 case 0x0437: // ka-GE Georgian (Georgia)
202 case 0x0038: // fo Faeroese
203 case 0x0438: // fo-FO Faeroese (Faeroe Islands)
204 case 0x0039: // hi Hindi
205 case 0x0439: // hi-IN Hindi (India)
206 case 0x003E: // ms Malay
207 case 0x043E: // ms-MY Malay (Malaysia)
208 case 0x083E: // ms-BN Malay (Brunei Darussalam)
209 case 0x003F: // kk Kazakh
210 case 0x043F: // kk-KZ Kazakh (Kazakhstan)
211 case 0x0040: // ky Kyrgyz
212 case 0x0440: // ky-KZ Kyrgyz (Kyrgyzstan)
213 case 0x0041: // sw Swahili
214 case 0x0441: // sw-KE Swahili (Kenya)
215 case 0x0043: // uz Uzbek
216 case 0x0443: // Lt-uz-UZ Uzbek (Latin) (Uzbekistan)
217 case 0x0843: // Cy-uz-UZ Uzbek (Cyrillic) (Uzbekistan)
218 case 0x0044: // tt Tatar
219 case 0x0444: // tt-TA Tatar (Tatarstan)
220 case 0x0046: // pa Punjabi
221 case 0x0446: // pa-IN Punjabi (India)
222 case 0x0047: // gu Gujarati
223 case 0x0447: // gu-IN Gujarati (India)
224 case 0x0049: // ta Tamil
225 case 0x0449: // ta-IN Tamil (India)
226 case 0x004A: // te Telugu
227 case 0x044A: // te-IN Telugu (India)
228 case 0x004B: // kn Kannada
229 case 0x044B: // kn-IN Kannada (India)
230 case 0x004E: // mr Marathi
231 case 0x044E: // mr-IN Marathi (India)
232 case 0x004F: // sa Sanskrit
233 case 0x044F: // sa-IN Sanskrit (India)
234 case 0x0050: // mn Mongolian
235 case 0x0450: // mn-MN Mongolian (Mongolia)
236 case 0x0056: // gl Galician
237 case 0x0456: // gl-ES Galician (Spain)
238 case 0x0057: // kok Konkani
239 case 0x0457: // kok-IN Konkani (India)
240 case 0x005A: // syr Syriac
241 case 0x045A: // syr-SY Syriac (Syria)
242 case 0x0065: // div Divehi
243 case 0x0465: // div-MV Divehi (Maldives)
244 case 0x007F: // Invariant Language (Invariant Country)
248 throw new ArgumentException ("CultureInfoCode");
251 this.use_user_override = use_user_override;
255 // Maps a name to a culture id
257 static int NameToID (string name)
669 // Creates a CultureInfo for a specific ID
671 public static CultureInfo CreateSpecificCulture (string name)
674 throw new ArgumentNullException ();
676 int id = NameToID (name);
679 throw new ArgumentException ("name");
681 return new CultureInfo (id, false);
685 /// CultureInfo instance that represents the culture used by the current thread
687 public static CultureInfo CurrentCulture
691 return Thread.CurrentThread.CurrentCulture;
696 Thread.CurrentThread.CurrentCulture = value;
701 /// CultureInfo instance that represents the current culture used by the ResourceManager to look up culture-specific resources at run time
703 public static CultureInfo CurrentUICulture
707 return Thread.CurrentThread.CurrentUICulture;
712 Thread.CurrentThread.CurrentUICulture = value;
717 public virtual int LCID {
724 // Gets the string-encoded name of the culture
726 public virtual string Name {
732 throw new Exception ("Miss constructed object for LCID: " + lcid);
736 internal static bool IsIDNeutralCulture (int lcid) {
737 return (lcid & 0xff00) == 0;
741 // Returns whether the current culture is neutral (neutral cultures
742 // only specify a language, not a country.
744 public virtual bool IsNeutralCulture {
746 return IsIDNeutralCulture (lcid);
750 // Returns the NumberFormat for the current lcid
752 public virtual NumberFormatInfo NumberFormat {
754 if (number_format == null){
756 if (number_format == null)
757 number_format = new NumberFormatInfo (lcid);
761 return number_format;
765 if (is_read_only) throw new InvalidOperationException(MSG_READONLY);
768 throw new ArgumentNullException ("NumberFormat");
770 number_format = value;
774 public virtual DateTimeFormatInfo DateTimeFormat
778 if (datetime_format == null)
782 if (datetime_format == null)
783 datetime_format = new DateTimeFormatInfo();
787 return datetime_format;
792 if (is_read_only) throw new InvalidOperationException(MSG_READONLY);
795 throw new ArgumentNullException ("DateTimeFormat");
797 datetime_format = value;
804 public CultureInfo (int culture, bool use_user_override)
807 throw new ArgumentOutOfRangeException ();
809 InitializeByID (culture, use_user_override);
812 public CultureInfo (int culture) : this (culture, false)
816 public CultureInfo (string name, bool use_user_override)
819 throw new ArgumentNullException ();
821 InitializeByID (NameToID (name), use_user_override);
824 public CultureInfo (string name) : this (name, false) {}