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("

  1. " + 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("
  2. \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); -%> - -