From 6c2569d5dc2069749ae9e27792e1b38f6da48432 Mon Sep 17 00:00:00 2001
From: btangmu
Date: Wed, 4 Sep 2024 16:10:00 -0400
Subject: [PATCH] CLDR-14913 Revise VXML generation, further
-Remove obsolete admin-OutputAllFiles.jsp and related dead code
-Shorten and simplify output; do not write strangely colored vxml xml rxml pxml
-Set percent to 100, and status to READY, only if verification is successful
-Use SpecialLocales.getType to skip generating locales such as mul_ZZ; still generate algorithmic locales
-Use Logger instead of System.out; use at least Level.WARNING since Level.INFO is not displayed (for unknown reasons)
-Do not log timing info that depended on deprecated ElapsedTimer
-Fix compiler warnings and accept compiler-suggested refactoring
-TODO comments
---
.../unicode/cldr/web/OutputFileManager.java | 506 +++++++-----------
.../org/unicode/cldr/web/VxmlGenerator.java | 8 +-
.../java/org/unicode/cldr/web/VxmlQueue.java | 11 +-
.../src/main/webapp/admin-OutputAllFiles.jsp | 20 -
4 files changed, 213 insertions(+), 332 deletions(-)
delete mode 100644 tools/cldr-apps/src/main/webapp/admin-OutputAllFiles.jsp
diff --git a/tools/cldr-apps/src/main/java/org/unicode/cldr/web/OutputFileManager.java b/tools/cldr-apps/src/main/java/org/unicode/cldr/web/OutputFileManager.java
index 42d862e8def..408aaa5ffd8 100644
--- a/tools/cldr-apps/src/main/java/org/unicode/cldr/web/OutputFileManager.java
+++ b/tools/cldr-apps/src/main/java/org/unicode/cldr/web/OutputFileManager.java
@@ -10,7 +10,6 @@
import com.google.common.collect.BiMap;
import com.google.common.collect.HashBiMap;
import com.google.common.collect.ImmutableMap;
-import com.ibm.icu.dev.util.ElapsedTimer;
import java.io.File;
import java.io.FileFilter;
import java.io.FileNotFoundException;
@@ -20,17 +19,20 @@
import java.io.PrintWriter;
import java.io.UnsupportedEncodingException;
import java.io.Writer;
+import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.time.Instant;
import java.util.*;
import java.util.Map.Entry;
import java.util.function.Predicate;
+import java.util.logging.Level;
+import java.util.logging.Logger;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.unicode.cldr.util.*;
-import org.unicode.cldr.web.CLDRProgressIndicator.CLDRProgressTask;
public class OutputFileManager {
+ private static final Logger logger = SurveyLog.forClass(OutputFileManager.class);
private static final String XML_SUFFIX = ".xml";
private final SurveyMain sm;
@@ -80,77 +82,31 @@ private static class DirNames {
static final String[] mainAndAnnotations = {justMain, justAnnotations};
}
- /**
- * Output all files (VXML, etc.) and verify their consistency
- *
- * @param request the HttpServletRequest, used for "vap"
- * @param out the Writer, to receive HTML output
- * Invoked by pasting a url like this into a browser:
- * .../cldr-apps/admin-OutputAllFiles.jsp?vap=...
- *
TODO: remove this method, and admin-OutputAllFiles.jsp, and other obsolete code once
- * the new implementation with GenerateVxml.java is well tested
- *
Reference: https://unicode-org.atlassian.net/browse/CLDR-14913
- */
- public static void outputAndVerifyAllFiles(HttpServletRequest request, Writer out) {
- String vap = request.getParameter("vap");
- try {
- if (vap == null || !vap.equals(SurveyMain.vap)) {
- out.write("Not authorized.");
- return;
- }
- boolean outputFiles = "true".equals(request.getParameter("output"));
- boolean removeEmpty = "true".equals(request.getParameter("remove"));
- boolean verifyConsistent = "true".equals(request.getParameter("verify"));
- if (!(outputFiles || removeEmpty || verifyConsistent)) {
- out.write(
- "
Usage: specify at least one of these parameters (all false by default):
\n");
- out.write("output=true/false
\n");
- out.write("remove=true/false
\n");
- out.write("verify=true/false
\n");
- return;
- }
- generateVxml(null, out, outputFiles, removeEmpty, verifyConsistent);
- } catch (Exception e) {
- System.err.println("Exception in outputAndVerifyAllFiles: " + e);
- e.printStackTrace();
- }
- }
-
/**
* Generate VXML
*
- * Called indirectly by modern api/GenerateVxml, as well as by legacy outputAndVerifyAllFiles
- *
- * @param vxmlGenerator the VxmlGenerator, or null if called by outputAndVerifyAllFiles
- * @param out
- * @param outputFiles
- * @param removeEmpty
- * @param verifyConsistent
+ * @param vxmlGenerator the VxmlGenerator
+ * @param out the Writer to receive output
*/
- public static void generateVxml(
- VxmlGenerator vxmlGenerator,
- Writer out,
- boolean outputFiles,
- boolean removeEmpty,
- boolean verifyConsistent) {
+ public static void generateVxml(VxmlGenerator vxmlGenerator, Writer out) {
try {
/*
* Sync on OutputFileManager.class here prevents re-entrance if invoked repeatedly before completion.
*/
synchronized (OutputFileManager.class) {
SurveyMain sm = CookieSession.sm;
-
OutputFileManager ofm = sm.getOutputFileManager();
-
File vetdataDir = sm.getVetdir();
vetdataDir = createNewManualVetdataDir(vetdataDir);
if (vetdataDir == null) {
out.write("Directory creation for vetting data failed.");
return;
}
+ // TODO: make the directory name a separate field of the http response.
+ // In the meantime, it is still part of the html written to "out".
+ // Reference: https://unicode-org.atlassian.net/browse/CLDR-14913
out.write("
Created new directory: " + vetdataDir + "
");
-
- if (outputFiles && !ofm.outputAllFiles(vxmlGenerator, out, vetdataDir)) {
+ if (!ofm.outputAllFiles(vxmlGenerator, out, vetdataDir)) {
out.write("File output failed.");
return;
}
@@ -158,21 +114,13 @@ public static void generateVxml(
out.write("Copying DTD failed.");
return;
}
- File vxmlDir = null;
- if (removeEmpty || verifyConsistent) {
- vxmlDir = new File(vetdataDir + "/" + Kind.vxml.name());
- }
- if (removeEmpty) {
- ofm.removeEmptyFiles(vxmlDir);
- }
- if (verifyConsistent) {
- ofm.verifyAllFiles(vxmlGenerator, out, vxmlDir);
- }
+ File vxmlDir = new File(vetdataDir + "/" + Kind.vxml.name());
+ ofm.removeEmptyFiles(vxmlDir);
+ ofm.verifyAllFiles(vxmlGenerator, out, vxmlDir);
}
- System.out.println("reallyOutputAndVerifyAllFiles finished");
+ logger.log(Level.WARNING, "generateVxml finished");
} catch (Exception e) {
- System.err.println("Exception in reallyOutputAndVerifyAllFiles: " + e);
- e.printStackTrace();
+ logger.log(Level.SEVERE, "generateVxml: " + e.getMessage(), e);
}
}
@@ -195,7 +143,7 @@ private static File createNewManualVetdataDir(File vetdataDir) {
String manualVetdataDirName =
vetdataDir.getParent() + "/" + vetdataDir.getName() + "-" + timestamp;
File manualVetdataDir = new File(manualVetdataDirName);
- if (manualVetdataDir.mkdirs() == false) {
+ if (!manualVetdataDir.mkdirs()) {
return null;
}
return manualVetdataDir;
@@ -247,78 +195,40 @@ private boolean copyDtd(File vetdataDir) {
/**
* Output all files (VXML, etc.)
*
- * @param vxmlGenerator the VxmlGenerator, or null if using jsp
+ * @param vxmlGenerator the VxmlGenerator
* @param out the Writer, to receive HTML output
* @param vetDataDir the folder in which to write
* @return true for success, false for failure
*/
private boolean outputAllFiles(VxmlGenerator vxmlGenerator, Writer out, File vetDataDir) {
try {
- long start = System.currentTimeMillis();
- ElapsedTimer overallTimer =
- new ElapsedTimer("overall update started " + new java.util.Date());
- int numupd = 0;
-
- out.write("\n");
-
- Set sortSet =
- (vxmlGenerator != null) ? vxmlGenerator.getSortSet() : createVxmlLocaleSet();
+ // TODO: instead of generating html on the back end, send structured data to the
+ // front end, including the generated list of locales as an array; or possibly just
+ // the number of locales written so far, along with most recent locale name.
+ // In the meantime, write a paragraph containing a comma-separated list of locale base
+ // names.
+ // Reference: https://unicode-org.atlassian.net/browse/CLDR-14913
+ out.write("");
+ Set sortSet = vxmlGenerator.getSortSet();
+ int i = 0;
for (CLDRLocale loc : sortSet) {
- out.write("- " + loc.getDisplayName() + "
\n");
+ if (i++ > 0) {
+ out.write(", ");
+ }
+ out.write(loc.getBaseName());
for (OutputFileManager.Kind kind : OutputFileManager.Kind.values()) {
- /*
- * TODO: is there any point in outputting anything here for kind other than vxml and pxml?
- */
- String background = "#ff9999";
- String weight = "regular";
- String color = "silver";
- out.write(
- "\n\n\t");
- out.write(kind.toString());
if (kind == OutputFileManager.Kind.vxml
|| kind == OutputFileManager.Kind.pxml) {
- System.err.println("Writing " + loc.getDisplayName() + ":" + kind);
- ElapsedTimer et = new ElapsedTimer("to write " + loc + ":" + kind);
+ logger.log(Level.WARNING, "Writing " + loc.getDisplayName() + ":" + kind);
writeManualOutputFile(vetDataDir, loc, kind);
- numupd++;
- System.err.println(et + " - upd " + numupd + "/" + (sortSet.size() + 2));
}
- out.write(" ");
- }
- out.write(" \n");
- if (vxmlGenerator != null) {
- vxmlGenerator.update(loc);
}
+ vxmlGenerator.update(loc);
}
- out.write("
\n");
- out.write("
\n");
- out.write("Total upd: " + numupd + "/" + (sortSet.size() + 2) + "\n");
- out.write(
- "Total time: "
- + overallTimer
- + " : "
- + ((System.currentTimeMillis() - start) / (1000.0 * 60))
- + "min\n");
-
- System.err.println(
- overallTimer
- + " - updated "
- + numupd
- + "/"
- + (sortSet.size() + 2)
- + " in "
- + (System.currentTimeMillis() - start) / (1000.0 * 60)
- + " min");
+ out.write("
");
return true;
} catch (Exception e) {
- System.err.println("Exception in outputAllFiles: " + e);
- e.printStackTrace();
+ logger.log(Level.SEVERE, "outputAllFiles: " + e.getMessage(), e);
return false;
}
}
@@ -328,8 +238,12 @@ public static Set createVxmlLocaleSet() {
// skip "en" and "root", since they should never be changed by the Survey Tool
set.remove(CLDRLocale.getInstance("en"));
set.remove(CLDRLocale.getInstance(LocaleNames.ROOT));
- // Remove "mul", "mul_ZZ", etc.
- set.removeIf(loc -> loc.getBaseName().startsWith(LocaleNames.MUL));
+ // Remove "mul", "mul_ZZ", etc.; all "special" locales except algorithmic.
+ set.removeIf(
+ loc -> {
+ SpecialLocales.Type t = SpecialLocales.getType(loc);
+ return t != null && t != SpecialLocales.Type.algorithmic;
+ });
return set;
}
@@ -343,7 +257,6 @@ public static Set createVxmlLocaleSet() {
* @param kind the Kind, currently Kind.vxml and Kind.pxml are supported
*/
private void writeManualOutputFile(File vetDataDir, CLDRLocale loc, Kind kind) {
- long st = System.currentTimeMillis();
CLDRFile cldrFile;
if (kind == Kind.vxml) {
cldrFile = sm.getSTFactory().make(loc.getBaseName(), false);
@@ -359,20 +272,7 @@ private void writeManualOutputFile(File vetDataDir, CLDRLocale loc, Kind kind) {
* in both common and seed, and follow that example. (This is somewhat circular.)
* If a baseline file doesn't exist in common or seed, go with common.
*/
- File baseDir = CLDRConfig.getInstance().getCldrBaseDirectory();
- String commonOrSeed = DirNames.justCommon;
- for (String c : DirNames.commonAndSeed) {
- String path = baseDir + "/" + c + "/" + DirNames.justMain + "/" + loc + XML_SUFFIX;
- if (new File(path).exists()) {
- commonOrSeed = c;
- break;
- }
- }
- /*
- * Only create the file in "main" here; doWriteFile will then create the file in "annotations"
- */
- String outDirName =
- vetDataDir + "/" + kind + "/" + commonOrSeed + "/" + DirNames.justMain;
+ String outDirName = getOutDirName(vetDataDir, loc, kind);
File outDir = new File(outDirName);
if (!outDir.exists() && !outDir.mkdirs()) {
throw new InternalError("Unable to create directory: " + outDirName);
@@ -380,19 +280,28 @@ private void writeManualOutputFile(File vetDataDir, CLDRLocale loc, Kind kind) {
String outFileName = outDirName + "/" + loc + XML_SUFFIX;
File outFile = new File(outFileName);
doWriteFile(cldrFile, kind, outFile);
- SurveyLog.debug(
- "Updater: MANUALLY wrote: "
- + kind
- + "/"
- + loc
- + " - "
- + ElapsedTimer.elapsedTime(st));
} catch (IOException e) {
- e.printStackTrace();
+ logger.log(Level.SEVERE, "writeManualOutputFile: " + e.getMessage(), e);
throw new RuntimeException("IO Exception " + e, e);
}
}
+ private static String getOutDirName(File vetDataDir, CLDRLocale loc, Kind kind) {
+ File baseDir = CLDRConfig.getInstance().getCldrBaseDirectory();
+ String commonOrSeed = DirNames.justCommon;
+ for (String c : DirNames.commonAndSeed) {
+ String path = baseDir + "/" + c + "/" + DirNames.justMain + "/" + loc + XML_SUFFIX;
+ if (new File(path).exists()) {
+ commonOrSeed = c;
+ break;
+ }
+ }
+ /*
+ * Only create the file in "main" here; doWriteFile will then create the file in "annotations"
+ */
+ return vetDataDir + "/" + kind + "/" + commonOrSeed + "/" + DirNames.justMain;
+ }
+
/** Remove "empty" VXML files in a set of directories */
private void removeEmptyFiles(File vxmlDir) throws IOException {
for (String c : DirNames.commonAndSeed) {
@@ -416,7 +325,7 @@ private void removeEmptyFilesOneDir(File dirFile) throws IOException {
Set treatAsNonEmpty = new HashSet<>();
BiMap onlyHasIdentity = HashBiMap.create();
int counter = 0;
- for (File f : dirFile.listFiles()) {
+ for (File f : Objects.requireNonNull(dirFile.listFiles())) {
List> data = new ArrayList<>();
String canonicalPath = f.getCanonicalPath();
if (canonicalPath.endsWith("root.xml") || !canonicalPath.endsWith(XML_SUFFIX)) {
@@ -432,7 +341,7 @@ private void removeEmptyFilesOneDir(File dirFile) throws IOException {
boolean itemHasMoreThanIdentity = false;
for (Pair item : data) {
if (!item.getFirst().contains("/identity")) {
- System.out.println(++counter + ") NOT-EMPTY: " + canonicalPath);
+ logger.log(Level.WARNING, ++counter + ") NOT-EMPTY: " + canonicalPath);
/*
* keep this file, and its ancestors (needed for inheritance even if only identity)
*/
@@ -450,8 +359,10 @@ private void removeEmptyFilesOneDir(File dirFile) throws IOException {
String name = entry.getKey();
if (!treatAsNonEmpty.contains(name)) {
File file = entry.getValue();
- System.out.println(++counter + ") Deleting: " + file.getCanonicalPath());
- file.delete();
+ logger.log(Level.WARNING, ++counter + ") Deleting: " + file.getCanonicalPath());
+ if (file.exists() && !file.delete()) {
+ throw new InternalError("Unable to delete file: " + file);
+ }
}
}
}
@@ -473,7 +384,7 @@ private static void addNameAndParents(Set treatAsNonEmpty, String name)
/**
* Verify all VXML files
*
- * @param vxmlGenerator the VxmlGenerator, or null if using jsp
+ * @param vxmlGenerator the VxmlGenerator
* @param out the Writer, to receive HTML output
* The following need to be verified on the server when generating vxml: • The same file
* must not occur in both the common/X and seed/X directories, for any X=main|annotations •
@@ -511,21 +422,13 @@ private void verifyAllFiles(VxmlGenerator vxmlGenerator, Writer out, File vxmlDi
if (failureCount == 0) {
out.write("
✅ VXML verification succeeded
\nOK
");
- if (vxmlGenerator != null) {
- vxmlGenerator.setVerificationStatus(VxmlGenerator.VerificationStatus.SUCCESSFUL);
- } else {
- System.out.println("VXML verification succeeded");
- }
+ vxmlGenerator.setVerificationStatus(VxmlGenerator.VerificationStatus.SUCCESSFUL);
} else {
out.write(
"❌ VXML verification failed!
\nFailure count = "
+ failureCount
+ "
");
- if (vxmlGenerator != null) {
- vxmlGenerator.setVerificationStatus(VxmlGenerator.VerificationStatus.FAILED);
- } else {
- System.out.println("VXML verification failed! Failure count = " + failureCount);
- }
+ vxmlGenerator.setVerificationStatus(VxmlGenerator.VerificationStatus.FAILED);
}
}
@@ -544,7 +447,7 @@ private boolean verifyNoDuplicatesInCommonAndSeed(Writer out, File vxmlDir) thro
String seedDirName = vxmlDir + "/" + DirNames.justSeed + "/" + m;
File dirFile = new File(commonDirName);
if (dirFile.exists()) {
- for (File file : dirFile.listFiles(xmlFileFilter)) {
+ for (File file : Objects.requireNonNull(dirFile.listFiles(xmlFileFilter))) {
String commonName = file.getName();
String commonPathName = commonDirName + "/" + commonName;
String seedPathName = seedDirName + "/" + commonName;
@@ -585,7 +488,7 @@ private boolean verifyParentChildSameDirectory(Writer out, File vxmlDir) throws
if (!dirFile.exists()) {
continue;
}
- for (File file : dirFile.listFiles(xmlFileFilter)) {
+ for (File file : Objects.requireNonNull(dirFile.listFiles(xmlFileFilter))) {
String childName = file.getName();
String childPathName = dirName + "/" + childName;
/*
@@ -609,8 +512,7 @@ private boolean verifyParentChildSameDirectory(Writer out, File vxmlDir) throws
&& !"root.xml".equals(parentName)) {
String parentPathName = dirName + "/" + parentName;
File fParent = new File(parentPathName);
- if (!fParent.exists()
- && !otherParentExists(parentPathName, parentName, c)) {
+ if (!fParent.exists() && !otherParentExists(parentPathName, c)) {
out.write(
"Verification failure, child without parent
\n"
+ "Child, present: "
@@ -638,12 +540,10 @@ private boolean verifyParentChildSameDirectory(Writer out, File vxmlDir) throws
* .../seed/main/el.xml Other parent: .../common/main/el.xml
*
* @param parentPathName like ".../seed/main"
- * @param parentName like "el_POLYTON.xml"
* @param commonOrSeed where we already looked: "common" (give up) or "seed" (try "common")
* @return true if the other parent exists
*/
- private boolean otherParentExists(
- String parentPathName, String parentName, String commonOrSeed) {
+ private boolean otherParentExists(String parentPathName, String commonOrSeed) {
/*
* Allow "parent in common and child in seed" but not vice-versa
*/
@@ -681,12 +581,12 @@ private boolean verifyVxmlAndBaselineFilesCorrespond(Writer out, File vxmlDir)
File vxmlDirFile = new File(vxmlDir + "/" + c + "/" + m);
File bxmlDirFile = new File(bxmlDir + "/" + c + "/" + m);
if (vxmlDirFile.exists()) {
- for (File file : vxmlDirFile.listFiles(xmlFileFilter)) {
+ for (File file : Objects.requireNonNull(vxmlDirFile.listFiles(xmlFileFilter))) {
vxmlFiles.add(c + "/" + m + "/" + file.getName());
}
}
if (bxmlDirFile.exists()) {
- for (File file : bxmlDirFile.listFiles(xmlFileFilter)) {
+ for (File file : Objects.requireNonNull(bxmlDirFile.listFiles(xmlFileFilter))) {
bxmlFiles.add(c + "/" + m + "/" + file.getName());
}
}
@@ -750,8 +650,9 @@ private static Set symmetricDifference(
private static final Predicate isAnnotations = x -> x.startsWith("//ldml/annotations");
- private Map OPTS_SKIP_ANNOTATIONS = ImmutableMap.of("SKIP_PATH", isAnnotations);
- private Map OPTS_KEEP_ANNOTATIONS =
+ private final Map OPTS_SKIP_ANNOTATIONS =
+ ImmutableMap.of("SKIP_PATH", isAnnotations);
+ private final Map OPTS_KEEP_ANNOTATIONS =
ImmutableMap.of("SKIP_PATH", isAnnotations.negate());
/**
@@ -765,21 +666,22 @@ private static Set symmetricDifference(
private void doWriteFile(CLDRFile file, Kind kind, File outFile)
throws UnsupportedEncodingException, FileNotFoundException {
try (PrintWriter u8out =
- new PrintWriter(new OutputStreamWriter(new FileOutputStream(outFile), "UTF8"))) {
+ new PrintWriter(
+ new OutputStreamWriter(
+ new FileOutputStream(outFile), StandardCharsets.UTF_8))) {
if (kind == Kind.vxml || kind == Kind.rxml) {
file.write(u8out, OPTS_SKIP_ANNOTATIONS);
// output annotations, too
- File parentDir = outFile.getParentFile().getParentFile();
- File annotationsDir = new File(parentDir, DirNames.justAnnotations);
- annotationsDir.mkdirs();
- File aFile =
- new File(annotationsDir, outFile.getName()); // same name, different subdir
+ File aFile = makeAnnotationFile(outFile); // same name, different subdir
try (PrintWriter u8outa =
new PrintWriter(
- new OutputStreamWriter(new FileOutputStream(aFile), "UTF8"))) {
+ new OutputStreamWriter(
+ new FileOutputStream(aFile), StandardCharsets.UTF_8))) {
if (!file.write(u8outa, OPTS_KEEP_ANNOTATIONS)) {
- aFile.delete();
+ if (aFile.exists() && !aFile.delete()) {
+ throw new InternalError("Unable to delete aFile: " + aFile);
+ }
}
}
} else {
@@ -788,6 +690,15 @@ private void doWriteFile(CLDRFile file, Kind kind, File outFile)
}
}
+ private static File makeAnnotationFile(File outFile) {
+ File parentDir = outFile.getParentFile().getParentFile();
+ File annotationsDir = new File(parentDir, DirNames.justAnnotations);
+ if (!annotationsDir.exists() && !annotationsDir.mkdirs()) {
+ throw new InternalError("Unable to create directory: " + annotationsDir);
+ }
+ return new File(annotationsDir, outFile.getName());
+ }
+
/**
* For a request like ".../cldr-apps/survey/vxml/main/aa.xml", respond with the xml
*
@@ -813,136 +724,125 @@ public boolean doRawXml(HttpServletRequest request, HttpServletResponse response
|| s.startsWith(TXML_PREFIX))) {
return false;
}
- CLDRProgressTask p = sm.openProgress("Raw XML");
- try {
-
- boolean finalData = false;
- String kind = null;
+ boolean finalData = false;
+ String kind = null;
- if (s.startsWith(VXML_PREFIX)) {
- finalData = true;
- if (s.equals(VXML_PREFIX)) {
- WebContext ctx = new WebContext(request, response);
- response.sendRedirect(ctx.schemeHostPort() + ctx.base() + VXML_PREFIX + "/");
- return true;
- }
- kind = "vxml";
- s = s.substring(VXML_PREFIX.length() + 1, s.length()); // "foo.xml"
- } else if (s.startsWith(PXML_PREFIX)) {
- finalData = true;
- if (s.equals(PXML_PREFIX)) {
- return true;
- }
- kind = "pxml";
- s = s.substring(PXML_PREFIX.length() + 1, s.length()); // "foo.xml"
- } else if (s.startsWith(RXML_PREFIX)) {
- finalData = true;
- if (s.equals(RXML_PREFIX)) {
- WebContext ctx = new WebContext(request, response);
- response.sendRedirect(ctx.schemeHostPort() + ctx.base() + RXML_PREFIX + "/");
- return true;
- }
- kind = "rxml"; // cached
- s = s.substring(RXML_PREFIX.length() + 1, s.length()); // "foo.xml"
- } else if (s.startsWith(TXML_PREFIX)) {
- finalData = true;
- if (s.equals(TXML_PREFIX)) {
- WebContext ctx = new WebContext(request, response);
- response.sendRedirect(ctx.schemeHostPort() + ctx.base() + TXML_PREFIX + "/");
- return true;
- }
- s = s.substring(TXML_PREFIX.length() + 1, s.length()); // "foo.xml"
- } else if (s.startsWith(ZXML_PREFIX)) {
- finalData = false;
- s = s.substring(ZXML_PREFIX.length() + 1, s.length()); // "foo.xml"
- } else if (s.startsWith(ZVXML_PREFIX)) {
- finalData = true;
- s = s.substring(ZVXML_PREFIX.length() + 1, s.length()); // "foo.xml"
- } else {
- if (s.equals(XML_PREFIX)) {
- WebContext ctx = new WebContext(request, response);
- response.sendRedirect(ctx.schemeHostPort() + ctx.base() + XML_PREFIX + "/");
- return true;
- }
- kind = "xml";
- s = s.substring(XML_PREFIX.length() + 1, s.length()); // "foo.xml"
+ if (s.startsWith(VXML_PREFIX)) {
+ finalData = true;
+ if (s.equals(VXML_PREFIX)) {
+ WebContext ctx = new WebContext(request, response);
+ response.sendRedirect(ctx.schemeHostPort() + ctx.base() + VXML_PREFIX + "/");
+ return true;
}
-
- if (s.length() == 0) {
+ kind = "vxml";
+ s = s.substring(VXML_PREFIX.length() + 1); // "foo.xml"
+ } else if (s.startsWith(PXML_PREFIX)) {
+ finalData = true;
+ if (s.equals(PXML_PREFIX)) {
+ return true;
+ }
+ kind = "pxml";
+ s = s.substring(PXML_PREFIX.length() + 1); // "foo.xml"
+ } else if (s.startsWith(RXML_PREFIX)) {
+ finalData = true;
+ if (s.equals(RXML_PREFIX)) {
WebContext ctx = new WebContext(request, response);
- response.setContentType("text/html; charset=utf-8");
- if (finalData) {
- ctx.println("CLDR Data | All Locales - Vetted Data");
- } else {
- ctx.println("CLDR Data | All Locales");
- }
- ctx.println("Return to SurveyTool");
- ctx.println("
Locales
");
- ctx.println("");
- CLDRLocale[] locales = SurveyMain.getLocales();
- int nrInFiles = locales.length;
- for (int i = 0; i < nrInFiles; i++) {
- CLDRLocale locale = locales[i];
- String localeName = locale.getBaseName();
- String fileName = localeName + XML_SUFFIX;
- ctx.println(
- "- "
- + fileName
- + " "
- + locale.getDisplayName(ctx.displayLocale)
- + "
");
- }
- ctx.println("
");
- ctx.println("
");
- ctx.println("Return to SurveyTool");
- ctx.close();
- } else if (!s.endsWith(XML_SUFFIX)) {
+ response.sendRedirect(ctx.schemeHostPort() + ctx.base() + RXML_PREFIX + "/");
+ return true;
+ }
+ kind = "rxml"; // cached
+ s = s.substring(RXML_PREFIX.length() + 1); // "foo.xml"
+ } else if (s.startsWith(TXML_PREFIX)) {
+ finalData = true;
+ if (s.equals(TXML_PREFIX)) {
+ WebContext ctx = new WebContext(request, response);
+ response.sendRedirect(ctx.schemeHostPort() + ctx.base() + TXML_PREFIX + "/");
+ return true;
+ }
+ s = s.substring(TXML_PREFIX.length() + 1); // "foo.xml"
+ } else if (s.startsWith(ZXML_PREFIX)) {
+ s = s.substring(ZXML_PREFIX.length() + 1); // "foo.xml"
+ } else if (s.startsWith(ZVXML_PREFIX)) {
+ finalData = true;
+ s = s.substring(ZVXML_PREFIX.length() + 1); // "foo.xml"
+ } else {
+ if (s.equals(XML_PREFIX)) {
WebContext ctx = new WebContext(request, response);
response.sendRedirect(ctx.schemeHostPort() + ctx.base() + XML_PREFIX + "/");
+ return true;
+ }
+ kind = "xml";
+ s = s.substring(XML_PREFIX.length() + 1); // "foo.xml"
+ }
+
+ if (s.isEmpty()) {
+ WebContext ctx = new WebContext(request, response);
+ response.setContentType("text/html; charset=utf-8");
+ if (finalData) {
+ ctx.println("
CLDR Data | All Locales - Vetted Data");
} else {
- boolean found = false;
- CLDRLocale[] locales = SurveyMain.getLocales();
- CLDRLocale foundLocale = null;
- int nrInFiles = locales.length;
- for (int i = 0; (!found) && (i < nrInFiles); i++) {
- CLDRLocale locale = locales[i];
- String localeName = locale.getBaseName();
- String fileName = localeName + XML_SUFFIX;
- if (s.equals(fileName)) {
- found = true;
- foundLocale = locale;
- }
+ ctx.println("CLDR Data | All Locales");
+ }
+ ctx.println("Return to SurveyTool");
+ ctx.println("
Locales
");
+ ctx.println("");
+ CLDRLocale[] locales = SurveyMain.getLocales();
+ for (CLDRLocale locale : locales) {
+ String localeName = locale.getBaseName();
+ String fileName = localeName + XML_SUFFIX;
+ ctx.println(
+ "- "
+ + fileName
+ + " "
+ + locale.getDisplayName(ctx.displayLocale)
+ + "
");
+ }
+ ctx.println("
");
+ ctx.println("
");
+ ctx.println("Return to SurveyTool");
+ ctx.close();
+ } else if (!s.endsWith(XML_SUFFIX)) {
+ WebContext ctx = new WebContext(request, response);
+ response.sendRedirect(ctx.schemeHostPort() + ctx.base() + XML_PREFIX + "/");
+ } else {
+ boolean found = false;
+ CLDRLocale[] locales = SurveyMain.getLocales();
+ CLDRLocale foundLocale = null;
+ int nrInFiles = locales.length;
+ for (int i = 0; (!found) && (i < nrInFiles); i++) {
+ CLDRLocale locale = locales[i];
+ String localeName = locale.getBaseName();
+ String fileName = localeName + XML_SUFFIX;
+ if (s.equals(fileName)) {
+ found = true;
+ foundLocale = locale;
}
- if (!found) {
- throw new InternalError("No such locale: " + s);
- } else {
- String doKvp = request.getParameter("kvp");
- boolean isKvp = (doKvp != null && doKvp.length() > 0);
+ }
+ if (!found) {
+ throw new InternalError("No such locale: " + s);
+ } else {
+ String doKvp = request.getParameter("kvp");
+ boolean isKvp = (doKvp != null && !doKvp.isEmpty());
- if (isKvp) {
- response.setContentType("text/plain; charset=utf-8");
- } else {
- response.setContentType("application/xml; charset=utf-8");
- }
+ if (isKvp) {
+ response.setContentType("text/plain; charset=utf-8");
+ } else {
+ response.setContentType("application/xml; charset=utf-8");
+ }
- if (kind.equals("vxml")) {
- sm.getSTFactory()
- .make(foundLocale.getBaseName(), false)
- .write(response.getWriter());
- return true;
- } else if (kind.equals("pxml")) {
- sm.getSTFactory().makeProposedFile(foundLocale).write(response.getWriter());
- return true;
- }
+ if (kind.equals("vxml")) {
+ sm.getSTFactory()
+ .make(foundLocale.getBaseName(), false)
+ .write(response.getWriter());
+ return true;
+ } else if (kind.equals("pxml")) {
+ sm.getSTFactory().makeProposedFile(foundLocale).write(response.getWriter());
+ return true;
}
}
- return true;
- } finally {
- if (p != null) {
- p.close();
- }
}
+ return true;
}
}
diff --git a/tools/cldr-apps/src/main/java/org/unicode/cldr/web/VxmlGenerator.java b/tools/cldr-apps/src/main/java/org/unicode/cldr/web/VxmlGenerator.java
index fb92838ad16..ede57368c03 100644
--- a/tools/cldr-apps/src/main/java/org/unicode/cldr/web/VxmlGenerator.java
+++ b/tools/cldr-apps/src/main/java/org/unicode/cldr/web/VxmlGenerator.java
@@ -9,13 +9,7 @@ public class VxmlGenerator {
public void generate(Set sortSet, Writer out) throws ExecutionException {
this.sortSet = sortSet;
try {
- // TODO: get the booleans somewhere, or remove the parameters
- // -- in practice, we want them all true
- // Reference: https://unicode-org.atlassian.net/browse/CLDR-14913
- OutputFileManager.generateVxml(
- this, out, true, // outputFiles
- true, // removeEmpty
- true); // verifyConsistent
+ OutputFileManager.generateVxml(this, out);
} catch (Exception e) {
throw new ExecutionException(e);
}
diff --git a/tools/cldr-apps/src/main/java/org/unicode/cldr/web/VxmlQueue.java b/tools/cldr-apps/src/main/java/org/unicode/cldr/web/VxmlQueue.java
index d0bf7f56715..e947da456db 100644
--- a/tools/cldr-apps/src/main/java/org/unicode/cldr/web/VxmlQueue.java
+++ b/tools/cldr-apps/src/main/java/org/unicode/cldr/web/VxmlQueue.java
@@ -224,8 +224,15 @@ public synchronized String getOutput(Args args, Results results) throws IOExcept
results.status = Status.STOPPED;
return VXML_MESSAGE_STOPPED_ON_REQUEST;
} else if (entry.done) {
- setPercent(100);
- results.status = Status.READY;
+ if (entry.verificationStatus == VxmlGenerator.VerificationStatus.SUCCESSFUL) {
+ results.status = Status.READY;
+ setPercent(100);
+ } else {
+ results.status = Status.STOPPED;
+ if (getPercent() > 99) {
+ setPercent(99);
+ }
+ }
stop(entry);
return entry.verificationStatus.toString();
}
diff --git a/tools/cldr-apps/src/main/webapp/admin-OutputAllFiles.jsp b/tools/cldr-apps/src/main/webapp/admin-OutputAllFiles.jsp
deleted file mode 100644
index 62c6a98b2c3..00000000000
--- a/tools/cldr-apps/src/main/webapp/admin-OutputAllFiles.jsp
+++ /dev/null
@@ -1,20 +0,0 @@
-<%@page import="com.ibm.icu.dev.util.ElapsedTimer"%>
-<%@page import="org.unicode.cldr.web.*"%>
-<%@page import="org.unicode.cldr.util.*,java.util.*"%>
-<%@page import="java.io.*"%>
-<%@page import="java.sql.*"%>
-<%@page import="org.unicode.cldr.test.*"%>
-<%@ page language="java" contentType="text/html; charset=UTF-8"
- pageEncoding="UTF-8"%>
-
-
-
-
-Update All Files
-
-
-<%
- OutputFileManager.outputAndVerifyAllFiles(request, out);
-%>
-
-