Skip to content

Commit

Permalink
CLDR-17514 Pages too big (v46): further divisions for Volume, Units
Browse files Browse the repository at this point in the history
-Divide Volume Other into Volume US and Volume Other

-Divide Other Units into Other Units Metric, Other Units Metric Per, Other Units US and Other Units

-New subroutines getOtherUnitsPageId, isSystemUnit, getShortUnitId

-Fix deprecation warnings: remove getSectionsToPages; fix TestZ and filterCldr
  • Loading branch information
btangmu committed Apr 5, 2024
1 parent d6ad707 commit 12cf831
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 36 deletions.
71 changes: 41 additions & 30 deletions tools/cldr-code/src/main/java/org/unicode/cldr/util/PathHeader.java
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Locale;
import java.util.Map;
Expand Down Expand Up @@ -232,6 +231,7 @@ public enum PageId {
Length(SectionId.Units),
Area(SectionId.Units),
Volume_Metric(SectionId.Units, "Volume Metric"),
Volume_US(SectionId.Units, "Volume US"),
Volume_Other(SectionId.Units, "Volume Other"),
SpeedAcceleration(SectionId.Units, "Speed and Acceleration"),
MassWeight(SectionId.Units, "Mass and Weight"),
Expand All @@ -240,6 +240,9 @@ public enum PageId {
Weather(SectionId.Units),
Digital(SectionId.Units),
Coordinates(SectionId.Units),
OtherUnitsMetric(SectionId.Units, "Other Unitsj Metric"),
OtherUnitsMetricPer(SectionId.Units, "Other Units Metric Per"),
OtherUnitsUS(SectionId.Units, "Other Units US"),
OtherUnits(SectionId.Units, "Other Units"),
CompoundUnits(SectionId.Units, "Compound Units"),

Expand Down Expand Up @@ -860,28 +863,7 @@ public static Relation<SectionId, PageId> getSectionIdsToPageIds() {
return SectionIdToPageIds;
}

/**
* Return the names for Sections and Pages that are defined, for display in menus. Both are
* ordered.
*
* @deprecated Use getSectionIdsToPageIds
*/
@Deprecated
public static LinkedHashMap<String, Set<String>> getSectionsToPages() {
LinkedHashMap<String, Set<String>> sectionsToPages = new LinkedHashMap<>();
for (PageId pageId : PageId.values()) {
String sectionId2 = pageId.getSectionId().toString();
Set<String> pages =
sectionsToPages.computeIfAbsent(sectionId2, k -> new LinkedHashSet<>());
pages.add(pageId.toString());
}
return sectionsToPages;
}

/**
* @deprecated, use the filterCldr with the section/page ids.
*/
public Iterable<String> filterCldr(String section, String page, CLDRFile file) {
public Iterable<String> filterCldr(SectionId section, PageId page, CLDRFile file) {
return new FilteredIterable(section, page, file);
}

Expand Down Expand Up @@ -2241,6 +2223,8 @@ private static String fix(String input, int orderIn) {
if (functionStart < 0) {
if ("Volume".equals(input)) {
return getVolumePageId(args.value[0] /* path */).toString();
} else if ("Other Units".equals(input)) {
return getOtherUnitsPageId(args.value[0] /* path */).toString();
}
return input;
}
Expand All @@ -2262,10 +2246,42 @@ private static String fix(String input, int orderIn) {
}
}

private static Set<UnitConverter.UnitSystem> METRIC =
private static Set<UnitConverter.UnitSystem> METRIC_UNITS =
Set.of(UnitConverter.UnitSystem.metric, UnitConverter.UnitSystem.metric_adjacent);

private static Set<UnitConverter.UnitSystem> US_UNITS =
Set.of(UnitConverter.UnitSystem.ussystem);

private static PageId getVolumePageId(String path) {
final String shortUnitId = getShortUnitId(path);
if (isSystemUnit(shortUnitId, METRIC_UNITS)) {
return PageId.Volume_Metric;
} else {
return isSystemUnit(shortUnitId, US_UNITS) ? PageId.Volume_US : PageId.Volume_Other;
}
}

private static PageId getOtherUnitsPageId(String path) {
String shortUnitId = getShortUnitId(path);
if (isSystemUnit(shortUnitId, METRIC_UNITS)) {
return shortUnitId.contains("per")
? PageId.OtherUnitsMetricPer
: PageId.OtherUnitsMetric;
} else {
return isSystemUnit(shortUnitId, US_UNITS)
? PageId.OtherUnitsUS
: PageId.OtherUnits;
}
}

private static boolean isSystemUnit(
String shortUnitId, Set<UnitConverter.UnitSystem> system) {
final UnitConverter uc = supplementalDataInfo.getUnitConverter();
final Set<UnitConverter.UnitSystem> systems = uc.getSystemsEnum(shortUnitId);
return !Collections.disjoint(system, systems);
}

private static String getShortUnitId(String path) {
// Extract the unit from the path. For example, if path is
// //ldml/units/unitLength[@type="narrow"]/unit[@type="volume-cubic-kilometer"]/displayName
// then extract "volume-cubic-kilometer" which is the long unit id
Expand All @@ -2276,12 +2292,7 @@ private static PageId getVolumePageId(String path) {
}
final UnitConverter uc = supplementalDataInfo.getUnitConverter();
// Convert, for example, "volume-cubic-kilometer" to "cubic-kilometer"
final String shortUnitId = uc.getShortId(longUnitId);
if (!Collections.disjoint(METRIC, uc.getSystemsEnum(shortUnitId))) {
return PageId.Volume_Metric;
} else {
return PageId.Volume_Other;
}
return uc.getShortId(longUnitId);
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1090,12 +1090,11 @@ public void TestZ() {
for (String item : threeLevel) {
logln(item);
}
LinkedHashMap<String, Set<String>> sectionsToPages =
org.unicode.cldr.util.PathHeader.Factory.getSectionsToPages();
logln("\nMenus:\t" + sectionsToPages.size());
for (Entry<String, Set<String>> item : sectionsToPages.entrySet()) {
final String section = item.getKey();
for (String page : item.getValue()) {
Relation<SectionId, PageId> s2p = PathHeader.Factory.getSectionIdsToPageIds();
logln("\nMenus:\t" + s2p.size());
for (Entry<SectionId, Set<PageId>> sectionAndPages : s2p.keyValuesSet()) {
final SectionId section = sectionAndPages.getKey();
for (PageId page : sectionAndPages.getValue()) {
logln("\t" + section + "\t" + page);
int count = 0;
for (String path : pathHeaderFactory.filterCldr(section, page, english)) {
Expand Down

0 comments on commit 12cf831

Please sign in to comment.