All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.neovisionaries.i18n.LocaleCode Maven / Gradle / Ivy

/*
 * Copyright (C) 2012-2016 Neo Visionaries Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.neovisionaries.i18n;


import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List;
import java.util.Locale;


/**
 * Locale code.
 *
 * 

* The list of the enum entries was generated based on the output from * {@link java.util.Locale#getAvailableLocales() * Locale.getAvailableLocales()} of Java SE 7, but locales whose * format do not match either 'xx' or 'xx-XX' were excluded. *

* *
 * // List all the locale codes.
 * for (LocaleCode code : LocaleCode.values())
 * {
 *     String language = code.{@link #getLanguage()}.{@link LanguageCode#getName() getName()};
 *     String country  = code.{@link #getCountry()} != null
 *                     ? code.{@link #getCountry()}.{@link CountryCode#getName() getName()} : null;
 *
 *     // For example, "[de-DE] German, Germany" is printed.
 *     System.out.format("[%s] %s, %s\n", code, language, country);
 * }
 *
 * // Get a LocaleCode instance in various ways.
 * LocaleCode code;
 * code = LocaleCode.{@link #getByCode(String) getByCode}("en-GB");
 * code = LocaleCode.{@link #getByCode(String, String) getByCode}("es", "ES");
 * code = LocaleCode.{@link #getByLocale(Locale) getByLocale}(new Locale("pt", "BR"));
 *
 * // Convert to a Locale instance.
 * Locale locale = LocaleCode.{@link #en}.{@link #toLocale()};
 *
 * // toLocale() of some LocaleCode instances does not create
 * // a new Locale instance but returns a static variable of
 * // Locale class instead. See {@link #toLocale()} for details.
 * if (locale == Locale.ENGLISH)
 * {
 *     System.out.println("Locale.en.toLocale() returned Locale.ENGLISH");
 * }
 *
 * // Get a list of LocaleCode instances whose language is Arabic.
 * List<LocaleCode> list = LocaleCode.{@link #getByLanguage(LanguageCode) getByLanguage}({@link LanguageCode#ar});
 *
 * // Get a list of LocaleCode instances whose country is Switzerland.
 * list = LocaleCode.{@link #getByCountry(CountryCode) getByCountry}({@link CountryCode#CH});
 * 
* * @author Takahiko Kawasaki */ public enum LocaleCode { /** * {@link LanguageCode#undefined Undefined}, {@link CountryCode#UNDEFINED Undefined} * * @since 1.14 */ undefined(LanguageCode.undefined, CountryCode.UNDEFINED) { @Override public Locale toLocale() { return undefinedLocale; } }, /** * {@link LanguageCode#ar Arabic} */ ar(LanguageCode.ar, null), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#AE United Arab Emirates} */ ar_AE(LanguageCode.ar, CountryCode.AE), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#BH Bahrain} */ ar_BH(LanguageCode.ar, CountryCode.BH), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#DZ Algeria} */ ar_DZ(LanguageCode.ar, CountryCode.DZ), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#EG Egypt} */ ar_EG(LanguageCode.ar, CountryCode.EG), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#IQ Iraq} */ ar_IQ(LanguageCode.ar, CountryCode.IQ), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#JO Jordan} */ ar_JO(LanguageCode.ar, CountryCode.JO), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#KW Kuwait} */ ar_KW(LanguageCode.ar, CountryCode.KW), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#LB Lebanon} */ ar_LB(LanguageCode.ar, CountryCode.LB), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#LY Libya} */ ar_LY(LanguageCode.ar, CountryCode.LY), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#MA Morocco} */ ar_MA(LanguageCode.ar, CountryCode.MA), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#OM Oman} */ ar_OM(LanguageCode.ar, CountryCode.OM), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#QA Qatar} */ ar_QA(LanguageCode.ar, CountryCode.QA), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#SA Saudi Arabia} */ ar_SA(LanguageCode.ar, CountryCode.SA), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#SD Sudan} */ ar_SD(LanguageCode.ar, CountryCode.SD), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#SY Syrian Arab Republic} */ ar_SY(LanguageCode.ar, CountryCode.SY), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#TN Tunisia} */ ar_TN(LanguageCode.ar, CountryCode.TN), /** * {@link LanguageCode#ar Arabic}, {@link CountryCode#YE Yemen} */ ar_YE(LanguageCode.ar, CountryCode.YE), /** * {@link LanguageCode#be Belarusian} */ be(LanguageCode.be, null), /** * {@link LanguageCode#be Belarusian}, {@link CountryCode#BY Belarus} */ be_BY(LanguageCode.be, CountryCode.BY), /** * {@link LanguageCode#bg Bulgarian} */ bg(LanguageCode.bg, null), /** * {@link LanguageCode#bg Bulgarian}, {@link CountryCode#BG Bulgaria} */ bg_BG(LanguageCode.bg, CountryCode.BG), /** * {@link LanguageCode#ca Catalan} */ ca(LanguageCode.ca, null), /** * {@link LanguageCode#ca Catalan}, {@link CountryCode#ES Spain} */ ca_ES(LanguageCode.ca, CountryCode.ES), /** * {@link LanguageCode#cs Czech} */ cs(LanguageCode.cs, null), /** * {@link LanguageCode#cs Czech}, {@link CountryCode#CZ Czech Republic} */ cs_CZ(LanguageCode.cs, CountryCode.CZ), /** * {@link LanguageCode#da Danish} */ da(LanguageCode.da, null), /** * {@link LanguageCode#da Danish}, {@link CountryCode#DK Denmark} */ da_DK(LanguageCode.da, CountryCode.DK), /** * {@link LanguageCode#de German} */ de(LanguageCode.de, null) { @Override public Locale toLocale() { return Locale.GERMAN; } }, /** * {@link LanguageCode#de German}, {@link CountryCode#AT Austria} */ de_AT(LanguageCode.de, CountryCode.AT), /** * {@link LanguageCode#de German}, {@link CountryCode#CH Switzerland} */ de_CH(LanguageCode.de, CountryCode.CH), /** * {@link LanguageCode#de German}, {@link CountryCode#DE Germany} */ de_DE(LanguageCode.de, CountryCode.DE), /** * {@link LanguageCode#de German}, {@link CountryCode#LU Luxembourg} */ de_LU(LanguageCode.de, CountryCode.LU), /** * {@link LanguageCode#el Greek} */ el(LanguageCode.el, null), /** * {@link LanguageCode#el Greek}, {@link CountryCode#CY Cyprus} */ el_CY(LanguageCode.el, CountryCode.CY), /** * {@link LanguageCode#el Greek}, {@link CountryCode#GR Greece} */ el_GR(LanguageCode.el, CountryCode.GR), /** * {@link LanguageCode#en English} */ en(LanguageCode.en, null) { @Override public Locale toLocale() { return Locale.ENGLISH; } }, /** * {@link LanguageCode#en English}, {@link CountryCode#AU Australia} */ en_AU(LanguageCode.en, CountryCode.AU), /** * {@link LanguageCode#en English}, {@link CountryCode#CA Canada} */ en_CA(LanguageCode.en, CountryCode.CA), /** * {@link LanguageCode#en English}, {@link CountryCode#GB United Kingdom} */ en_GB(LanguageCode.en, CountryCode.GB), /** * {@link LanguageCode#en English}, {@link CountryCode#IE Ireland} */ en_IE(LanguageCode.en, CountryCode.IE), /** * {@link LanguageCode#en English}, {@link CountryCode#IN India} */ en_IN(LanguageCode.en, CountryCode.IN), /** * {@link LanguageCode#en English}, {@link CountryCode#MT Malta} */ en_MT(LanguageCode.en, CountryCode.MT), /** * {@link LanguageCode#en English}, {@link CountryCode#NZ New Zealand} */ en_NZ(LanguageCode.en, CountryCode.NZ), /** * {@link LanguageCode#en English}, {@link CountryCode#PH Philippines} */ en_PH(LanguageCode.en, CountryCode.PH), /** * {@link LanguageCode#en English}, {@link CountryCode#SG Singapore} */ en_SG(LanguageCode.en, CountryCode.SG), /** * {@link LanguageCode#en English}, {@link CountryCode#US United States} */ en_US(LanguageCode.en, CountryCode.US), /** * {@link LanguageCode#en English}, {@link CountryCode#ZA South Africa} */ en_ZA(LanguageCode.en, CountryCode.ZA), /** * {@link LanguageCode#es Spanish} */ es(LanguageCode.es, null), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#AR Argentina} */ es_AR(LanguageCode.es, CountryCode.AR), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#BO Bolivia, Plurinational State of} */ es_BO(LanguageCode.es, CountryCode.BO), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#CL Chile} */ es_CL(LanguageCode.es, CountryCode.CL), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#CO Colombia} */ es_CO(LanguageCode.es, CountryCode.CO), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#CR Costa Rica} */ es_CR(LanguageCode.es, CountryCode.CR), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#DO Dominican Republic} */ es_DO(LanguageCode.es, CountryCode.DO), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#EC Ecuador} */ es_EC(LanguageCode.es, CountryCode.EC), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#ES Spain} */ es_ES(LanguageCode.es, CountryCode.ES), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#GT Guatemala} */ es_GT(LanguageCode.es, CountryCode.GT), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#HN Honduras} */ es_HN(LanguageCode.es, CountryCode.HN), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#MX Mexico} */ es_MX(LanguageCode.es, CountryCode.MX), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#NI Nicaragua} */ es_NI(LanguageCode.es, CountryCode.NI), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#PA Panama} */ es_PA(LanguageCode.es, CountryCode.PA), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#PE Peru} */ es_PE(LanguageCode.es, CountryCode.PE), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#PR Puerto Rico} */ es_PR(LanguageCode.es, CountryCode.PR), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#PY Paraguay} */ es_PY(LanguageCode.es, CountryCode.PY), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#SV El Salvador} */ es_SV(LanguageCode.es, CountryCode.SV), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#US United States} */ es_US(LanguageCode.es, CountryCode.US), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#UY Uruguay} */ es_UY(LanguageCode.es, CountryCode.UY), /** * {@link LanguageCode#es Spanish}, {@link CountryCode#VE Venezuela, Bolivarian Republic of} */ es_VE(LanguageCode.es, CountryCode.VE), /** * {@link LanguageCode#et Estonian} */ et(LanguageCode.et, null), /** * {@link LanguageCode#et Estonian}, {@link CountryCode#EE Estonia} */ et_EE(LanguageCode.et, CountryCode.EE), /** * {@link LanguageCode#fa Farsi} * * @since 1.21 */ fa(LanguageCode.fa, null), /** * {@link LanguageCode#fa Farsi}, {@link CountryCode#IR Iran} * * @since 1.21 */ fa_IR(LanguageCode.fa, CountryCode.IR), /** * {@link LanguageCode#fi Finnish} */ fi(LanguageCode.fi, null), /** * {@link LanguageCode#fi Finnish}, {@link CountryCode#FI Finland} */ fi_FI(LanguageCode.fi, CountryCode.FI), /** * {@link LanguageCode#fr French} */ fr(LanguageCode.fr, null) { @Override public Locale toLocale() { return Locale.FRENCH; } }, /** * {@link LanguageCode#fr French}, {@link CountryCode#BE Belgium} */ fr_BE(LanguageCode.fr, CountryCode.BE), /** * {@link LanguageCode#fr French}, {@link CountryCode#CA Canada} */ fr_CA(LanguageCode.fr, CountryCode.CA) { @Override public Locale toLocale() { return Locale.CANADA_FRENCH; } }, /** * {@link LanguageCode#fr French}, {@link CountryCode#CH Switzerland} */ fr_CH(LanguageCode.fr, CountryCode.CH), /** * {@link LanguageCode#fr French}, {@link CountryCode#FR France} */ fr_FR(LanguageCode.fr, CountryCode.FR), /** * {@link LanguageCode#fr French}, {@link CountryCode#LU Luxembourg} */ fr_LU(LanguageCode.fr, CountryCode.LU), /** * {@link LanguageCode#ga Irish} */ ga(LanguageCode.ga, null), /** * {@link LanguageCode#ga Irish}, {@link CountryCode#IE Ireland} */ ga_IE(LanguageCode.ga, CountryCode.IE), /** * {@link LanguageCode#he Hebrew} */ he(LanguageCode.he, null), /** * {@link LanguageCode#he Hebrew}, {@link CountryCode#IL Israel} */ he_IL(LanguageCode.he, CountryCode.IL), /** * {@link LanguageCode#hi Hindi}, {@link CountryCode#IN India} */ hi_IN(LanguageCode.hi, CountryCode.IN), /** * {@link LanguageCode#hr Croatian} */ hr(LanguageCode.hr, null), /** * {@link LanguageCode#hr Croatian}, {@link CountryCode#HR Croatia} */ hr_HR(LanguageCode.hr, CountryCode.HR), /** * {@link LanguageCode#hu Hungarian} */ hu(LanguageCode.hu, null), /** * {@link LanguageCode#hu Hungarian}, {@link CountryCode#HU Hungary} */ hu_HU(LanguageCode.hu, CountryCode.HU), /** * {@link LanguageCode#id Indonesian} */ id(LanguageCode.id, null), /** * {@link LanguageCode#id Indonesian}, {@link CountryCode#ID Indonesia} */ id_ID(LanguageCode.id, CountryCode.ID), /** * {@link LanguageCode#is Icelandic} */ is(LanguageCode.is, null), /** * {@link LanguageCode#is Icelandic}, {@link CountryCode#IS Iceland} */ is_IS(LanguageCode.is, CountryCode.IS), /** * {@link LanguageCode#it Italian} */ it(LanguageCode.it, null) { @Override public Locale toLocale() { return Locale.ITALIAN; } }, /** * {@link LanguageCode#it Italian}, {@link CountryCode#CH Switzerland} */ it_CH(LanguageCode.it, CountryCode.CH), /** * {@link LanguageCode#it Italian}, {@link CountryCode#IT Italy} */ it_IT(LanguageCode.it, CountryCode.IT), /** * {@link LanguageCode#ja Japanese} */ ja(LanguageCode.ja, null) { @Override public Locale toLocale() { return Locale.JAPANESE; } }, /** * {@link LanguageCode#ja Japanese}, {@link CountryCode#JP Japan} */ ja_JP(LanguageCode.ja, CountryCode.JP), /** * {@link LanguageCode#ko Korean} */ ko(LanguageCode.ko, null) { @Override public Locale toLocale() { return Locale.KOREAN; } }, /** * {@link LanguageCode#ko Korean}, {@link CountryCode#KR Korea, Republic of} */ ko_KR(LanguageCode.ko, CountryCode.KR), /** * {@link LanguageCode#lt Lithuanian} */ lt(LanguageCode.lt, null), /** * {@link LanguageCode#lt Lithuanian}, {@link CountryCode#LT Lithuania} */ lt_LT(LanguageCode.lt, CountryCode.LT), /** * {@link LanguageCode#lv Latvian} */ lv(LanguageCode.lv, null), /** * {@link LanguageCode#lv Latvian}, {@link CountryCode#LV Latvia} */ lv_LV(LanguageCode.lv, CountryCode.LV), /** * {@link LanguageCode#mk Macedonian} */ mk(LanguageCode.mk, null), /** * {@link LanguageCode#mk Macedonian}, {@link CountryCode#MK Macedonia, the former Yugoslav Republic of} */ mk_MK(LanguageCode.mk, CountryCode.MK), /** * {@link LanguageCode#ms Malay} */ ms(LanguageCode.ms, null), /** * {@link LanguageCode#ms Malay}, {@link CountryCode#MY Malaysia} */ ms_MY(LanguageCode.ms, CountryCode.MY), /** * {@link LanguageCode#mt Maltese} */ mt(LanguageCode.mt, null), /** * {@link LanguageCode#mt Maltese}, {@link CountryCode#MT Malta} */ mt_MT(LanguageCode.mt, CountryCode.MT), /** * {@link LanguageCode#nb Norwegian Bokmål} * * @since 1.8 */ nb(LanguageCode.nb, null), /** * {@link LanguageCode#nb Norwegian Bokmål}, {@link CountryCode#NO Norway} * * @since 1.8 */ nb_NO(LanguageCode.nb, CountryCode.NO), /** * {@link LanguageCode#nl Dutch} */ nl(LanguageCode.nl, null), /** * {@link LanguageCode#nl Dutch}, {@link CountryCode#BE Belgium} */ nl_BE(LanguageCode.nl, CountryCode.BE), /** * {@link LanguageCode#nl Dutch}, {@link CountryCode#NL Netherlands} */ nl_NL(LanguageCode.nl, CountryCode.NL), /** * {@link LanguageCode#nn Norwegian Nynorsk}, {@link CountryCode#NO Norway} */ nn_NO(LanguageCode.nn, CountryCode.NO), /** * {@link LanguageCode#no Norwegian} * * @deprecated {@link #nb} or {@link #nb_NO} should be used. * @see Språkkoder for POSIX locale i Norge * @see Red Hat Bugzilla – Bug 532487 Legacy Norwegian locale (no_NO) * should be removed from language selection menu */ no(LanguageCode.no, null), /** * {@link LanguageCode#no Norwegian}, {@link CountryCode#NO Norway} * * @deprecated {@link #nb_NO} should be used. * @see Språkkoder for POSIX locale i Norge * @see Red Hat Bugzilla – Bug 532487 Legacy Norwegian locale (no_NO) * should be removed from language selection menu */ no_NO(LanguageCode.no, CountryCode.NO), /** * {@link LanguageCode#pl Polish} */ pl(LanguageCode.pl, null), /** * {@link LanguageCode#pl Polish}, {@link CountryCode#PL Poland} */ pl_PL(LanguageCode.pl, CountryCode.PL), /** * {@link LanguageCode#pt Portuguese} */ pt(LanguageCode.pt, null), /** * {@link LanguageCode#pt Portuguese}, {@link CountryCode#BR Brazil} */ pt_BR(LanguageCode.pt, CountryCode.BR), /** * {@link LanguageCode#pt Portuguese}, {@link CountryCode#PT Portugal} */ pt_PT(LanguageCode.pt, CountryCode.PT), /** * {@link LanguageCode#ro Romanian} */ ro(LanguageCode.ro, null), /** * {@link LanguageCode#ro Romanian}, {@link CountryCode#RO Romania} */ ro_RO(LanguageCode.ro, CountryCode.RO), /** * {@link LanguageCode#ru Russian} */ ru(LanguageCode.ru, null), /** * {@link LanguageCode#ru Russian}, {@link CountryCode#RU Russian Federation} */ ru_RU(LanguageCode.ru, CountryCode.RU), /** * {@link LanguageCode#se Northern Sami} * * @since 1.8 */ se(LanguageCode.se, null), /** * {@link LanguageCode#se Northern Sami}, {@link CountryCode#NO Norway} * * @since 1.8 */ se_NO(LanguageCode.se, CountryCode.NO), /** * {@link LanguageCode#sk Slovak} */ sk(LanguageCode.sk, null), /** * {@link LanguageCode#sk Slovak}, {@link CountryCode#SK Slovakia} */ sk_SK(LanguageCode.sk, CountryCode.SK), /** * {@link LanguageCode#sl Slovene} */ sl(LanguageCode.sl, null), /** * {@link LanguageCode#sl Slovene}, {@link CountryCode#SI Slovenia} */ sl_SI(LanguageCode.sl, CountryCode.SI), /** * {@link LanguageCode#sq Albanian} */ sq(LanguageCode.sq, null), /** * {@link LanguageCode#sq Albanian}, {@link CountryCode#AL Albania} */ sq_AL(LanguageCode.sq, CountryCode.AL), /** * {@link LanguageCode#sr Serbian} */ sr(LanguageCode.sr, null), /** * {@link LanguageCode#sr Serbian}, {@link CountryCode#BA Bosnia and Herzegovina} */ sr_BA(LanguageCode.sr, CountryCode.BA), /** * {@link LanguageCode#sr Serbian}, {@link CountryCode#CS Serbia and Montenegro} */ sr_CS(LanguageCode.sr, CountryCode.CS), /** * {@link LanguageCode#sr Serbian}, {@link CountryCode#ME Montenegro} */ sr_ME(LanguageCode.sr, CountryCode.ME), /** * {@link LanguageCode#sr Serbian}, {@link CountryCode#RS Serbia} */ sr_RS(LanguageCode.sr, CountryCode.RS), /** * {@link LanguageCode#sv Swedish} */ sv(LanguageCode.sv, null), /** * {@link LanguageCode#sv Swedish}, {@link CountryCode#SE Sweden} */ sv_SE(LanguageCode.sv, CountryCode.SE), /** * {@link LanguageCode#th Thai} */ th(LanguageCode.th, null), /** * {@link LanguageCode#th Thai}, {@link CountryCode#TH Thailand} */ th_TH(LanguageCode.th, CountryCode.TH), /** * {@link LanguageCode#tr Turkish} */ tr(LanguageCode.tr, null), /** * {@link LanguageCode#tr Turkish}, {@link CountryCode#TR Turkey} */ tr_TR(LanguageCode.tr, CountryCode.TR), /** * {@link LanguageCode#uk Ukrainian} */ uk(LanguageCode.uk, null), /** * {@link LanguageCode#uk Ukrainian}, {@link CountryCode#UA Ukraine} */ uk_UA(LanguageCode.uk, CountryCode.UA), /** * {@link LanguageCode#vi Vietnamese} */ vi(LanguageCode.vi, null), /** * {@link LanguageCode#vi Vietnamese}, {@link CountryCode#VN Viet Nam} */ vi_VN(LanguageCode.vi, CountryCode.VN), /** * {@link LanguageCode#zh Chinese} */ zh(LanguageCode.zh, null) { @Override public Locale toLocale() { return Locale.CHINESE; } }, /** * {@link LanguageCode#zh Chinese}, {@link CountryCode#CN China} */ zh_CN(LanguageCode.zh, CountryCode.CN) { @Override public Locale toLocale() { return Locale.SIMPLIFIED_CHINESE; } }, /** * {@link LanguageCode#zh Chinese}, {@link CountryCode#HK Hong Kong} */ zh_HK(LanguageCode.zh, CountryCode.HK), /** * {@link LanguageCode#zh Chinese}, {@link CountryCode#SG Singapore} */ zh_SG(LanguageCode.zh, CountryCode.SG), /** * {@link LanguageCode#zh Chinese}, {@link CountryCode#TW Taiwan, Province of China} */ zh_TW(LanguageCode.zh, CountryCode.TW) { @Override public Locale toLocale() { return Locale.TRADITIONAL_CHINESE; } } ; private static final Locale undefinedLocale = getUndefinedLocale(); private final LanguageCode language; private final CountryCode country; private final String string; private LocaleCode(LanguageCode language, CountryCode country) { this.language = language; this.country = country; if (country == null) { string = language.name(); } else { string = language.name() + "-" + country.name(); } } /** * Get the language code. * * @return * The language code. This method always returns a non-null value. */ public LanguageCode getLanguage() { return language; } /** * Get the country code. * * @return * The country code. This method may return null. * For example, {@link #en LocaleCode.en}.getCountry() returns null. */ public CountryCode getCountry() { return country; } /** * Get the string representation of this locale code. Its format is * either of the following: * *
    *
  • language
  • *
  • language-country *
* *

* where language is an ISO 639-1 code * and country is an ISO 3166-1 * alpha-2 code. *

* * @return * The string representation of this locale code. */ @Override public String toString() { return string; } /** * Convert this {@code LocaleCode} instance to a {@link Locale} instance. * *

* In most cases, this method creates a new {@code Locale} instance * every time it is called, but some {@code LocaleCode} instances * return their corresponding entries in {@code Locale} class. * For example, {@link #it LocaleCode.it} always returns * {@link Locale#ITALIAN}. *

* *

* The table below lists {@code LocaleCode} entries whose {@code toLocale()} * does not create a new {@code Locale} instance but returns an entry in * {@code Locale} class. *

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
LocaleCodeLocale
{@link LocaleCode#de LocaleCode.de}{@link Locale#GERMAN}
{@link LocaleCode#en LocaleCode.en}{@link Locale#ENGLISH}
{@link LocaleCode#fr LocaleCode.fr}{@link Locale#FRENCH}
{@link LocaleCode#fr_CA LocaleCode.fr_CA}{@link Locale#CANADA_FRENCH}
{@link LocaleCode#it LocaleCode.it}{@link Locale#ITALIAN}
{@link LocaleCode#ja LocaleCode.ja}{@link Locale#JAPANESE}
{@link LocaleCode#ko LocaleCode.ko}{@link Locale#KOREAN}
{@link LocaleCode#zh LocaleCode.zh}{@link Locale#CHINESE}
{@link LocaleCode#zh_CN LocaleCode.zh_CN}{@link Locale#SIMPLIFIED_CHINESE}
{@link LocaleCode#zh_TW LocaleCode.zh_TW}{@link Locale#TRADITIONAL_CHINESE}
* *

* In addition, {@code toLocale()} of {@link LocaleCode#undefined * LocaleCode.undefined} behaves a bit differently. It returns * {@link Locale#ROOT Locale.ROOT} when it is available (i.e. when * the version of Java SE is 1.6 or higher). Otherwise, it returns * a {@code Locale} instance whose language and country are empty * strings. Even in the latter case, the same instance is returned * on every call. *

* * @return * A {@code Locale} instance that matches this {@code LocaleCode}. */ public Locale toLocale() { if (country != null) { return new Locale(language.name(), country.name()); } else { return new Locale(language.name()); } } /** * Get a {@code LocaleCode} instance that corresponds to the given code. * *

* This method just calls {@link #getByCode(String, boolean) getByCode}{@code (code, true)}. * Note that the behavior has changed since the version 1.13. In the older versions, * this method was an alias of {@code getByCode(code, false)}. *

* * @param code * A locale code. * * @return * A {@code LocaleCode} instance, or {@code null} if not found. * * @see #getByCode(String, boolean) */ public static LocaleCode getByCode(String code) { return getByCode(code, true); } /** * Get a {@code LocaleCode} instance that corresponds to the given code. * *

* This method just calls {@link #getByCode(String, boolean) getByCode}{@code (code, false)}. *

* * @param code * A locale code. * * @return * A {@code LocaleCode} instance, or {@code null} if not found. * * @since 1.13 * * @see #getByCode(String, boolean) */ public static LocaleCode getByCodeIgnoreCase(String code) { return getByCode(code, false); } /** * Get a {@code LocaleCode} instance that corresponds to the given code. * *

* The format of the code should be either of the following: *

* *
    *
  • language
  • *
  • language-country *
* *

* where language is an ISO 639-1 code * and country is an ISO 3166-1 * alpha-2 code. The separator between language and * country should be a hyphen (-) or an underscore * (_). *

* *

* Note that if the language part of the given code is one of legacy * ones { "iw", "ji" and "in" }, it is regarded as its newer official * counterpart { "he", "yi" and "id" }, respectively. *

* * @param code * A locale code. * * @param caseSensitive * If {@code true}, the language part of the given code must be * lower-case and the country part, if not {@code null}, must be * upper-case. If false, this method internally canonicalizes * the given code and then performs search. * * @return * A {@code LocaleCode} instance, or {@code null} if not found. */ public static LocaleCode getByCode(String code, boolean caseSensitive) { if (code == null) { return null; } switch (code.length()) { case 2: case 9: // The given code is regarded as a language code. return getByCode(code, null, caseSensitive); case 5: return getByCombinedCode(code, caseSensitive, 2); case 19: return getByCombinedCode(code, caseSensitive, 9); default: return null; } } /** * Get a {@code LocaleCode} instance that corresponds to the given pair of * language code and country code. * *

* This method just calls {@link #getByCode(String, String, boolean) * getByCode}{@code (language, country, true)}. * Note that the behavior has changed since the version 1.13. * In the older versions, this method was an alias of {@code * getByCode(language, country, false)}. *

* * @param language * ISO 639-1 language code. Or "undefined" (case * sensitive). If the given language code is one of legacy * ones { "iw", "ji" and "in" }, it is regarded as its newer * official counterpart { "he", "yi" and "id" }, respectively. * * @param country * ISO 3166-1 alpha-2 country code. Or "UNDEFINED" * (case sensitive). * * @return * A {@code LocaleCode}, or {@code null} if not found. * * @see #getByCode(String, String, boolean) */ public static LocaleCode getByCode(String language, String country) { return getByCode(language, country, true); } /** * Get a {@code LocaleCode} instance that corresponds to the given pair of * language code and country code. * *

* This method just calls {@link #getByCode(String, String, boolean) * getByCode}{@code (language, country, false)}. *

* * @param language * ISO 639-1 language code. Or "undefined" (case * insensitive). If the given language code is one of legacy * ones { "iw", "ji" and "in" }, it is regarded as its newer * official counterpart { "he", "yi" and "id" }, respectively. * * @param country * ISO 3166-1 alpha-2 country code. Or "UNDEFINED" * (case insensitive). * * @return * A {@code LocaleCode}, or {@code null} if not found. * * @since 1.13 * * @see #getByCode(String, String, boolean) */ public static LocaleCode getByCodeIgnoreCase(String language, String country) { return getByCode(language, country, false); } /** * Get a {@code LocaleCode} instance that corresponds to the given pair of * language code and country code. * *

* If {@code language} is "undefined" and if {@code country} is {@code null} * or "UNDEFINED", {@link #undefined LocaleCode.undefined} is returned. *

* * @param language * ISO 639-1 language code. Or "undefined". * If the given language code is one of legacy ones { "iw", * "ji" and "in" }, it is regarded as its newer official * counterpart { "he", "yi" and "id" }, respectively. * * @param country * ISO 3166-1 alpha-2 country code. Or "UNDEFINED". * * @param caseSensitive * If {@code true}, the given language code must be lower-case and * the given country code, if not {@code null}, must be upper-case. * If {@code false}, this method internally canonicalizes the given * codes and then performs search. * * @return * A {@code LocaleCode}, or {@code null} if not found. */ public static LocaleCode getByCode(String language, String country, boolean caseSensitive) { // Canonicalize the given language code. language = LanguageCode.canonicalize(language, caseSensitive); if (language == null) { // There is no LocaleCode whose language is not given. return null; } // Canonicalize the given country code. country = CountryCode.canonicalize(country, caseSensitive); if (language.equals("undefined") && (country == null || country.equals("UNDEFINED"))) { return LocaleCode.undefined; } if (country == null) { return getByEnumName(language); } else { return getByEnumName(language + "_" + country); } } /** * Get a {@code LocaleCode} instance that corresponds to the given * {@link Locale} instance. * * @param locale * A {@code Locale} instance. * * @return * A {@code LocaleCode} instance, or {@code null} if not found. * When the value returned by {@link Locale#getLanguage() getLanguage()} * method of the given instance is {@code null} or an empty string and * the value returned by {@link Locale#getCountry() getCountry()} method * of the given instance is {@code null} or an empty string, * {@link #undefined LocaleCode.undefined} is returned. */ public static LocaleCode getByLocale(Locale locale) { if (locale == null) { return null; } // Locale.getLanguage() returns either an empty string or // a lower-case ISO 639 code. String language = locale.getLanguage(); // Locale.getCountry() returns either an empty string or // a upper-case ISO 3166-1 alphe-2 code. String country = locale.getCountry(); if ((language == null || language.length() == 0) && (country == null || country.length() == 0)) { return LocaleCode.undefined; } // 'language' and 'country' are already lower-case and upper-case, // so true can be given as the third argument. return getByCode(language, country, true); } private static LocaleCode getByCombinedCode(String code, boolean caseSensitive, int splitPosition) { // Get the character that separates the language code from the country code. char separator = code.charAt(splitPosition); if (separator == '_') { if (caseSensitive && splitPosition == 2) { // The given code can be handled as enum name. return getByEnumName(code); } } else if (separator != '-') { // Bad format. return null; } // Extract the language part and the country part from the given code. String language = code.substring(0, splitPosition); String country = code.substring(splitPosition + 1); return getByCode(language, country, caseSensitive); } private static LocaleCode getByEnumName(String name) { try { return Enum.valueOf(LocaleCode.class, name); } catch (IllegalArgumentException e) { return null; } } /** * Get a list of {@code LocaleCode} instances whose language matches the given one. * *

* This method is an alias of {@link #getByLanguage(String, boolean) * getByLanguage}{@code (language, true)}. * Note that the behavior has changed since the version 1.13. In the older versions, * this method was an alias of {@code getByLanguage(language, false)}. *

* * @param language * Language code. ISO 639 alpha-2 or alpha-3. * * @return * List of {@code LocaleCode} instances. If there is no {@code LocaleCode} * instance whose language matches the given one, the size of the returned * list is zero. * * @since 1.3 */ public static List getByLanguage(String language) { return getByLanguage(language, true); } /** * Get a list of {@code LocaleCode} instances whose language matches the given one. * *

* This method is an alias of {@link #getByLanguage(String, boolean) * getByLanguage}{@code (language, false)}. *

* * @param language * Language code. ISO 639 alpha-2 or alpha-3. * * @return * List of {@code LocaleCode} instances. If there is no {@code LocaleCode} * instance whose language matches the given one, the size of the returned * list is zero. * * @since 1.13 */ public static List getByLanguageIgnoreCase(String language) { return getByLanguage(language, false); } /** * Get a list of {@code LocaleCode} instances whose language matches the given one. * *

* This method is an alias of {@link #getByLanguage(LanguageCode) * getByLanguage}{@code (}{@link LanguageCode}{@code .}{@link * LanguageCode#getByCode(String, boolean) getByCode}{@code (language, caseSensitive))}. *

* * @param language * Language code. ISO 639 alpha-2 or alpha-3. * * @param caseSensitive * If {@code true}, the given code should consist of lowercase letters only. * If {@code false}, case is ignored. * * @return * List of {@code LocaleCode} instances. If there is no {@code LocaleCode} * instance whose language matches the given one, the size of the returned * list is zero. * * @since 1.3 */ public static List getByLanguage(String language, boolean caseSensitive) { return getByLanguage(LanguageCode.getByCode(language, caseSensitive)); } /** * Get a list of {@code LocaleCode} instances whose language matches the given one. * * @param language * {@code LanguageCode} instance that represents a language. * * @return * List of {@code LocaleCode} instances. If there is no {@code LocaleCode} * instance whose language matches the given one, the size of the returned * list is zero. * * @since 1.3 */ public static List getByLanguage(LanguageCode language) { List list = new ArrayList(); if (language == null) { return list; } for (LocaleCode code : values()) { if (code.getLanguage() == language) { list.add(code); } } return list; } /** * Get a list of {@code LocaleCode} instances whose country matches the given one. * *

* This method is an alias of {@link #getByCountry(String, boolean) * getByCountry}{@code (country, true)}. * Note that the behavior has changed since the version 1.13. In the older versions, * this method was an alias of {@code getByCountry(country, false)}. *

* * @param country * Country code. ISO 3166-1 alpha-2 or alpha-3. * * @return * List of {@code LocaleCode} instances. If there is no {@code LocaleCode} * instance whose country matches the given one, the size of the returned * list is zero. * * @since 1.3 */ public static List getByCountry(String country) { return getByCountry(country, true); } /** * Get a list of {@code LocaleCode} instances whose country matches the given one. * *

* This method is an alias of {@link #getByCountry(String, boolean) * getByCountry}{@code (country, false)}. *

* * @param country * Country code. ISO 3166-1 alpha-2 or alpha-3. * * @return * List of {@code LocaleCode} instances. If there is no {@code LocaleCode} * instance whose country matches the given one, the size of the returned * list is zero. * * @since 1.13 */ public static List getByCountryIgnoreCase(String country) { return getByCountry(country, false); } /** * Get a list of {@code LocaleCode} instances whose country matches the given one. * *

* This method is an alias of {@link #getByCountry(CountryCode) * getByCountry}{@code (}{@link CountryCode}{@code .}{@link * CountryCode#getByCode(String, boolean) getByCode}{@code * (country, caseSensitive))}. *

* * @param country * Country code. ISO 3166-1 alpha-2 or alpha-3. * * @param caseSensitive * If {@code true}, the given code should consist of uppercase letters only. * If {@code false}, case is ignored. * * @return * List of {@code LocaleCode} instances. If there is no {@code LocaleCode} * instance whose country matches the given one, the size of the returned * list is zero. * * @since 1.3 */ public static List getByCountry(String country, boolean caseSensitive) { return getByCountry(CountryCode.getByCode(country, caseSensitive)); } /** * Get a list of {@code LocaleCode} instances whose country matches the given one. * * @param country * {@code CountryCode} instance that represents a country. * * @return * List of {@code LocaleCode} instances. If there is no {@code LocaleCode} * instance whose country matches the given one, the size of the returned * list is zero. * * @since 1.3 */ public static List getByCountry(CountryCode country) { List list = new ArrayList(); if (country == null) { return list; } for (LocaleCode code : values()) { if (code.getCountry() == country) { list.add(code); } } return list; } private static Locale getUndefinedLocale() { try { // Try to get Locale.ROOT which is available since Java SE 1.6. Field root = Locale.class.getDeclaredField("ROOT"); // Return Locale.ROOT. return (Locale)root.get(null); } catch (Exception e) { // Simulate Locale.ROOT. return new Locale("", ""); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy