diff --git a/make/jdk/src/classes/build/tools/cldrconverter/CLDRConverter.java b/make/jdk/src/classes/build/tools/cldrconverter/CLDRConverter.java index abf1be64306..e0e95c9e6a2 100644 --- a/make/jdk/src/classes/build/tools/cldrconverter/CLDRConverter.java +++ b/make/jdk/src/classes/build/tools/cldrconverter/CLDRConverter.java @@ -847,19 +847,24 @@ public class CLDRConverter { "DateTimePatternChars", "PluralRules", "DayPeriodRules", - "DateFormatItem", + "DateFormatItemInputRegions.allowed", + "DateFormatItemInputRegions.preferred", }; + static final Set availableSkeletons = new HashSet<>(); + private static Map extractFormatData(Map map, String id) { Map formatData = new LinkedHashMap<>(); for (CalendarType calendarType : CalendarType.values()) { String prefix = calendarType.keyElementName(); Arrays.stream(FORMAT_DATA_ELEMENTS) - .flatMap(elem -> map.keySet().stream().filter(k -> k.startsWith(prefix + elem))) - .forEach(key -> { + .forEach(elem -> { + var key = prefix + elem; copyIfPresent(map, "java.time." + key, formatData); copyIfPresent(map, key, formatData); }); + availableSkeletons.forEach(s -> + copyIfPresent(map, prefix + "DateFormatItem." + s, formatData)); } for (String key : map.keySet()) { diff --git a/make/jdk/src/classes/build/tools/cldrconverter/LDMLParseHandler.java b/make/jdk/src/classes/build/tools/cldrconverter/LDMLParseHandler.java index 729900c9e05..78152453792 100644 --- a/make/jdk/src/classes/build/tools/cldrconverter/LDMLParseHandler.java +++ b/make/jdk/src/classes/build/tools/cldrconverter/LDMLParseHandler.java @@ -768,9 +768,14 @@ class LDMLParseHandler extends AbstractLDMLHandler { case "dateFormatItem": { // for FormatData - prefix = (currentCalendarType == null) ? "" : currentCalendarType.keyElementName(); - pushStringEntry(qName, attributes, - prefix + Bundle.DATEFORMATITEM_KEY_PREFIX + attributes.getValue("id")); + if (currentCalendarType != null) { + var skeleton = attributes.getValue("id"); + CLDRConverter.availableSkeletons.add(skeleton); + pushStringEntry(qName, attributes, + currentCalendarType.keyElementName() + Bundle.DATEFORMATITEM_KEY_PREFIX + skeleton); + } else { + pushIgnoredContainer(qName); + } } break;