]> WPIA git - gigi.git/blobdiff - src/org/cacert/gigi/Language.java
HTMLEncode all language text before outputting it.
[gigi.git] / src / org / cacert / gigi / Language.java
index 431f0b32a41989fa2ff87a4e45aae4eec47e218f..75593ccf723618a47598b084611d971c987c809e 100644 (file)
@@ -4,11 +4,13 @@ import java.io.File;
 import java.io.FileInputStream;
 import java.io.IOException;
 import java.util.HashMap;
+import java.util.Locale;
 
 import javax.xml.parsers.DocumentBuilder;
 import javax.xml.parsers.DocumentBuilderFactory;
 import javax.xml.parsers.ParserConfigurationException;
 
+import org.cacert.gigi.util.HTMLEncoder;
 import org.w3c.dom.Document;
 import org.w3c.dom.Element;
 import org.w3c.dom.NodeList;
@@ -17,12 +19,19 @@ import org.xml.sax.SAXException;
 public class Language {
        private static HashMap<String, Language> langs = new HashMap<String, Language>();
        HashMap<String, String> translations = new HashMap<String, String>();
-       private Language(String language) throws ParserConfigurationException,
-                       IOException, SAXException {
+       Locale l;
+
+       private Language(String language) throws ParserConfigurationException, IOException, SAXException {
+               if (language.contains("_")) {
+                       String[] parts = language.split("_");
+                       l = new Locale(parts[0], parts[1]);
+               } else {
+                       l = new Locale(language);
+               }
+
                DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
                DocumentBuilder db = dbf.newDocumentBuilder();
-               Document d = db.parse(new FileInputStream(new File("locale", language
-                               + ".xml")));
+               Document d = db.parse(new FileInputStream(new File("locale", language + ".xml")));
                NodeList nl = d.getDocumentElement().getChildNodes();
                for (int i = 0; i < nl.getLength(); i++) {
                        if (!(nl.item(i) instanceof Element)) {
@@ -31,10 +40,19 @@ public class Language {
                        Element e = (Element) nl.item(i);
                        Element id = (Element) e.getElementsByTagName("id").item(0);
                        Element msg = (Element) e.getElementsByTagName("msg").item(0);
-                       translations.put(id.getTextContent(), msg.getTextContent());
+                       translations.put(id.getTextContent(), HTMLEncoder.encodeHTML(msg.getTextContent()));
                }
                System.out.println(translations.size() + " strings loaded.");
        }
+
+       public String getTranslation(String text) {
+               String string = translations.get(text);
+               if (string == null || string.equals("")) {
+                       return text;
+               }
+               return string;
+       }
+
        public static Language getInstance(String language) {
                Language l = langs.get(language);
                if (l == null) {
@@ -51,7 +69,9 @@ public class Language {
                }
                return l;
        }
-       public static void main(String[] args) {
-               Language.getInstance("de");
+
+       public Locale getLocale() {
+               return l;
        }
+
 }