X-Git-Url: https://code.wpia.club/?p=gigi.git;a=blobdiff_plain;f=src%2Forg%2Fcacert%2Fgigi%2FGigiApiException.java;h=7b3a990938ad0df650ec2b9c5079124f6d7286ee;hp=944fe645ece5618fb2dc93afc5318d164be6c84b;hb=a4a022f3ef3f697298fca60520d422d8662ec706;hpb=ec24cf6925bb3729a644580ad4a9375d05883c62 diff --git a/src/org/cacert/gigi/GigiApiException.java b/src/org/cacert/gigi/GigiApiException.java index 944fe645..7b3a9909 100644 --- a/src/org/cacert/gigi/GigiApiException.java +++ b/src/org/cacert/gigi/GigiApiException.java @@ -13,6 +13,8 @@ import org.cacert.gigi.output.template.TranslateCommand; public class GigiApiException extends Exception { + private static final Language PLAIN_LANGUAGE = Language.getInstance(Locale.ENGLISH); + private static final long serialVersionUID = -164928670180852588L; private SQLException e; @@ -49,25 +51,43 @@ public class GigiApiException extends Exception { } public void format(PrintWriter out, Language language) { - out.println("
"); + out.println("
"); if (isInternalError()) { e.printStackTrace(); - out.print("
"); - out.println(language.getTranslation("An internal error ouccured.")); - out.println("
"); + out.print("

"); + out.println(language.getTranslation("An internal error occurred.")); + out.println("

"); } HashMap map = new HashMap<>(); for (Outputable message : messages) { map.clear(); - out.print("
"); + out.print("

"); message.output(out, language, map); - out.println("

"); + out.println("

"); } out.println("
"); } + public void formatPlain(PrintWriter out) { + if (isInternalError()) { + out.println(PLAIN_LANGUAGE.getTranslation("An internal error occurred.")); + } + HashMap map = new HashMap<>(); + for (Outputable message : messages) { + if (message instanceof TranslateCommand) { + String m = ((TranslateCommand) message).getRaw(); + // Skip HTML Entities + out.println(PLAIN_LANGUAGE.getTranslation(m)); + } else { + map.clear(); + message.output(out, PLAIN_LANGUAGE, map); + out.println(); + } + } + } + public boolean isEmpty() { return e == null && messages.size() == 0; } @@ -81,7 +101,7 @@ public class GigiApiException extends Exception { HashMap map = new HashMap<>(); for (Outputable message : messages) { map.clear(); - message.output(pw, Language.getInstance(Locale.ENGLISH), map); + message.output(pw, PLAIN_LANGUAGE, map); } pw.flush();