package org.unicode.cldr.tool; import java.io.IOException; import java.util.HashMap; import java.util.HashSet; import java.util.List; import java.util.Map; import java.util.Map.Entry; import java.util.Set; import java.util.TreeSet; import org.unicode.cldr.util.CLDRFile; import org.unicode.cldr.util.CldrUtility; import org.unicode.cldr.util.StandardCodes.LstrType; import org.unicode.cldr.util.TransliteratorUtilities; import org.unicode.cldr.util.Validity; import org.unicode.cldr.util.Validity.Status; import com.ibm.icu.dev.util.CollectionUtilities; import com.ibm.icu.impl.Relation; import com.ibm.icu.impl.Row.R2; public class ChartSubdivisions extends Chart { static SubdivisionNames EN = new SubdivisionNames("en"); public static void main(String[] args) { new ChartSubdivisions().writeChart(null); } @Override public String getDirectory() { return FormattedFileWriter.CHART_TARGET_DIR; } @Override public String getTitle() { return "Territory Subdivisions"; } @Override public String getExplanation() { return "
Shows the subdivisions of territories, using the Unicode Subdivision Codes with the English names (and sort order). " + "For more information see the LDML spec.
";
}
@Override
public void writeContents(FormattedFileWriter pw) throws IOException {
TablePrinter tablePrinter = new TablePrinter()
.addColumn("Region", "class='source'", null, "class='source'", true)
.setSortPriority(1)
.addColumn("Code", "class='source'", CldrUtility.getDoubleLinkMsg(), "class='source'", true)
.setBreakSpans(true)
.addColumn("Subdivision1", "class='target'", null, "class='target'", true)
.setSortPriority(2)
.addColumn("Code", "class='target'", CldrUtility.getDoubleLinkMsg(), "class='target'", true)
.setBreakSpans(true)
.addColumn("Subdivision2", "class='target'", null, "class='target'", true)
.setSortPriority(3)
.addColumn("Code", "class='target'", CldrUtility.getDoubleLinkMsg(), "class='target'", true);
Map, String> a1 = aliases.get(s1);
if (a1 != null) {
name1 = "= " + a1.get0().get(0) + " (" + name1 + ")";
}
R2
, String> a2 = aliases.get(s2);
if (a2 != null) {
name2 = "= " + a2.get0().get(0) + " (" + name2 + ")";
}
tablePrinter.addRow()
.addCell(ENGLISH.getName(CLDRFile.TERRITORY_NAME, region))
.addCell(region)
.addCell(name1)
//.addCell(type)
.addCell(s1)
.addCell(name2)
.addCell(s2)
.finishRow();
remainder.remove(region);
}
}
for (String region : remainder) {
Set