8185841: Values from getFirstDayOfWeek() are inconsistent with CLDR
Reviewed-by: naoto
This commit is contained in:
parent
9768149887
commit
3ae10b235d
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2012, 2017, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
@ -36,6 +36,7 @@ import java.util.*;
|
||||
import java.util.ResourceBundle.Control;
|
||||
import java.util.logging.Level;
|
||||
import java.util.logging.Logger;
|
||||
import java.util.stream.Collectors;
|
||||
import javax.xml.parsers.SAXParser;
|
||||
import javax.xml.parsers.SAXParserFactory;
|
||||
import org.xml.sax.SAXNotRecognizedException;
|
||||
@ -217,6 +218,7 @@ public class CLDRConverter {
|
||||
|
||||
List<Bundle> bundles = readBundleList();
|
||||
convertBundles(bundles);
|
||||
convertBundles(addedBundles);
|
||||
}
|
||||
|
||||
private static void usage() {
|
||||
@ -293,14 +295,7 @@ public class CLDRConverter {
|
||||
if (fileName.endsWith(".xml")) {
|
||||
String id = fileName.substring(0, fileName.indexOf('.'));
|
||||
Locale cldrLoc = Locale.forLanguageTag(toLanguageTag(id));
|
||||
List<Locale> candList = applyParentLocales("", defCon.getCandidateLocales("", cldrLoc));
|
||||
StringBuilder sb = new StringBuilder();
|
||||
for (Locale loc : candList) {
|
||||
if (!loc.equals(Locale.ROOT)) {
|
||||
sb.append(toLocaleName(loc.toLanguageTag()));
|
||||
sb.append(",");
|
||||
}
|
||||
}
|
||||
StringBuilder sb = getCandLocales(cldrLoc);
|
||||
if (sb.indexOf("root") == -1) {
|
||||
sb.append("root");
|
||||
}
|
||||
@ -319,6 +314,23 @@ public class CLDRConverter {
|
||||
}
|
||||
|
||||
private static final Map<String, Map<String, Object>> cldrBundles = new HashMap<>();
|
||||
// this list will contain additional bundles to be generated for Region dependent Data.
|
||||
private static List<Bundle> addedBundles = new ArrayList<>();
|
||||
|
||||
private static Map<String, SortedSet<String>> metaInfo = new HashMap<>();
|
||||
|
||||
static {
|
||||
// For generating information on supported locales.
|
||||
metaInfo.put("LocaleNames", new TreeSet<>());
|
||||
metaInfo.put("CurrencyNames", new TreeSet<>());
|
||||
metaInfo.put("TimeZoneNames", new TreeSet<>());
|
||||
metaInfo.put("CalendarData", new TreeSet<>());
|
||||
metaInfo.put("FormatData", new TreeSet<>());
|
||||
metaInfo.put("AvailableLocales", new TreeSet<>());
|
||||
}
|
||||
|
||||
|
||||
private static Set<String> calendarDataFields = Set.of("firstDayOfWeek", "minimalDaysInFirstWeek");
|
||||
|
||||
static Map<String, Object> getCLDRBundle(String id) throws Exception {
|
||||
Map<String, Object> bundle = cldrBundles.get(id);
|
||||
@ -411,16 +423,85 @@ public class CLDRConverter {
|
||||
parserLikelySubtags.parse(fileLikelySubtags, handlerLikelySubtags);
|
||||
}
|
||||
|
||||
private static void convertBundles(List<Bundle> bundles) throws Exception {
|
||||
// For generating information on supported locales.
|
||||
Map<String, SortedSet<String>> metaInfo = new HashMap<>();
|
||||
metaInfo.put("LocaleNames", new TreeSet<>());
|
||||
metaInfo.put("CurrencyNames", new TreeSet<>());
|
||||
metaInfo.put("TimeZoneNames", new TreeSet<>());
|
||||
metaInfo.put("CalendarData", new TreeSet<>());
|
||||
metaInfo.put("FormatData", new TreeSet<>());
|
||||
metaInfo.put("AvailableLocales", new TreeSet<>());
|
||||
/**
|
||||
* This method will check if a new region dependent Bundle needs to be
|
||||
* generated for this Locale id and targetMap. New Bundle will be generated
|
||||
* when Locale id has non empty script and country code and targetMap
|
||||
* contains region dependent data. This method will also remove region
|
||||
* dependent data from this targetMap after candidate locales check. E.g. It
|
||||
* will call genRegionDependentBundle() in case of az_Latn_AZ locale and
|
||||
* remove region dependent data from this targetMap so that az_Latn_AZ
|
||||
* bundle will not be created. For az_Cyrl_AZ, new Bundle will be generated
|
||||
* but region dependent data will not be removed from targetMap as its candidate
|
||||
* locales are [az_Cyrl_AZ, az_Cyrl, root], which does not include az_AZ for
|
||||
* fallback.
|
||||
*
|
||||
*/
|
||||
|
||||
private static void checkRegionDependentBundle(Map<String, Object> targetMap, String id) {
|
||||
if ((CLDRConverter.getScript(id) != "")
|
||||
&& (CLDRConverter.getCountryCode(id) != "")) {
|
||||
Map<String, Object> regionDepDataMap = targetMap
|
||||
.keySet()
|
||||
.stream()
|
||||
.filter(calendarDataFields::contains)
|
||||
.collect(Collectors.toMap(k -> k, targetMap::get));
|
||||
if (!regionDepDataMap.isEmpty()) {
|
||||
Locale cldrLoc = new Locale(CLDRConverter.getLanguageCode(id),
|
||||
CLDRConverter.getCountryCode(id));
|
||||
genRegionDependentBundle(regionDepDataMap, cldrLoc);
|
||||
if (checkCandidateLocales(id, cldrLoc)) {
|
||||
// Remove matchedKeys from this targetMap only if checkCandidateLocales() returns true.
|
||||
regionDepDataMap.keySet().forEach(targetMap::remove);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
/**
|
||||
* This method will generate a new Bundle for region dependent data,
|
||||
* minimalDaysInFirstWeek and firstDayOfWeek. Newly generated Bundle will be added
|
||||
* to addedBundles list.
|
||||
*/
|
||||
private static void genRegionDependentBundle(Map<String, Object> targetMap, Locale cldrLoc) {
|
||||
String localeId = cldrLoc.toString();
|
||||
StringBuilder sb = getCandLocales(cldrLoc);
|
||||
if (sb.indexOf(localeId) == -1) {
|
||||
sb.append(localeId);
|
||||
}
|
||||
Bundle bundle = new Bundle(localeId, sb.toString(), null, null);
|
||||
cldrBundles.put(localeId, targetMap);
|
||||
addedBundles.add(bundle);
|
||||
}
|
||||
|
||||
private static StringBuilder getCandLocales(Locale cldrLoc) {
|
||||
List<Locale> candList = getCandidateLocales(cldrLoc);
|
||||
StringBuilder sb = new StringBuilder();
|
||||
for (Locale loc : candList) {
|
||||
if (!loc.equals(Locale.ROOT)) {
|
||||
sb.append(toLocaleName(loc.toLanguageTag()));
|
||||
sb.append(",");
|
||||
}
|
||||
}
|
||||
return sb;
|
||||
}
|
||||
|
||||
private static List<Locale> getCandidateLocales(Locale cldrLoc) {
|
||||
List<Locale> candList = new ArrayList<>();
|
||||
candList = applyParentLocales("", defCon.getCandidateLocales("", cldrLoc));
|
||||
return candList;
|
||||
}
|
||||
|
||||
/**
|
||||
* This method will return true, if for a given locale, its language and
|
||||
* country specific locale will exist in runtime lookup path. E.g. it will
|
||||
* return true for bs_Latn_BA.
|
||||
*/
|
||||
private static boolean checkCandidateLocales(String id, Locale cldrLoc) {
|
||||
return(getCandidateLocales(Locale.forLanguageTag(id.replaceAll("_", "-")))
|
||||
.contains(cldrLoc));
|
||||
}
|
||||
|
||||
private static void convertBundles(List<Bundle> bundles) throws Exception {
|
||||
// parent locales map. The mappings are put in base metaInfo file
|
||||
// for now.
|
||||
if (isBaseModule) {
|
||||
@ -433,6 +514,8 @@ public class CLDRConverter {
|
||||
|
||||
Map<String, Object> targetMap = bundle.getTargetMap();
|
||||
|
||||
// check if new region DependentBundle needs to be generated for this Locale.
|
||||
checkRegionDependentBundle(targetMap, bundle.getID());
|
||||
EnumSet<Bundle.Type> bundleTypes = bundle.getBundleTypes();
|
||||
|
||||
if (bundle.isRoot()) {
|
||||
@ -573,6 +656,14 @@ public class CLDRConverter {
|
||||
return Locale.forLanguageTag(id.replaceAll("_", "-")).getCountry();
|
||||
}
|
||||
|
||||
/*
|
||||
* Returns the script portion of the given id.
|
||||
* If id is "root", "" is returned.
|
||||
*/
|
||||
static String getScript(String id) {
|
||||
return "root".equals(id) ? "" : Locale.forLanguageTag(id.replaceAll("_", "-")).getScript();
|
||||
}
|
||||
|
||||
private static class KeyComparator implements Comparator<String> {
|
||||
static KeyComparator INSTANCE = new KeyComparator();
|
||||
|
||||
|
278
test/java/util/Calendar/Bug8185841.java
Normal file
278
test/java/util/Calendar/Bug8185841.java
Normal file
@ -0,0 +1,278 @@
|
||||
/*
|
||||
* Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
/*
|
||||
* @test
|
||||
* @bug 8185841
|
||||
* @summary Test that Region dependent Bundles are added/removed correctly.
|
||||
* @modules jdk.localedata
|
||||
*/
|
||||
|
||||
/*
|
||||
This test is dependent on a particular version of CLDR.
|
||||
*/
|
||||
import java.net.URI;
|
||||
import java.nio.file.FileSystem;
|
||||
import java.nio.file.FileSystems;
|
||||
import java.nio.file.Files;
|
||||
import java.nio.file.Path;
|
||||
import java.util.Collections;
|
||||
import java.util.HashSet;
|
||||
import java.util.Set;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
public class Bug8185841 {
|
||||
// Golden data for Region dependent Bundles in CLDR29.
|
||||
|
||||
private static final Set<String> expectedBundles
|
||||
= Set.of("CalendarData_af_NA.class", "CalendarData_af_ZA.class", "CalendarData_agq_CM.class",
|
||||
"CalendarData_ak_GH.class", "CalendarData_am_ET.class", "CalendarData_ar_AE.class",
|
||||
"CalendarData_ar_BH.class", "CalendarData_ar_DJ.class", "CalendarData_ar_DZ.class",
|
||||
"CalendarData_ar_EG.class", "CalendarData_ar_EH.class", "CalendarData_ar_ER.class",
|
||||
"CalendarData_ar_IL.class", "CalendarData_ar_IQ.class", "CalendarData_ar_JO.class",
|
||||
"CalendarData_ar_KM.class", "CalendarData_ar_KW.class", "CalendarData_ar_LB.class",
|
||||
"CalendarData_ar_LY.class", "CalendarData_ar_MA.class", "CalendarData_ar_MR.class",
|
||||
"CalendarData_ar_OM.class", "CalendarData_ar_PS.class", "CalendarData_ar_QA.class",
|
||||
"CalendarData_ar_SA.class", "CalendarData_ar_SD.class", "CalendarData_ar_SO.class",
|
||||
"CalendarData_ar_SS.class", "CalendarData_ar_SY.class", "CalendarData_ar_TD.class",
|
||||
"CalendarData_ar_TN.class", "CalendarData_ar_YE.class", "CalendarData_as_IN.class",
|
||||
"CalendarData_asa_TZ.class", "CalendarData_ast_ES.class", "CalendarData_az_AZ.class",
|
||||
"CalendarData_az_Cyrl_AZ.class", "CalendarData_bas_CM.class", "CalendarData_be_BY.class",
|
||||
"CalendarData_bem_ZM.class", "CalendarData_bez_TZ.class", "CalendarData_bg_BG.class",
|
||||
"CalendarData_bm_ML.class", "CalendarData_bn_BD.class", "CalendarData_bn_IN.class",
|
||||
"CalendarData_bo_CN.class", "CalendarData_bo_IN.class", "CalendarData_br_FR.class",
|
||||
"CalendarData_brx_IN.class", "CalendarData_bs_BA.class", "CalendarData_bs_Cyrl_BA.class",
|
||||
"CalendarData_ca_AD.class", "CalendarData_ca_ES.class", "CalendarData_ca_FR.class",
|
||||
"CalendarData_ca_IT.class", "CalendarData_ce_RU.class", "CalendarData_cgg_UG.class",
|
||||
"CalendarData_chr_US.class", "CalendarData_ckb_IQ.class", "CalendarData_ckb_IR.class",
|
||||
"CalendarData_cs_CZ.class", "CalendarData_cu_RU.class", "CalendarData_cy_GB.class",
|
||||
"CalendarData_da_DK.class", "CalendarData_da_GL.class", "CalendarData_dav_KE.class",
|
||||
"CalendarData_de_AT.class", "CalendarData_de_BE.class", "CalendarData_de_CH.class",
|
||||
"CalendarData_de_DE.class", "CalendarData_de_LI.class", "CalendarData_de_LU.class",
|
||||
"CalendarData_dje_NE.class", "CalendarData_dsb_DE.class", "CalendarData_dua_CM.class",
|
||||
"CalendarData_dyo_SN.class", "CalendarData_dz_BT.class", "CalendarData_ebu_KE.class",
|
||||
"CalendarData_ee_GH.class", "CalendarData_ee_TG.class", "CalendarData_el_CY.class",
|
||||
"CalendarData_el_GR.class", "CalendarData_en_AG.class", "CalendarData_en_AI.class",
|
||||
"CalendarData_en_AS.class", "CalendarData_en_AT.class", "CalendarData_en_AU.class",
|
||||
"CalendarData_en_BB.class", "CalendarData_en_BE.class", "CalendarData_en_BI.class",
|
||||
"CalendarData_en_BM.class", "CalendarData_en_BS.class", "CalendarData_en_BW.class",
|
||||
"CalendarData_en_BZ.class", "CalendarData_en_CA.class", "CalendarData_en_CC.class",
|
||||
"CalendarData_en_CH.class", "CalendarData_en_CK.class", "CalendarData_en_CM.class",
|
||||
"CalendarData_en_CX.class", "CalendarData_en_CY.class", "CalendarData_en_DE.class",
|
||||
"CalendarData_en_DG.class", "CalendarData_en_DK.class", "CalendarData_en_DM.class",
|
||||
"CalendarData_en_ER.class", "CalendarData_en_FI.class", "CalendarData_en_FJ.class",
|
||||
"CalendarData_en_FK.class", "CalendarData_en_FM.class", "CalendarData_en_GB.class",
|
||||
"CalendarData_en_GD.class", "CalendarData_en_GG.class", "CalendarData_en_GH.class",
|
||||
"CalendarData_en_GI.class", "CalendarData_en_GM.class", "CalendarData_en_GU.class",
|
||||
"CalendarData_en_GY.class", "CalendarData_en_HK.class", "CalendarData_en_IE.class",
|
||||
"CalendarData_en_IL.class", "CalendarData_en_IM.class", "CalendarData_en_IN.class",
|
||||
"CalendarData_en_IO.class", "CalendarData_en_JE.class", "CalendarData_en_JM.class",
|
||||
"CalendarData_en_KE.class", "CalendarData_en_KI.class", "CalendarData_en_KN.class",
|
||||
"CalendarData_en_KY.class", "CalendarData_en_LC.class", "CalendarData_en_LR.class",
|
||||
"CalendarData_en_LS.class", "CalendarData_en_MG.class", "CalendarData_en_MH.class",
|
||||
"CalendarData_en_MO.class", "CalendarData_en_MP.class", "CalendarData_en_MS.class",
|
||||
"CalendarData_en_MT.class", "CalendarData_en_MU.class", "CalendarData_en_MW.class",
|
||||
"CalendarData_en_MY.class", "CalendarData_en_NA.class", "CalendarData_en_NF.class",
|
||||
"CalendarData_en_NG.class", "CalendarData_en_NL.class", "CalendarData_en_NR.class",
|
||||
"CalendarData_en_NU.class", "CalendarData_en_NZ.class", "CalendarData_en_PG.class",
|
||||
"CalendarData_en_PH.class", "CalendarData_en_PK.class", "CalendarData_en_PN.class",
|
||||
"CalendarData_en_PR.class", "CalendarData_en_PW.class", "CalendarData_en_RW.class",
|
||||
"CalendarData_en_SB.class", "CalendarData_en_SC.class", "CalendarData_en_SD.class",
|
||||
"CalendarData_en_SE.class", "CalendarData_en_SG.class", "CalendarData_en_SH.class",
|
||||
"CalendarData_en_SI.class", "CalendarData_en_SL.class", "CalendarData_en_SS.class",
|
||||
"CalendarData_en_SX.class", "CalendarData_en_SZ.class", "CalendarData_en_TC.class",
|
||||
"CalendarData_en_TK.class", "CalendarData_en_TO.class", "CalendarData_en_TT.class",
|
||||
"CalendarData_en_TV.class", "CalendarData_en_TZ.class", "CalendarData_en_UG.class",
|
||||
"CalendarData_en_UM.class", "CalendarData_en_VC.class", "CalendarData_en_VG.class",
|
||||
"CalendarData_en_VI.class", "CalendarData_en_VU.class", "CalendarData_en_WS.class",
|
||||
"CalendarData_en_ZA.class", "CalendarData_en_ZM.class", "CalendarData_en_ZW.class",
|
||||
"CalendarData_es_AR.class", "CalendarData_es_BO.class", "CalendarData_es_BR.class",
|
||||
"CalendarData_es_CL.class", "CalendarData_es_CO.class", "CalendarData_es_CR.class",
|
||||
"CalendarData_es_CU.class", "CalendarData_es_DO.class", "CalendarData_es_EA.class",
|
||||
"CalendarData_es_EC.class", "CalendarData_es_ES.class", "CalendarData_es_GQ.class",
|
||||
"CalendarData_es_GT.class", "CalendarData_es_HN.class", "CalendarData_es_IC.class",
|
||||
"CalendarData_es_MX.class", "CalendarData_es_NI.class", "CalendarData_es_PA.class",
|
||||
"CalendarData_es_PE.class", "CalendarData_es_PH.class", "CalendarData_es_PR.class",
|
||||
"CalendarData_es_PY.class", "CalendarData_es_SV.class", "CalendarData_es_US.class",
|
||||
"CalendarData_es_UY.class", "CalendarData_es_VE.class", "CalendarData_et_EE.class",
|
||||
"CalendarData_eu_ES.class", "CalendarData_ewo_CM.class", "CalendarData_fa_AF.class",
|
||||
"CalendarData_fa_IR.class", "CalendarData_ff_CM.class", "CalendarData_ff_GN.class",
|
||||
"CalendarData_ff_MR.class", "CalendarData_ff_SN.class", "CalendarData_fi_FI.class",
|
||||
"CalendarData_fil_PH.class", "CalendarData_fo_DK.class", "CalendarData_fo_FO.class",
|
||||
"CalendarData_fr_BE.class", "CalendarData_fr_BF.class", "CalendarData_fr_BI.class",
|
||||
"CalendarData_fr_BJ.class", "CalendarData_fr_BL.class", "CalendarData_fr_CA.class",
|
||||
"CalendarData_fr_CD.class", "CalendarData_fr_CF.class", "CalendarData_fr_CG.class",
|
||||
"CalendarData_fr_CH.class", "CalendarData_fr_CI.class", "CalendarData_fr_CM.class",
|
||||
"CalendarData_fr_DJ.class", "CalendarData_fr_DZ.class", "CalendarData_fr_FR.class",
|
||||
"CalendarData_fr_GA.class", "CalendarData_fr_GF.class", "CalendarData_fr_GN.class",
|
||||
"CalendarData_fr_GP.class", "CalendarData_fr_GQ.class", "CalendarData_fr_HT.class",
|
||||
"CalendarData_fr_KM.class", "CalendarData_fr_LU.class", "CalendarData_fr_MA.class",
|
||||
"CalendarData_fr_MC.class", "CalendarData_fr_MF.class", "CalendarData_fr_MG.class",
|
||||
"CalendarData_fr_ML.class", "CalendarData_fr_MQ.class", "CalendarData_fr_MR.class",
|
||||
"CalendarData_fr_MU.class", "CalendarData_fr_NC.class", "CalendarData_fr_NE.class",
|
||||
"CalendarData_fr_PF.class", "CalendarData_fr_PM.class", "CalendarData_fr_RE.class",
|
||||
"CalendarData_fr_RW.class", "CalendarData_fr_SC.class", "CalendarData_fr_SN.class",
|
||||
"CalendarData_fr_SY.class", "CalendarData_fr_TD.class", "CalendarData_fr_TG.class",
|
||||
"CalendarData_fr_TN.class", "CalendarData_fr_VU.class", "CalendarData_fr_WF.class",
|
||||
"CalendarData_fr_YT.class", "CalendarData_fur_IT.class", "CalendarData_fy_NL.class",
|
||||
"CalendarData_ga_IE.class", "CalendarData_gd_GB.class", "CalendarData_gl_ES.class",
|
||||
"CalendarData_gsw_CH.class", "CalendarData_gsw_FR.class", "CalendarData_gsw_LI.class",
|
||||
"CalendarData_gu_IN.class", "CalendarData_guz_KE.class", "CalendarData_gv_IM.class",
|
||||
"CalendarData_ha_GH.class", "CalendarData_ha_NE.class", "CalendarData_ha_NG.class",
|
||||
"CalendarData_haw_US.class", "CalendarData_hi_IN.class", "CalendarData_hr_BA.class",
|
||||
"CalendarData_hr_HR.class", "CalendarData_hsb_DE.class", "CalendarData_hu_HU.class",
|
||||
"CalendarData_hy_AM.class", "CalendarData_ig_NG.class", "CalendarData_ii_CN.class",
|
||||
"CalendarData_in_ID.class", "CalendarData_is_IS.class", "CalendarData_it_CH.class",
|
||||
"CalendarData_it_IT.class", "CalendarData_it_SM.class", "CalendarData_iw_IL.class",
|
||||
"CalendarData_ja_JP.class", "CalendarData_jgo_CM.class", "CalendarData_jmc_TZ.class",
|
||||
"CalendarData_ka_GE.class", "CalendarData_kab_DZ.class", "CalendarData_kam_KE.class",
|
||||
"CalendarData_kde_TZ.class", "CalendarData_kea_CV.class", "CalendarData_khq_ML.class",
|
||||
"CalendarData_ki_KE.class", "CalendarData_kk_KZ.class", "CalendarData_kkj_CM.class",
|
||||
"CalendarData_kl_GL.class", "CalendarData_kln_KE.class", "CalendarData_km_KH.class",
|
||||
"CalendarData_kn_IN.class", "CalendarData_ko_KP.class", "CalendarData_ko_KR.class",
|
||||
"CalendarData_kok_IN.class", "CalendarData_ks_IN.class", "CalendarData_ksb_TZ.class",
|
||||
"CalendarData_ksf_CM.class", "CalendarData_ksh_DE.class", "CalendarData_kw_GB.class",
|
||||
"CalendarData_ky_KG.class", "CalendarData_lag_TZ.class", "CalendarData_lb_LU.class",
|
||||
"CalendarData_lg_UG.class", "CalendarData_lkt_US.class", "CalendarData_ln_AO.class",
|
||||
"CalendarData_ln_CD.class", "CalendarData_ln_CF.class", "CalendarData_ln_CG.class",
|
||||
"CalendarData_lo_LA.class", "CalendarData_lrc_IQ.class", "CalendarData_lrc_IR.class",
|
||||
"CalendarData_lt_LT.class", "CalendarData_lu_CD.class", "CalendarData_luo_KE.class",
|
||||
"CalendarData_luy_KE.class", "CalendarData_lv_LV.class", "CalendarData_mas_KE.class",
|
||||
"CalendarData_mas_TZ.class", "CalendarData_mer_KE.class", "CalendarData_mfe_MU.class",
|
||||
"CalendarData_mg_MG.class", "CalendarData_mgh_MZ.class", "CalendarData_mgo_CM.class",
|
||||
"CalendarData_mk_MK.class", "CalendarData_ml_IN.class", "CalendarData_mn_MN.class",
|
||||
"CalendarData_mr_IN.class", "CalendarData_ms_BN.class", "CalendarData_ms_MY.class",
|
||||
"CalendarData_ms_SG.class", "CalendarData_mt_MT.class", "CalendarData_mua_CM.class",
|
||||
"CalendarData_my_MM.class", "CalendarData_mzn_IR.class", "CalendarData_naq_NA.class",
|
||||
"CalendarData_nb_NO.class", "CalendarData_nb_SJ.class", "CalendarData_nd_ZW.class",
|
||||
"CalendarData_ne_IN.class", "CalendarData_ne_NP.class", "CalendarData_nl_AW.class",
|
||||
"CalendarData_nl_BE.class", "CalendarData_nl_BQ.class", "CalendarData_nl_CW.class",
|
||||
"CalendarData_nl_NL.class", "CalendarData_nl_SR.class", "CalendarData_nl_SX.class",
|
||||
"CalendarData_nmg_CM.class", "CalendarData_nnh_CM.class", "CalendarData_nus_SS.class",
|
||||
"CalendarData_nyn_UG.class", "CalendarData_om_ET.class", "CalendarData_om_KE.class",
|
||||
"CalendarData_or_IN.class", "CalendarData_os_GE.class", "CalendarData_os_RU.class",
|
||||
"CalendarData_pa_Arab_PK.class", "CalendarData_pa_IN.class", "CalendarData_pa_PK.class",
|
||||
"CalendarData_pl_PL.class", "CalendarData_ps_AF.class", "CalendarData_pt_AO.class",
|
||||
"CalendarData_pt_BR.class", "CalendarData_pt_CV.class", "CalendarData_pt_GQ.class",
|
||||
"CalendarData_pt_GW.class", "CalendarData_pt_MO.class", "CalendarData_pt_MZ.class",
|
||||
"CalendarData_pt_PT.class", "CalendarData_pt_ST.class", "CalendarData_pt_TL.class",
|
||||
"CalendarData_qu_BO.class", "CalendarData_qu_EC.class", "CalendarData_qu_PE.class",
|
||||
"CalendarData_rm_CH.class", "CalendarData_rn_BI.class", "CalendarData_ro_MD.class",
|
||||
"CalendarData_ro_RO.class", "CalendarData_rof_TZ.class", "CalendarData_ru_BY.class",
|
||||
"CalendarData_ru_KG.class", "CalendarData_ru_KZ.class", "CalendarData_ru_MD.class",
|
||||
"CalendarData_ru_RU.class", "CalendarData_ru_UA.class", "CalendarData_rw_RW.class",
|
||||
"CalendarData_rwk_TZ.class", "CalendarData_sah_RU.class", "CalendarData_saq_KE.class",
|
||||
"CalendarData_sbp_TZ.class", "CalendarData_se_FI.class", "CalendarData_se_NO.class",
|
||||
"CalendarData_se_SE.class", "CalendarData_seh_MZ.class", "CalendarData_ses_ML.class",
|
||||
"CalendarData_sg_CF.class", "CalendarData_shi_Latn_MA.class", "CalendarData_shi_MA.class",
|
||||
"CalendarData_si_LK.class", "CalendarData_sk_SK.class", "CalendarData_sl_SI.class",
|
||||
"CalendarData_smn_FI.class", "CalendarData_sn_ZW.class", "CalendarData_so_DJ.class",
|
||||
"CalendarData_so_ET.class", "CalendarData_so_KE.class", "CalendarData_so_SO.class",
|
||||
"CalendarData_sq_AL.class", "CalendarData_sq_MK.class", "CalendarData_sq_XK.class",
|
||||
"CalendarData_sr_BA.class", "CalendarData_sr_Latn_BA.class", "CalendarData_sr_Latn_ME.class",
|
||||
"CalendarData_sr_Latn_RS.class", "CalendarData_sr_Latn_XK.class", "CalendarData_sr_ME.class",
|
||||
"CalendarData_sr_RS.class", "CalendarData_sr_XK.class", "CalendarData_sv_AX.class",
|
||||
"CalendarData_sv_FI.class", "CalendarData_sv_SE.class", "CalendarData_sw_CD.class",
|
||||
"CalendarData_sw_KE.class", "CalendarData_sw_TZ.class", "CalendarData_sw_UG.class",
|
||||
"CalendarData_ta_IN.class", "CalendarData_ta_LK.class", "CalendarData_ta_MY.class",
|
||||
"CalendarData_ta_SG.class", "CalendarData_te_IN.class", "CalendarData_teo_KE.class",
|
||||
"CalendarData_teo_UG.class", "CalendarData_th_TH.class", "CalendarData_ti_ER.class",
|
||||
"CalendarData_ti_ET.class", "CalendarData_tk_TM.class", "CalendarData_to_TO.class",
|
||||
"CalendarData_tr_CY.class", "CalendarData_tr_TR.class", "CalendarData_twq_NE.class",
|
||||
"CalendarData_tzm_MA.class", "CalendarData_ug_CN.class", "CalendarData_uk_UA.class",
|
||||
"CalendarData_ur_IN.class", "CalendarData_ur_PK.class", "CalendarData_uz_AF.class",
|
||||
"CalendarData_uz_Arab_AF.class", "CalendarData_uz_Cyrl_UZ.class", "CalendarData_uz_UZ.class",
|
||||
"CalendarData_vai_LR.class", "CalendarData_vai_Latn_LR.class", "CalendarData_vi_VN.class",
|
||||
"CalendarData_vun_TZ.class", "CalendarData_wae_CH.class", "CalendarData_xog_UG.class",
|
||||
"CalendarData_yav_CM.class", "CalendarData_yo_BJ.class", "CalendarData_yo_NG.class",
|
||||
"CalendarData_yue_HK.class", "CalendarData_zgh_MA.class", "CalendarData_zh_CN.class",
|
||||
"CalendarData_zh_HK.class", "CalendarData_zh_Hant_HK.class", "CalendarData_zh_Hant_TW.class",
|
||||
"CalendarData_zh_MO.class", "CalendarData_zh_SG.class", "CalendarData_zh_TW.class", "CalendarData_zu_ZA.class");
|
||||
|
||||
private static Set<String> removedBundles = Set.of(
|
||||
"CalendarData_az_Latn_AZ.class", "CalendarData_bs_Latn_BA.class",
|
||||
"CalendarData_pa_Guru_IN.class", "CalendarData_shi_Tfng_MA.class",
|
||||
"CalendarData_sr_Cyrl_BA.class", "CalendarData_sr_Cyrl_ME.class",
|
||||
"CalendarData_sr_Cyrl_RS.class", "CalendarData_sr_Cyrl_XK.class",
|
||||
"CalendarData_uz_Latn_UZ.class", "CalendarData_vai_Vaii_LR.class",
|
||||
"CalendarData_zh_Hans_CN.class", "CalendarData_zh_Hans_HK.class",
|
||||
"CalendarData_zh_Hans_MO.class", "CalendarData_zh_Hans_SG.class");
|
||||
|
||||
private static Set<String> addedBundles = Set.of(
|
||||
"CalendarData_az_AZ.class", "CalendarData_bs_BA.class",
|
||||
"CalendarData_pa_IN.class", "CalendarData_pa_PK.class",
|
||||
"CalendarData_shi_MA.class", "CalendarData_sr_BA.class",
|
||||
"CalendarData_sr_ME.class", "CalendarData_sr_RS.class",
|
||||
"CalendarData_sr_XK.class", "CalendarData_uz_UZ.class",
|
||||
"CalendarData_uz_AF.class", "CalendarData_vai_LR.class",
|
||||
"CalendarData_zh_CN.class", "CalendarData_zh_HK.class",
|
||||
"CalendarData_zh_MO.class", "CalendarData_zh_SG.class", "CalendarData_zh_TW.class");
|
||||
|
||||
private static Set<String> retrievedBundles = Collections.EMPTY_SET;
|
||||
|
||||
public static void main(String[] args) throws Exception {
|
||||
FileSystem fs = FileSystems.newFileSystem(URI.create("jrt:/"),
|
||||
Collections.emptyMap());
|
||||
Path path = fs.getPath("/", "modules", "jdk.localedata", "sun/util/resources/cldr/ext");
|
||||
retrievedBundles = Files.walk(path)
|
||||
.map(p -> p.getFileName().toString())
|
||||
.filter(p -> p.startsWith("CalendarData_"))
|
||||
.collect(Collectors.toSet());
|
||||
if (!retrievedBundles.equals(expectedBundles)) {
|
||||
checkAddedBundles();
|
||||
checkRemovedBundles();
|
||||
Set<String> retrievedBundlesSet = new HashSet<>(retrievedBundles);
|
||||
retrievedBundlesSet.removeAll(expectedBundles);
|
||||
throw new RuntimeException("Unexpected "
|
||||
+ " bundles " + retrievedBundlesSet + " are present in jdk.localedata module ");
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* This method checks that bundles which have been additionally generated
|
||||
* are present in jdk.localedata module.
|
||||
*/
|
||||
private static void checkAddedBundles() {
|
||||
Set<String> addedBundlesSet = new HashSet<>(addedBundles);
|
||||
addedBundlesSet.removeAll(retrievedBundles);
|
||||
if (!addedBundlesSet.isEmpty()) {
|
||||
throw new RuntimeException("expected CalendarData"
|
||||
+ " bundles " + addedBundlesSet + " are not present in jdk.localedata module ");
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* This method checks that bundles which have been removed are not present
|
||||
* in jdk.localedata module.
|
||||
*/
|
||||
private static void checkRemovedBundles() {
|
||||
Set<String> unexpectedBundles = removedBundles.stream().
|
||||
filter(retrievedBundles::contains).collect(Collectors.toSet());
|
||||
if (!unexpectedBundles.isEmpty()) {
|
||||
throw new RuntimeException("Unexpected CalendarData"
|
||||
+ " bundles " + unexpectedBundles + " are present in jdk.localedata module ");
|
||||
}
|
||||
}
|
||||
}
|
@ -8300,3 +8300,82 @@ FormatData/kea/latn.NumberElements/0=,
|
||||
FormatData/kea/latn.NumberElements/1=\u00a0
|
||||
FormatData/kea_CV/latn.NumberElements/0=,
|
||||
FormatData/kea_CV/latn.NumberElements/1=\u00a0
|
||||
|
||||
# bug #8185841
|
||||
|
||||
CalendarData/az-Latn-AZ/firstDayOfWeek=2
|
||||
CalendarData/az-Latn-AZ/minimalDaysInFirstWeek=1
|
||||
CalendarData/az-Cyrl-AZ/firstDayOfWeek=2
|
||||
CalendarData/az-Cyrl-AZ/minimalDaysInFirstWeek=1
|
||||
CalendarData/az_AZ/firstDayOfWeek=2
|
||||
CalendarData/az-AZ/minimalDaysInFirstWeek=1
|
||||
CalendarData/bs-Cyrl-BA/firstDayOfWeek=2
|
||||
CalendarData/bs-Cyrl-BA/minimalDaysInFirstWeek=1
|
||||
CalendarData/bs_BA/firstDayOfWeek=2
|
||||
CalendarData/bs_BA/minimalDaysInFirstWeek=1
|
||||
CalendarData/pa-Arab-PK/firstDayOfWeek=1
|
||||
CalendarData/pa-Arab-PK/minimalDaysInFirstWeek=1
|
||||
CalendarData/pa_PK/firstDayOfWeek=1
|
||||
CalendarData/pa_PK/minimalDaysInFirstWeek=1
|
||||
CalendarData/pa-Guru-IN/firstDayOfWeek=1
|
||||
CalendarData/pa-Guru-IN/minimalDaysInFirstWeek=1
|
||||
CalendarData/pa_IN/firstDayOfWeek=1
|
||||
CalendarData/pa_IN/minimalDaysInFirstWeek=1
|
||||
CalendarData/shi-Latn-MA/firstDayOfWeek=7
|
||||
CalendarData/shi-Latn-MA/minimalDaysInFirstWeek=1
|
||||
CalendarData/shi-Tfng-MA/firstDayOfWeek=7
|
||||
CalendarData/shi-Tfng-MA/minimalDaysInFirstWeek=1
|
||||
CalendarData/shi_MA/firstDayOfWeek=7
|
||||
CalendarData/shi_MA/minimalDaysInFirstWeek=1
|
||||
CalendarData/sr-Cyrl-BA/firstDayOfWeek=2
|
||||
CalendarData/sr-Cyrl-BA/minimalDaysInFirstWeek=1
|
||||
CalendarData/sr-Cyrl-ME/firstDayOfWeek=2
|
||||
CalendarData/sr-Cyrl-ME/minimalDaysInFirstWeek=1
|
||||
CalendarData/sr-Cyrl-RS/firstDayOfWeek=2
|
||||
CalendarData/sr-Cyrl-RS/minimalDaysInFirstWeek=1
|
||||
CalendarData/sr-Cyrl-XK/firstDayOfWeek=2
|
||||
CalendarData/sr-Cyrl-XK/minimalDaysInFirstWeek=1
|
||||
CalendarData/sr_RS/firstDayOfWeek=2
|
||||
CalendarData/sr_RS/minimalDaysInFirstWeek=1
|
||||
CalendarData/sr_BA/firstDayOfWeek=2
|
||||
CalendarData/sr_BA/minimalDaysInFirstWeek=1
|
||||
CalendarData/sr_ME/firstDayOfWeek=2
|
||||
CalendarData/sr_ME/minimalDaysInFirstWeek=1
|
||||
CalendarData/sr_XK/firstDayOfWeek=2
|
||||
CalendarData/sr_XK/minimalDaysInFirstWeek=1
|
||||
CalendarData/uz-Arab-AF/firstDayOfWeek=7
|
||||
CalendarData/uz-Arab-AF/minimalDaysInFirstWeek=1
|
||||
CalendarData/uz-Cyrl-UZ/firstDayOfWeek=2
|
||||
CalendarData/uz-Cyrl-UZ/minimalDaysInFirstWeek=1
|
||||
CalendarData/uz-Latn-UZ/firstDayOfWeek=2
|
||||
CalendarData/uz-Latn-UZ/minimalDaysInFirstWeek=1
|
||||
CalendarData/vai-Latn-LR/firstDayOfWeek=2
|
||||
CalendarData/vai-Latn-LR/minimalDaysInFirstWeek=1
|
||||
CalendarData/vai-Vaii-LR/firstDayOfWeek=2
|
||||
CalendarData/vai-Vaii-LR/minimalDaysInFirstWeek=1
|
||||
CalendarData/vai_LR/firstDayOfWeek=2
|
||||
CalendarData/vai_LR/minimalDaysInFirstWeek=1
|
||||
CalendarData/uz_UZ/firstDayOfWeek=2
|
||||
CalendarData/uz_UZ/minimalDaysInFirstWeek=1
|
||||
CalendarData/zh_CN/firstDayOfWeek=1
|
||||
CalendarData/zh_CN/minimalDaysInFirstWeek=1
|
||||
CalendarData/zh-Hans-CN/minimalDaysInFirstWeek=1
|
||||
CalendarData/zh-Hans-CN/firstDayOfWeek=1
|
||||
CalendarData/zh-Hans-HK/firstDayOfWeek=1
|
||||
CalendarData/zh-Hans-HK/minimalDaysInFirstWeek=1
|
||||
CalendarData/zh-Hans-MO/minimalDaysInFirstWeek=1
|
||||
CalendarData/zh-Hans-MO/firstDayOfWeek=1
|
||||
CalendarData/zh-Hans-SG/firstDayOfWeek=1
|
||||
CalendarData/zh-Hans-SG/minimalDaysInFirstWeek=1
|
||||
CalendarData/zh-Hant-HK/minimalDaysInFirstWeek=1
|
||||
CalendarData/zh-Hant-HK/firstDayOfWeek=1
|
||||
CalendarData/zh-Hant-TW/minimalDaysInFirstWeek=1
|
||||
CalendarData/zh-Hant-TW/firstDayOfWeek=1
|
||||
CalendarData/zh_HK/minimalDaysInFirstWeek=1
|
||||
CalendarData/zh_HK/firstDayOfWeek=1
|
||||
CalendarData/zh_MO/minimalDaysInFirstWeek=1
|
||||
CalendarData/zh_MO/firstDayOfWeek=1
|
||||
CalendarData/zh_SG/minimalDaysInFirstWeek=1
|
||||
CalendarData/zh_SG/firstDayOfWeek=1
|
||||
CalendarData/zh_TW/firstDayOfWeek=1
|
||||
CalendarData/zh_TW/minimalDaysInFirstWeek=1
|
||||
|
@ -37,7 +37,7 @@
|
||||
* 7003124 7085757 7028073 7171028 7189611 8000983 7195759 8004489 8006509
|
||||
* 7114053 7074882 7040556 8008577 8013836 8021121 6192407 6931564 8027695
|
||||
* 8017142 8037343 8055222 8042126 8074791 8075173 8080774 8129361 8134916
|
||||
* 8145136 8145952 8164784 8037111 8081643 7037368 8178872
|
||||
* 8145136 8145952 8164784 8037111 8081643 7037368 8178872 8185841
|
||||
* @summary Verify locale data
|
||||
* @modules java.base/sun.util.resources
|
||||
* @modules jdk.localedata
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2016, 2017, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
@ -40,7 +40,7 @@ import tests.Result;
|
||||
|
||||
/*
|
||||
* @test
|
||||
* @bug 8152143 8152704 8155649 8165804
|
||||
* @bug 8152143 8152704 8155649 8165804 8185841
|
||||
* @summary IncludeLocalesPlugin tests
|
||||
* @author Naoto Sato
|
||||
* @library ../../lib
|
||||
@ -231,7 +231,7 @@ public class IncludeLocalesPluginTest {
|
||||
"/jdk.localedata/sun/text/resources/cldr/ext/FormatData_en_001.class",
|
||||
"/jdk.localedata/sun/text/resources/cldr/ext/FormatData_en_IN.class",
|
||||
"/jdk.localedata/sun/util/resources/cldr/ext/CalendarData_kok_IN.class",
|
||||
"/jdk.localedata/sun/util/resources/cldr/ext/CalendarData_pa_Guru_IN.class"),
|
||||
"/jdk.localedata/sun/util/resources/cldr/ext/CalendarData_pa_IN.class"),
|
||||
List.of(
|
||||
"/jdk.localedata/sun/text/resources/ext/LineBreakIteratorData_th",
|
||||
"/jdk.localedata/sun/text/resources/ext/thai_dict",
|
||||
@ -327,7 +327,7 @@ public class IncludeLocalesPluginTest {
|
||||
"/jdk.localedata/sun/text/resources/cldr/ext/FormatData_th.class"),
|
||||
List.of(
|
||||
"(root)", "en", "en_US", "en_US_POSIX", "zh", "zh__#Hans", "zh_CN",
|
||||
"zh_CN_#Hans", "zh_HK_#Hans", "zh_MO_#Hans", "zh_SG", "zh_SG_#Hans"),
|
||||
"zh_HK", "zh_MO", "zh_CN_#Hans", "zh_HK_#Hans", "zh_MO_#Hans", "zh_SG", "zh_SG_#Hans"),
|
||||
"",
|
||||
},
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user