Skip to content

Commit

Permalink
CLDR-17367 v45 JSON: improve localeRules processing
Browse files Browse the repository at this point in the history
- add special handling for localeRules
  • Loading branch information
srl295 committed Apr 4, 2024
1 parent 126326e commit e2bc061
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -1855,7 +1855,27 @@ private JsonElement startNonleafNode(JsonElement out, final CldrNode node) throw
o.getAsJsonObject().addProperty(attrAsKey, v);
} // else, omit
} else {
o.getAsJsonObject().addProperty(attrAsKey, value);
// hack for localeRules
if (attrAsKey.equals("_localeRules")) {
// find the _localeRules object, add if it didn't exist
JsonElement localeRules = out.getAsJsonObject().get(attrAsKey);
if (localeRules == null) {
localeRules = new JsonObject();
out.getAsJsonObject().add(attrAsKey, localeRules);
}
// find the sibling object, add if it did't exist ( this will be parentLocale or collations etc.)
JsonElement sibling = localeRules.getAsJsonObject().get(name);
if (sibling == null) {
sibling = new JsonObject();
localeRules.getAsJsonObject().add(name, sibling);
}
// get the 'parent' attribute, which wil be the value
final String parent = XPathParts.getFrozenInstance(node.getUntransformedPath()).getAttributeValue(-1, "parent");
// finally, we add something like "nonLikelyScript: und"
sibling.getAsJsonObject().addProperty(value, parent);
} else {
o.getAsJsonObject().addProperty(attrAsKey, value);
}
}
}
return o;
Expand Down Expand Up @@ -2312,7 +2332,9 @@ private void writeLeafNode(
String attrValue = escapeValue(rawAttrValue);
// attribute is prefixed with "_" when being used as key.
String attrAsKey = "_" + key;
logger.finest(() -> "Leaf Node: " + node.getUntransformedPath() + " ." + key);
if (node != null) {
logger.finest(() -> "Leaf Node: " + node.getUntransformedPath() + " ." + key);
}
if (LdmlConvertRules.ATTRVALUE_AS_ARRAY_SET.contains(key)) {
String[] strings = attrValue.trim().split("\\s+");
JsonArray a = new JsonArray();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -288,16 +288,22 @@ public static class SplittableAttributeSpec {
new SplittableAttributeSpec("paperSize", "territories", "type"),
new SplittableAttributeSpec("parentLocale", "locales", "parent"),
new SplittableAttributeSpec(
"collations", "locales", "parent"), // parentLocale component=collations
"collations", "locales", "parent"), // parentLocale component=collations
new SplittableAttributeSpec(
"segmentations", "locales", "parent"), // parentLocale component=segmentations
"grammaticalFeatures", "locales", "parent"), // parentLocale component=grammaticalFeatures
new SplittableAttributeSpec(
"plurals", "locales", "parent"), // parentLocale component=plurals
new SplittableAttributeSpec(
"segmentations", "locales", "parent"), // parentLocale component=segmentations
new SplittableAttributeSpec("hours", "regions", null),
new SplittableAttributeSpec("dayPeriodRules", "locales", null),
// new SplittableAttributeSpec("group", "contains", "group"),
new SplittableAttributeSpec("personList", "locales", "type"),
new SplittableAttributeSpec("unitPreference", "regions", null),
new SplittableAttributeSpec("grammaticalFeatures", "locales", null),
new SplittableAttributeSpec("grammaticalDerivations", "locales", null),
// this will cause EMPTY parentLocales elements to work properly
new SplittableAttributeSpec("parentLocales", "component", ""/* Not null */),
};

/** The set that contains all timezone type of elements. */
Expand Down

0 comments on commit e2bc061

Please sign in to comment.