X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=src%2Forg%2Fcacert%2Fgigi%2Foutput%2Ftemplate%2FSprintfCommand.java;h=47389643995640afa854a63469abfc345b45bbf9;hb=b207e1989b166619e924946731e40ccf98457fae;hp=24608d2ec030ea671b5d7b69281e2d6107b08470;hpb=ffab4ac1fae1a58919c7dde59d90c75df096512c;p=gigi.git diff --git a/src/org/cacert/gigi/output/template/SprintfCommand.java b/src/org/cacert/gigi/output/template/SprintfCommand.java index 24608d2e..47389643 100644 --- a/src/org/cacert/gigi/output/template/SprintfCommand.java +++ b/src/org/cacert/gigi/output/template/SprintfCommand.java @@ -2,28 +2,75 @@ package org.cacert.gigi.output.template; import java.io.PrintWriter; import java.util.LinkedList; +import java.util.List; import java.util.Map; +import java.util.regex.Matcher; +import java.util.regex.Pattern; -import org.cacert.gigi.Language; -import org.cacert.gigi.output.Outputable; - -final class SprintfCommand implements Outputable { - private final String text; - private final LinkedList store; - - SprintfCommand(String text, LinkedList store) { - this.text = text; - this.store = store; - } - - @Override - public void output(PrintWriter out, Language l, Map vars) { - String[] parts = l.getTranslation(text).split("%s"); - String[] myvars = store.toArray(new String[store.size()]); - out.print(parts[0]); - for (int j = 1; j < parts.length; j++) { - Template.outputVar(out, l, vars, myvars[j - 1].substring(1)); - out.print(parts[j]); - } - } -} \ No newline at end of file +import org.cacert.gigi.localisation.Language; +import org.cacert.gigi.util.HTMLEncoder; + +public final class SprintfCommand implements Outputable { + + private final String text; + + private final String[] store; + + public SprintfCommand(String text, List store) { + this.text = text; + this.store = store.toArray(new String[store.size()]); + } + + private static final String VARIABLE = "\\$!?\\{[a-zA-Z0-9_-]+\\}"; + + private static final Pattern processingInstruction = Pattern.compile("(" + VARIABLE + ")|(!'[^{}'\\$]*)'"); + + public SprintfCommand(String content) { + StringBuffer raw = new StringBuffer(); + List var = new LinkedList(); + int counter = 0; + Matcher m = processingInstruction.matcher(content); + int last = 0; + while (m.find()) { + raw.append(content.substring(last, m.start())); + String group = null; + if ((group = m.group(1)) != null) { + var.add(group); + } else if ((group = m.group(2)) != null) { + var.add(group); + } else { + throw new Error("Regex is broken??"); + } + last = m.end(); + raw.append("{" + (counter++) + "}"); + } + raw.append(content.substring(last)); + text = raw.toString(); + store = var.toArray(new String[var.size()]); + } + + private final Pattern replacant = Pattern.compile("\\{([0-9]+)\\}"); + + @Override + public void output(PrintWriter out, Language l, Map vars) { + String parts = l.getTranslation(text); + Matcher m = replacant.matcher(parts); + int pos = 0; + while (m.find()) { + out.print(HTMLEncoder.encodeHTML(parts.substring(pos, m.start()))); + String var = store[Integer.parseInt(m.group(1))]; + if (var.startsWith("$!")) { + Template.outputVar(out, l, vars, var.substring(3, var.length() - 1), true); + } else if (var.startsWith("!'")) { + out.print(var.substring(2)); + } else if (var.startsWith("$")) { + Template.outputVar(out, l, vars, var.substring(2, var.length() - 1), false); + } else { + throw new Error("Processing error in template."); + } + pos = m.end(); + + } + out.print(HTMLEncoder.encodeHTML(parts.substring(pos))); + } +}