changeset 1100:7683c4162746

Updated importer. * Fixed in grammar * More reporting * Fixed unit test
author Raimund Renkert <raimund.renkert@intevation.de>
date Mon, 24 Oct 2016 11:52:17 +0200 (2016-10-24)
parents 46df70a27767
children 2593ba20487e
files src/main/antlr4/de/intevation/lada/importer/laf/Laf.g4 src/main/java/de/intevation/lada/importer/laf/LafImporter.java src/main/java/de/intevation/lada/importer/laf/LafObjectListener.java src/main/java/de/intevation/lada/importer/laf/LafObjectMapper.java src/main/java/de/intevation/lada/importer/laf/LafParser.java src/main/java/de/intevation/lada/importer/laf/LafRawData.java src/main/java/de/intevation/lada/rest/importer/LafImportService.java src/main/java/de/intevation/lada/util/data/DataTransaction.java src/test/java/de/intevation/lada/ImporterTest.java
diffstat 9 files changed, 2444 insertions(+), 1249 deletions(-) [+]
line wrap: on
line diff
--- a/src/main/antlr4/de/intevation/lada/importer/laf/Laf.g4	Mon Oct 24 11:47:55 2016 +0200
+++ b/src/main/antlr4/de/intevation/lada/importer/laf/Laf.g4	Mon Oct 24 11:52:17 2016 +0200
@@ -32,6 +32,7 @@
   | testdaten
   | szenario
   | sek_datenbasis
+  | sek_datenbasis_s
   | us
   | ph
   | pg
@@ -65,7 +66,7 @@
   | bearbeitungsstatus
   | pep_flag
   | erfassung_abgeschlossen
-  | messwert
+  | mw
   | mess_kommentar
 ;
 
@@ -222,7 +223,7 @@
 u_koordinaten_s : U_KOORDINATEN_S STRING (' ')* (STRING_ESC | STRING) (' ')* (STRING_ESC | STRING) ; // SI2 C22 C22
 u_orts_zusatzcode : U_ORTS_ZUSATZCODE (STRING_ESC | STRING) ; // C8
 u_orts_zusatztext : U_ORTS_ZUSATZTEXT (STRING_ESC | STRING) ; // MC50
-u_nuts_code : U_NUTS_CODE STRING ; // I10
+u_nuts_code : U_NUTS_CODE (STRING_ESC | STRING) ; // C10
 p_herkunftsland_lang : P_HERKUNFTSLAND_LANG (STRING_ESC | STRING) ; //C50*
 p_herkunftsland_kurz : P_HERKUNFTSLAND_KURZ (STRING_ESC | STRING) ; // C5
 p_herkunftsland_s : P_HERKUNFTSLAND_S STRING ; // SI8
@@ -233,7 +234,7 @@
 p_koordinaten_s : P_KOORDINATEN_S STRING (' ')* (STRING_ESC | STRING) (' ')* (STRING_ESC | STRING) ; // SI2 C22 C22
 p_orts_zusatzcode : P_ORTS_ZUSATZCODE (STRING_ESC | STRING) ; // C8
 p_orts_zusatztext : P_ORTS_ZUSATZTEXT (STRING_ESC | STRING) ; // MC50
-p_nuts_code : P_NUTS_CODE STRING ; // I10
+p_nuts_code : P_NUTS_CODE (STRING_ESC | STRING) ; // C10
 p_site_id : P_SITE_ID (STRING_ESC | STRING) ; // C8
 p_site_name : P_SITE_NAME (STRING_ESC | STRING) ; // C50*
 p_hoehe_nn : P_HOEHE_NN STRING ; // F10
--- a/src/main/java/de/intevation/lada/importer/laf/LafImporter.java	Mon Oct 24 11:47:55 2016 +0200
+++ b/src/main/java/de/intevation/lada/importer/laf/LafImporter.java	Mon Oct 24 11:52:17 2016 +0200
@@ -4,9 +4,11 @@
 import java.io.IOException;
 import java.io.InputStream;
 import java.nio.charset.StandardCharsets;
+import java.util.ArrayList;
 import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
+import java.util.Map.Entry;
 
 import javax.inject.Inject;
 
@@ -50,10 +52,34 @@
             LafObjectListener listener = new LafObjectListener();
             ParseTreeWalker walker = new ParseTreeWalker();
             walker.walk(listener, tree);
-            logger.debug("Parsed Proben: " + listener.getData().count());
-            errors.put("parser", errorListener.getErrors());
+            if (!listener.hasUebertragungsformat() ||
+                !listener.hasVersion()) {
+                List<ReportItem> items = new ArrayList<ReportItem>();
+                items.add(new ReportItem("missing header", "format", 673));
+                errors.put("parser", items);
+                return;
+            }
+            if (!errorListener.getErrors().isEmpty()) {
+                errors.put("parser", errorListener.getErrors());
+            }
             errors.putAll(listener.getErrors());
+            mapper.setUserInfo(userInfo);
             mapper.mapObjects(listener.getData());
+            logger.debug("listener errors: " + listener.getErrors().size());
+            logger.debug("import mapper errors: " + mapper.getErrors().size());
+            for (Entry<String, List<ReportItem>> entry : mapper.getErrors().entrySet()) {
+                logger.debug("add for key: "+ entry.getKey());
+                if (errors.containsKey(entry.getKey())) {
+                    errors.get(entry.getKey()).addAll(entry.getValue());
+                    logger.debug("done");
+                }
+                else {
+                    errors.put(entry.getKey(), entry.getValue());
+                    logger.debug("done2");
+                }
+            }
+            warnings.putAll(mapper.getWarnings());
+            logger.debug("import warnings: " + warnings.size());
         } catch (IOException e) {
             // TODO Auto-generated catch block
             e.printStackTrace();
@@ -66,12 +92,12 @@
     }
 
     @Override
-    public Map<String, List<ReportItem>> getWarnings() {
+    public Map<String, List<ReportItem>> getErrors() {
         return this.errors;
     }
 
     @Override
-    public Map<String, List<ReportItem>> getErrors() {
+    public Map<String, List<ReportItem>> getWarnings() {
         return this.warnings;
     }
 }
--- a/src/main/java/de/intevation/lada/importer/laf/LafObjectListener.java	Mon Oct 24 11:47:55 2016 +0200
+++ b/src/main/java/de/intevation/lada/importer/laf/LafObjectListener.java	Mon Oct 24 11:52:17 2016 +0200
@@ -19,6 +19,14 @@
     Map<String, List<ReportItem>> errors;
     List<ReportItem> currentErrors;
 
+    private boolean hasDatenbasis = false;
+    private boolean hasMessprogramm = false;
+    private boolean hasUmwelt = false;
+    private boolean hasZeitbasis = false;
+    private boolean hasUebertragungsformat = false;
+    private boolean hasVersion = false;
+
+
     public LafObjectListener() {
         data = new LafRawData();
         errors = new HashMap<String, List<ReportItem>>();
@@ -37,12 +45,26 @@
     }
 
     /**
+     * @return the hasUebertragungsformat
+     */
+    public boolean hasUebertragungsformat() {
+        return hasUebertragungsformat;
+    }
+
+    /**
+     * @return the hasVersion
+     */
+    public boolean hasVersion() {
+        return hasVersion;
+    }
+
+    /**
      * {@inheritDoc}
      *
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterProbendatei(LafParser.ProbendateiContext ctx) {
-        System.out.println("entering probe-datei");
+        System.out.println("start building raw data");
     }
 
     /**
@@ -51,6 +73,8 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void exitProbendatei(LafParser.ProbendateiContext ctx) {
+        System.out.println("finished.");
+        System.out.println("build " + data.count() + " proben.");
     }
 
     /**
@@ -61,12 +85,19 @@
     @Override public void enterEnd(LafParser.EndContext ctx) {
         if (currentProbe != null) {
             data.addProbe(currentProbe);
-            String identifier = currentProbe.getAttributes().get("PROBE_ID");
-            identifier = identifier == null ? currentProbe.getAttributes().get("PROBEN_NR") : null;
-            identifier = identifier == null ? currentProbe.getAttributes().get("HAUPTPROBEN_NR") : "not identified";
-            errors.put(identifier, currentErrors);
+            if (!currentErrors.isEmpty()) {
+                String identifier = currentProbe.getAttributes().get("PROBE_ID");
+                identifier = identifier == null ? currentProbe.getAttributes().get("PROBEN_NR") : null;
+                identifier = identifier == null ? currentProbe.getAttributes().get("HAUPTPROBEN_NR") : "not identified";
+                System.out.println("exit: " + identifier);
+                errors.put(identifier, currentErrors);
+            }
             currentErrors.clear();
             currentProbe = null;
+            hasDatenbasis = false;
+            hasMessprogramm = false;
+            hasUmwelt = false;
+            hasZeitbasis = false;
         }
     }
 
@@ -90,12 +121,23 @@
      */
     @Override public void exitProbe(LafParser.ProbeContext ctx) {
         data.addProbe(currentProbe);
-        String identifier = currentProbe.getAttributes().get("PROBE_ID");
-        identifier = identifier == null ? currentProbe.getAttributes().get("PROBEN_NR") : null;
-        identifier = identifier == null ? currentProbe.getAttributes().get("HAUPTPROBEN_NR") : "not identified";
-        errors.put(identifier, currentErrors);
+        if (!currentErrors.isEmpty()) {
+            for (ReportItem item : currentErrors) {
+                System.out.println("item: " + item.getKey());
+            }
+            String identifier = currentProbe.getAttributes().get("PROBE_ID");
+            identifier = identifier == null ? currentProbe.getAttributes().get("PROBEN_NR") : null;
+            identifier = identifier == null ? currentProbe.getAttributes().get("HAUPTPROBEN_NR") : null;
+            identifier = identifier == null ? "not identified" : identifier;
+            System.out.println("exit probe: " + identifier);
+            errors.put(identifier, currentErrors);
+        }
         currentErrors.clear();
         currentProbe = null;
+        hasDatenbasis = false;
+        hasMessprogramm = false;
+        hasUmwelt = false;
+        hasZeitbasis = false;
     }
 
     /**
@@ -286,7 +328,7 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterUebertragungsformat(LafParser.UebertragungsformatContext ctx) {
-        System.out.println(ctx.getChild(0) + ": " + ctx.getChild(1));
+        hasUebertragungsformat = true;
     }
 
     /**
@@ -295,7 +337,7 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterVersion(LafParser.VersionContext ctx) {
-        System.out.println(ctx.getChild(0) + ": " + ctx.getChild(1));
+        hasVersion = true;
     }
 
     /**
@@ -304,6 +346,9 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterDatenbasis(LafParser.DatenbasisContext ctx) {
+        if (this.hasDatenbasis) {
+            return;
+        }
         String value = ctx.getChild(1).toString();
         // Trim double qoutes.
         value = value.replaceAll("\"", "");
@@ -316,7 +361,7 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
+        this.hasDatenbasis = true;
     }
 
     /**
@@ -325,6 +370,9 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterDatenbasis_s(LafParser.Datenbasis_sContext ctx) {
+        if (this.hasDatenbasis) {
+            return;
+        }
         String value = ctx.getChild(1).toString();
         value = value.replaceAll("\"", "");
         if (!value.matches(LafDataTypes.SI2)) {
@@ -336,7 +384,7 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
+        this.hasDatenbasis = true;
     }
 
     /**
@@ -356,7 +404,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -376,7 +423,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -396,7 +442,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -416,7 +461,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -436,7 +480,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -456,7 +499,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -476,7 +518,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -496,7 +537,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -519,7 +559,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -539,7 +578,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -559,7 +597,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -582,7 +619,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -591,6 +627,9 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterMessprogramm_c(LafParser.Messprogramm_cContext ctx) {
+        if (this.hasMessprogramm) {
+            return;
+        }
         String value = ctx.getChild(1).toString();
         value = value.replaceAll("\"", "");
         if (!value.matches(LafDataTypes.C_STAR)) {
@@ -602,7 +641,7 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
+        this.hasMessprogramm = true;
     }
 
     /**
@@ -611,6 +650,9 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterMessprogramm_s(LafParser.Messprogramm_sContext ctx) {
+        if (this.hasMessprogramm) {
+            return;
+        }
         String value = ctx.getChild(1).toString();
         value = value.replaceAll("\"", "");
         if (!value.matches(LafDataTypes.SC1)) {
@@ -622,7 +664,7 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
+        this.hasMessprogramm = true;
     }
 
     /**
@@ -642,7 +684,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -662,7 +703,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -682,7 +722,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -691,6 +730,9 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterZeitbasis(LafParser.ZeitbasisContext ctx) {
+        if (this.hasZeitbasis) {
+            return;
+        }
         String value = ctx.getChild(1).toString();
         value = value.replaceAll("\"", "");
         if (!value.matches(LafDataTypes.C_STAR)) {
@@ -702,7 +744,7 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
+        this.hasZeitbasis = true;
     }
 
     /**
@@ -711,6 +753,9 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterZeitbasis_s(LafParser.Zeitbasis_sContext ctx) {
+        if (this.hasZeitbasis) {
+            return;
+        }
         String value = ctx.getChild(1).toString();
         value = value.replaceAll("\"", "");
         if (!value.matches(LafDataTypes.SI1)) {
@@ -722,7 +767,7 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
+        this.hasZeitbasis = true;
     }
 
     /**
@@ -752,7 +797,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), date + ' ' + time);
-        System.out.println(ctx.getChild(0) + ": " + date + ' ' + time);
     }
 
     /**
@@ -782,7 +826,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), date + ' ' + time);
-        System.out.println(ctx.getChild(0) + ": " + date + ' ' + time);
     }
 
     /**
@@ -812,7 +855,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), date + ' ' + time);
-        System.out.println(ctx.getChild(0) + ": " + date + ' ' + time);
     }
 
     /**
@@ -842,7 +884,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), date + ' ' + time);
-        System.out.println(ctx.getChild(0) + ": " + date + ' ' + time);
     }
 
     /**
@@ -872,7 +913,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), date + ' ' + time);
-        System.out.println(ctx.getChild(0) + ": " + date + ' ' + time);
     }
 
     /**
@@ -881,6 +921,9 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterUmweltbereich_c(LafParser.Umweltbereich_cContext ctx) {
+        if (this.hasUmwelt) {
+            return;
+        }
         String value = ctx.getChild(1).toString();
         value = value.replaceAll("\"", "");
         if (!value.matches(LafDataTypes.C_STAR)) {
@@ -892,7 +935,7 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
+        this.hasUmwelt = true;
     }
 
     /**
@@ -901,6 +944,9 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterUmweltbereich_s(LafParser.Umweltbereich_sContext ctx) {
+        if (this.hasUmwelt) {
+            return;
+        }
         String value = ctx.getChild(1).toString();
         value = value.replaceAll("\"", "");
         if (!value.matches(LafDataTypes.SC3)) {
@@ -912,7 +958,7 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
+        this.hasUmwelt = true;
     }
 
     /**
@@ -932,7 +978,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -952,7 +997,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -972,7 +1016,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1002,7 +1045,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), date + ' ' + time);
-        System.out.println(ctx.getChild(0) + ": " + date + ' ' + time);
     }
 
     /**
@@ -1022,7 +1064,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1042,7 +1083,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1062,7 +1102,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1082,7 +1121,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1103,7 +1141,6 @@
         }
         // TODO: Add to "ursprungsort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1124,7 +1161,6 @@
         }
         // TODO: Add to "ursprungsort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1145,7 +1181,6 @@
         }
         // TODO: Add to "ursprungsort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1166,7 +1201,6 @@
         }
         // TODO: Add to "ursprungsort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1187,7 +1221,6 @@
         }
         // TODO: Add to "ursprungsort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1208,7 +1241,6 @@
         }
         // TODO: Add to "ursprungsort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1249,7 +1281,6 @@
         }
         // TODO: Add to "ursprungsort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + art + " " + koord1 + " " + koord2);
     }
 
     /**
@@ -1290,7 +1321,6 @@
         }
         // TODO: Add to "ursprungsort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + art + " " + koord1 + " " + koord2);
     }
 
     /**
@@ -1311,7 +1341,6 @@
         }
         // TODO: Add to "ursprungsort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1332,7 +1361,6 @@
         }
         // TODO: Add to "ursprungsort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1341,10 +1369,9 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterU_nuts_code(LafParser.U_nuts_codeContext ctx) {
-        System.out.println(ctx.exception.getMessage());
         String value = ctx.getChild(1).toString();
         value = value.replaceAll("\"", "");
-        if (!value.matches(LafDataTypes.I10)) {
+        if (!value.matches(LafDataTypes.C10)) {
             ReportItem err = new ReportItem();
             err.setKey(ctx.getChild(0).toString());
             err.setValue(value);
@@ -1354,7 +1381,6 @@
         }
         // TODO: Add to "ursprungsort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1375,7 +1401,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1396,7 +1421,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1417,7 +1441,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1438,7 +1461,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1459,7 +1481,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1480,7 +1501,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1521,7 +1541,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + art + " " + koord1 + " " + koord2);
     }
 
     /**
@@ -1562,7 +1581,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + art + " " + koord1 + " " + koord2);
     }
 
     /**
@@ -1583,7 +1601,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1604,7 +1621,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1615,7 +1631,7 @@
     @Override public void enterP_nuts_code(LafParser.P_nuts_codeContext ctx) {
         String value = ctx.getChild(1).toString();
         value = value.replaceAll("\"", "");
-        if (!value.matches(LafDataTypes.I10)) {
+        if (!value.matches(LafDataTypes.C10)) {
             ReportItem err = new ReportItem();
             err.setKey(ctx.getChild(0).toString());
             err.setValue(value);
@@ -1625,7 +1641,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1646,7 +1661,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1667,7 +1681,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1679,7 +1692,6 @@
         String value = ctx.getChild(1).toString();
         value = value.replaceAll("\"", "");
         if (!value.matches(LafDataTypes.F10)) {
-            System.out.println("F10 does not match in hoehe_nn");
             ReportItem err = new ReportItem();
             err.setKey(ctx.getChild(0).toString());
             err.setValue(value);
@@ -1689,7 +1701,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1701,7 +1712,6 @@
         String value = ctx.getChild(1).toString();
         value = value.replaceAll("\"", "");
         if (!value.matches(LafDataTypes.F10)) {
-            System.out.println("F10 does not match in hoehe_land");
             ReportItem err = new ReportItem();
             err.setKey(ctx.getChild(0).toString());
             err.setValue(value);
@@ -1711,7 +1721,6 @@
         }
         // TODO: Add to "entnahmeort"
         //currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1731,7 +1740,6 @@
             return;
         }
         currentProbe.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1764,7 +1772,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addAttribute(ctx.getChild(0).toString().toUpperCase(), date + ' ' + time);
-        System.out.println(ctx.getChild(0) + ": " + date + ' ' + time);
     }
 
     /**
@@ -1787,7 +1794,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1810,7 +1816,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1833,7 +1838,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1856,7 +1860,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1879,7 +1882,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1902,7 +1904,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addAttribute(ctx.getChild(0).toString().toUpperCase(), value);
-        System.out.println(ctx.getChild(0) + ": " + value);
     }
 
     /**
@@ -1958,7 +1959,6 @@
         zusatzwert.put("EINHEIT", einheit);
         zusatzwert.put("MESSFEHLER", fehler);
         currentProbe.addZusatzwert(zusatzwert);
-        System.out.println("PZS: " + groesse + " MW: " + wert);
     }
 
     /**
@@ -2014,7 +2014,6 @@
         zusatzwert.put("EINHEIT_ID", einheit);
         zusatzwert.put("MESSFEHLER", fehler);
         currentProbe.addZusatzwert(zusatzwert);
-        System.out.println("PZS: " + groesse + " MW: " + wert);
     }
 
     /**
@@ -2033,7 +2032,6 @@
         String groesse = children.get(1);
         groesse = groesse.replaceAll("\"", "");
         if (!groesse.matches(LafDataTypes.C_STAR)) {
-            System.out.println("mw - groesse: " + groesse);
             ReportItem err = new ReportItem();
             err.setKey(ctx.getChild(0).toString());
             err.setValue(groesse);
@@ -2043,9 +2041,7 @@
         }
         String wert = children.get(2);
         wert = wert.replaceAll("\"", "");
-        System.out.println(wert);
         if (!wert.matches(LafDataTypes.F12)) {
-            System.out.println("mw: wert");
             ReportItem err = new ReportItem();
             err.setKey(ctx.getChild(0).toString());
             err.setValue(wert);
@@ -2056,7 +2052,6 @@
         String einheit = children.get(3);
         einheit = einheit.replaceAll("\"", "");
         if (!einheit.matches(LafDataTypes.C9)) {
-            System.out.println("mw: einheit");
             ReportItem err = new ReportItem();
             err.setKey(ctx.getChild(0).toString());
             err.setValue(einheit);
@@ -2065,11 +2060,10 @@
             return;
         }
         String fehler = null;
-        if (ctx.getChildCount() >= 8) {
+        if (ctx.getChildCount() >= 5) {
             fehler = children.get(4);
             fehler = fehler.replaceAll("\"", "");
             if (!fehler.matches(LafDataTypes.F9)) {
-            System.out.println("mw: fehler");
                 ReportItem err = new ReportItem();
                 err.setKey(ctx.getChild(0).toString());
                 err.setValue(fehler);
@@ -2087,7 +2081,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addMesswert(messwert);
-        System.out.println("GROESSE: " + groesse + " MW: " + wert);
     }
 
     /**
@@ -2155,7 +2148,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addMesswert(messwert);
-        System.out.println("GROESSE: " + groesse + " MW: " + wert);
     }
 
     /**
@@ -2224,7 +2216,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addMesswert(messwert);
-        System.out.println("GROESSE: " + groesse + " MW: " + wert);
     }
 
     /**
@@ -2293,7 +2284,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addMesswert(messwert);
-        System.out.println("GROESSE: " + groesse + " MW: " + wert);
     }
 
     /**
@@ -2303,7 +2293,72 @@
      */
     @Override public void enterMesswert_nwg(LafParser.Messwert_nwgContext ctx) {
         // C50* f12 c9 f9** f12
-        // TODO
+        List<String> children = new ArrayList<String>();
+        for (int i = 0; i < ctx.getChildCount(); i++) {
+            if (!ctx.getChild(i).toString().startsWith(" ")) {
+                children.add(ctx.getChild(i).toString());
+            }
+        }
+        String groesse = children.get(1);
+        groesse = groesse.replaceAll("\"", "");
+        if (!groesse.matches(LafDataTypes.C_STAR)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(groesse);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String wert = children.get(2);
+        wert = wert.replaceAll("\"", "");
+        if (!wert.matches(LafDataTypes.F12)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(wert);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String einheit = children.get(3);
+        einheit = einheit.replaceAll("\"", "");
+        if (!einheit.matches(LafDataTypes.C9)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(einheit);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String fehler = children.get(4);
+        fehler = fehler.replaceAll("\"", "");
+        if (!fehler.matches(LafDataTypes.F9)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(fehler);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String nwg = children.get(5);
+        nwg = nwg.replaceAll("\"", "");
+        if (!nwg.matches(LafDataTypes.F12)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(nwg);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        Map<String, String> messwert = new HashMap<String, String>();
+        messwert.put("MESSGROESSE", groesse);
+        messwert.put("MESSWERT", wert);
+        messwert.put("MEH", einheit);
+        messwert.put("MESSFEHLER", fehler);
+        messwert.put("NWG", nwg);
+        if (currentMessung == null) {
+            currentMessung = data.new Messung();
+        }
+        currentMessung.addMesswert(messwert);
     }
 
     /**
@@ -2312,7 +2367,73 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterMesswert_nwg_s(LafParser.Messwert_nwg_sContext ctx) {
-        // TODO
+        List<String> children = new ArrayList<String>();
+        for (int i = 0; i < ctx.getChildCount(); i++) {
+            if (!ctx.getChild(i).toString().startsWith(" ")) {
+                children.add(ctx.getChild(i).toString());
+            }
+        }
+        String groesse = children.get(1);
+        groesse = groesse.replaceAll("\"", "");
+        if (!groesse.matches(LafDataTypes.SI8)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(groesse);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String wert = children.get(2);
+        wert = wert.replaceAll("\"", "");
+        if (!wert.matches(LafDataTypes.F12)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(wert);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String einheit = children.get(3);
+        einheit = einheit.replaceAll("\"", "");
+        if (!einheit.matches(LafDataTypes.SI3)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(einheit);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String fehler = children.get(4);
+        fehler = fehler.replaceAll("\"", "");
+        if (!fehler.matches(LafDataTypes.F9)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(fehler);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String nwg = children.get(5);
+        nwg = nwg.replaceAll("\"", "");
+        if (!nwg.matches(LafDataTypes.F12)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(nwg);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        // TODO: handle all values
+        Map<String, String> messwert = new HashMap<String, String>();
+        messwert.put("MESSGROESSE_ID", groesse);
+        messwert.put("MESSWERT", wert);
+        messwert.put("MEH_ID", einheit);
+        messwert.put("MESSFEHLER", fehler);
+        messwert.put("NWG", nwg);
+        if (currentMessung == null) {
+            currentMessung = data.new Messung();
+        }
+        currentMessung.addMesswert(messwert);
     }
 
     /**
@@ -2321,7 +2442,73 @@
      * <p>The default implementation does nothing.</p>
      */
     @Override public void enterMesswert_nwg_i(LafParser.Messwert_nwg_iContext ctx) {
-        // TODO
+        List<String> children = new ArrayList<String>();
+        for (int i = 0; i < ctx.getChildCount(); i++) {
+            if (!ctx.getChild(i).toString().startsWith(" ")) {
+                children.add(ctx.getChild(i).toString());
+            }
+        }
+        String groesse = children.get(1);
+        groesse = groesse.replaceAll("\"", "");
+        if (!groesse.matches(LafDataTypes.C_STAR)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(groesse);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String wert = children.get(2);
+        wert = wert.replaceAll("\"", "");
+        if (!wert.matches(LafDataTypes.F12)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(wert);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String einheit = children.get(3);
+        einheit = einheit.replaceAll("\"", "");
+        if (!einheit.matches(LafDataTypes.C9)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(einheit);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String fehler = children.get(4);
+        fehler = fehler.replaceAll("\"", "");
+        if (!fehler.matches(LafDataTypes.F9)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(fehler);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String nwg = children.get(5);
+        nwg = nwg.replaceAll("\"", "");
+        if (!nwg.matches(LafDataTypes.F12)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(nwg);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        // TODO: handle all values
+        Map<String, String> messwert = new HashMap<String, String>();
+        messwert.put("MESSGROESSE", groesse);
+        messwert.put("MESSWERT", wert);
+        messwert.put("MEH", einheit);
+        messwert.put("MESSFEHLER", fehler);
+        messwert.put("NWG", nwg);
+        if (currentMessung == null) {
+            currentMessung = data.new Messung();
+        }
+        currentMessung.addMesswert(messwert);
     }
 
     /**
@@ -2331,6 +2518,84 @@
      */
     @Override public void enterMesswert_nwg_g(LafParser.Messwert_nwg_gContext ctx) {
         // TODO
+        List<String> children = new ArrayList<String>();
+        for (int i = 0; i < ctx.getChildCount(); i++) {
+            if (!ctx.getChild(i).toString().startsWith(" ")) {
+                children.add(ctx.getChild(i).toString());
+            }
+        }
+        String groesse = children.get(1);
+        groesse = groesse.replaceAll("\"", "");
+        if (!groesse.matches(LafDataTypes.C_STAR)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(groesse);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String wert = children.get(2);
+        wert = wert.replaceAll("\"", "");
+        if (!wert.matches(LafDataTypes.F12)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(wert);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String einheit = children.get(3);
+        einheit = einheit.replaceAll("\"", "");
+        if (!einheit.matches(LafDataTypes.C9)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(einheit);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String fehler = children.get(4);
+        fehler = fehler.replaceAll("\"", "");
+        if (!fehler.matches(LafDataTypes.F9)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(fehler);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String nwg = children.get(5);
+        nwg = nwg.replaceAll("\"", "");
+        if (!nwg.matches(LafDataTypes.F12)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(nwg);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        String gw = children.get(8);
+        gw = gw.replaceAll("\"", "");
+        if (!gw.matches(LafDataTypes.F12)) {
+            ReportItem err = new ReportItem();
+            err.setKey(ctx.getChild(0).toString());
+            err.setValue(gw);
+            err.setCode(670);
+            currentErrors.add(err);;
+            return;
+        }
+        // TODO: handle all values
+        Map<String, String> messwert = new HashMap<String, String>();
+        messwert.put("MESSGROESSE", groesse);
+        messwert.put("MESSWERT", wert);
+        messwert.put("MEH", einheit);
+        messwert.put("MESSFEHLER", fehler);
+        messwert.put("NWG", nwg);
+        messwert.put("GRENZWERT", gw);
+        if (currentMessung == null) {
+            currentMessung = data.new Messung();
+        }
+        currentMessung.addMesswert(messwert);
     }
 
     /**
@@ -2389,7 +2654,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addKommentar(kommentar);
-        System.out.println("KOMMENTAR: " + text);
     }
 
     /**
@@ -2414,7 +2678,6 @@
             currentMessung = data.new Messung();
         }
         currentMessung.addKommentar(kommentar);
-        System.out.println("KOMMENTAR: " + text);
     }
 
     /**
@@ -2470,7 +2733,6 @@
         kommentar.put("TIME", time);
         kommentar.put("TEXT", text);
         currentProbe.addKommentar(kommentar);
-        System.out.println("KOMMENTAR: " + text);
     }
 
     /**
@@ -2492,7 +2754,6 @@
         Map<String, String> kommentar = new HashMap<String, String>();
         kommentar.put("TEXT", text);
         currentProbe.addKommentar(kommentar);
-        System.out.println("KOMMENTAR: " + text);
     }
 
     /**
--- a/src/main/java/de/intevation/lada/importer/laf/LafObjectMapper.java	Mon Oct 24 11:47:55 2016 +0200
+++ b/src/main/java/de/intevation/lada/importer/laf/LafObjectMapper.java	Mon Oct 24 11:52:17 2016 +0200
@@ -1,32 +1,865 @@
 package de.intevation.lada.importer.laf;
 
+import java.sql.Timestamp;
+import java.text.DateFormat;
+import java.text.ParseException;
+import java.text.SimpleDateFormat;
+import java.util.ArrayList;
+import java.util.Date;
+import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
+import java.util.Map.Entry;
 
 import javax.inject.Inject;
+import javax.management.modelmbean.InvalidTargetObjectTypeException;
 
+import org.apache.commons.lang.StringUtils;
+import org.apache.log4j.Logger;
+
+import de.intevation.lada.factory.ProbeFactory;
+import de.intevation.lada.importer.Identified;
+import de.intevation.lada.importer.Identifier;
+import de.intevation.lada.importer.IdentifierConfig;
+import de.intevation.lada.importer.ObjectMerger;
 import de.intevation.lada.importer.ReportItem;
+import de.intevation.lada.model.land.KommentarM;
+import de.intevation.lada.model.land.KommentarP;
+import de.intevation.lada.model.land.Messung;
+import de.intevation.lada.model.land.Messwert;
+import de.intevation.lada.model.land.Probe;
+import de.intevation.lada.model.land.StatusProtokoll;
+import de.intevation.lada.model.land.ZusatzWert;
+import de.intevation.lada.model.stammdaten.Datenbasis;
+import de.intevation.lada.model.stammdaten.MessEinheit;
+import de.intevation.lada.model.stammdaten.MessStelle;
+import de.intevation.lada.model.stammdaten.Messgroesse;
+import de.intevation.lada.model.stammdaten.MessprogrammKategorie;
+import de.intevation.lada.model.stammdaten.MessprogrammTransfer;
+import de.intevation.lada.model.stammdaten.ProbenZusatz;
+import de.intevation.lada.model.stammdaten.Probenart;
+import de.intevation.lada.model.stammdaten.StatusKombi;
+import de.intevation.lada.model.stammdaten.Umwelt;
+import de.intevation.lada.util.annotation.AuthorizationConfig;
 import de.intevation.lada.util.annotation.RepositoryConfig;
+import de.intevation.lada.util.auth.Authorization;
+import de.intevation.lada.util.auth.AuthorizationType;
+import de.intevation.lada.util.auth.UserInfo;
+import de.intevation.lada.util.data.QueryBuilder;
 import de.intevation.lada.util.data.Repository;
 import de.intevation.lada.util.data.RepositoryType;
+import de.intevation.lada.util.rest.Response;
+import de.intevation.lada.validation.Validator;
+import de.intevation.lada.validation.Violation;
+import de.intevation.lada.validation.annotation.ValidationConfig;
 
 public class LafObjectMapper {
 
     @Inject
+    private Logger logger;
+
+    @Inject
+    @AuthorizationConfig(type=AuthorizationType.HEADER)
+    private Authorization authorizer;
+
+    @Inject
+    @ValidationConfig(type="Probe")
+    private Validator probeValidator;
+
+    @Inject
+    @ValidationConfig(type="Messung")
+    private Validator messungValidator;
+
+    @Inject
+    @IdentifierConfig(type="Probe")
+    private Identifier probeIdentifier;
+
+    @Inject
+    @IdentifierConfig(type="Messung")
+    private Identifier messungIdentifier;
+
+    @Inject
+    private ObjectMerger merger;
+
+    @Inject
     @RepositoryConfig(type=RepositoryType.RW)
     private Repository repository;
 
+    @Inject
+    private ProbeFactory factory;
+
     private Map<String, List<ReportItem>> errors;
     private Map<String, List<ReportItem>> warnings;
+    private List<ReportItem> currentErrors;
+    private List<ReportItem> currentWarnings;
+
+
+    private UserInfo userInfo;
 
     public void mapObjects(LafRawData data) {
+        errors = new HashMap<String, List<ReportItem>>();
+        warnings = new HashMap<String, List<ReportItem>>();
         for (int i = 0; i < data.getProben().size(); i++) {
-            generate(data.getProben().get(i));
+            create(data.getProben().get(i));
         }
     }
 
-    private void generate(LafRawData.Probe object) {
-        object.getAttributes();
+    private void create(LafRawData.Probe object) {
+        currentWarnings = new ArrayList<ReportItem>();
+        currentErrors = new ArrayList<ReportItem>();
+        Probe probe = new Probe();
+
+        // Fill the object with data
+        for (Entry<String, String> attribute : object.getAttributes().entrySet()) {
+            addProbeAttribute(attribute, probe);
+        }
+        // Use the deskriptor string to find the medium
+        probe = factory.findMediaDesk(probe);
+        //logProbe(probe);
+
+        // Check if the user is authorized to create the probe
+        boolean isAuthorized = authorizer.isAuthorized(userInfo, probe, Probe.class);
+        if (!isAuthorized) {
+            ReportItem err = new ReportItem();
+            err.setCode(699);
+            err.setKey("auth");
+            err.setValue("not authorized");
+            currentErrors.add(err);
+            return;
+        }
+
+        // Check for errors and warnings
+
+        // Compare the probe with objects in the db
+        Probe newProbe = null;
+        try {
+            Identified i = probeIdentifier.find(probe);
+            Probe old = (Probe)probeIdentifier.getExisting();
+            // Matching probe was found in the db. Update it!
+            if(i == Identified.UPDATE) {
+                merger.merge(old, probe);
+                newProbe = old;
+                Violation violation = probeValidator.validate(newProbe);
+                for (Entry<String, List<Integer>> warn : violation.getWarnings().entrySet()) {
+                    for (Integer code : warn.getValue()) {
+                        currentWarnings.add(new ReportItem("validation", warn.getKey(), code));
+                    }
+                }
+            }
+            // Probe was found but some data does not match
+            else if(i == Identified.REJECT){
+                ReportItem err = new ReportItem();
+                err.setCode(631);
+                err.setKey("duplicate");
+                err.setValue("");
+                currentErrors.add(err);
+                return;
+            }
+            // It is a brand new probe!
+            else if(i == Identified.NEW){
+                Violation violation = probeValidator.validate(probe);
+                for (Entry<String, List<Integer>> err : violation.getErrors().entrySet()) {
+                    for (Integer code : err.getValue()) {
+                        currentErrors.add(new ReportItem("validation", err.getKey(), code));
+                    }
+                }
+                for (Entry<String, List<Integer>> warn : violation.getWarnings().entrySet()) {
+                    for (Integer code : warn.getValue()) {
+                        currentWarnings.add(new ReportItem("validation", warn.getKey(), code));
+                    }
+                }
+                Response created = repository.create(probe, "land");
+                newProbe = ((Probe)created.getData());
+            }
+        } catch (InvalidTargetObjectTypeException e) {
+            ReportItem err = new ReportItem();
+            err.setCode(604);
+            err.setKey("not known");
+            err.setValue("No valid Probe Object");
+            currentErrors.add(err);
+            return;
+        }
+        if (newProbe == null) {
+            // Only occurs if object type is not probe
+            return;
+        }
+        // Create kommentar objects
+        List<KommentarP> kommentare = new ArrayList<KommentarP>();
+        for (int i = 0; i < object.getKommentare().size(); i++) {
+            KommentarP tmp = createProbeKommentar(object.getKommentare().get(i), newProbe.getId());
+            if (tmp != null) {
+                kommentare.add(tmp);
+            }
+        }
+        // Persist kommentar objects
+        merger.mergeKommentare(newProbe, kommentare);
+
+        // Create zusatzwert objects
+        List<ZusatzWert> zusatzwerte = new ArrayList<ZusatzWert>();
+        for (int i = 0; i < object.getZusatzwerte().size(); i++) {
+            ZusatzWert tmp = createZusatzwert(object.getZusatzwerte().get(i), newProbe.getId());
+            if (tmp != null) {
+                zusatzwerte.add(tmp);
+            }
+        }
+        // Persist zusatzwert objects
+        merger.mergeZusatzwerte(newProbe, zusatzwerte);
+
+        // Create messung objects
+        for (int i = 0; i < object.getMessungen().size(); i++) {
+            create(object.getMessungen().get(i), newProbe.getId(), newProbe.getMstId());
+        }
+        if (currentErrors.size() > 0) {
+            List<ReportItem> copyErr = new ArrayList<ReportItem>(currentErrors);
+            System.out.println("errs for probe: " + probe.getIdAlt());
+            errors.put(probe.getIdAlt(), copyErr);
+        }
+        if (currentWarnings.size() > 0) {
+            List<ReportItem> copyWarn = new ArrayList<ReportItem>(currentWarnings);
+            warnings.put(probe.getIdAlt(), copyWarn);
+            System.out.println("warn: " + warnings.size());
+        }
+        currentErrors.clear();
+        currentWarnings.clear();
+        logger.debug("probe written to database.");
+    }
+
+    private void create(LafRawData.Messung object, int probeId, String mstId) {
+        Messung messung = new Messung();
+        messung.setProbeId(probeId);
+
+        // Fill the new messung with data
+        for (Entry<String, String> attribute : object.getAttributes().entrySet()) {
+            addMessungAttribute(attribute, messung);
+        }
+
+        // Check if the user is authorized to create the object
+        if (!authorizer.isAuthorizedOnNew(userInfo, messung, Messung.class)) {
+            ReportItem warn = new ReportItem();
+            warn.setCode(699);
+            warn.setKey("auth");
+            warn.setValue("Messung: " + messung.getNebenprobenNr());
+            currentErrors.add(warn);
+            return;
+        }
+
+
+        // Compare with messung objects in the db
+        Messung newMessung = null;
+        try {
+            Identified i = messungIdentifier.find(messung);
+            Messung old = (Messung)messungIdentifier.getExisting();
+            if (i == Identified.UPDATE) {
+                merger.mergeMessung(old, messung);
+                newMessung = old;
+                // We do not import the status. Doing this can cause an
+                // inconsistent status protocol.
+            }
+            else if (i == Identified.REJECT) {
+                ReportItem warn = new ReportItem();
+                warn.setCode(631);
+                warn.setKey("duplicate");
+                warn.setValue("Messung: " + messung.getNebenprobenNr());
+                currentWarnings.add(warn);
+                return;
+            }
+            else if (i == Identified.NEW) {
+                // Create a new messung and the first status
+                Response created = repository.create(messung, "land");
+                newMessung = ((Messung)created.getData());
+                created = repository.getById(Messung.class, newMessung.getId(), "land");
+                newMessung = ((Messung)created.getData());
+                StatusProtokoll status = new StatusProtokoll();
+                status.setDatum(new Timestamp(new Date().getTime()));
+                status.setMessungsId(newMessung.getId());
+                status.setMstId(mstId);
+                status.setStatusKombi(1);
+                Response st = repository.create(status, "land");
+                newMessung.setStatus(((StatusProtokoll)st.getData()).getId());
+                repository.update(newMessung, "land");
+                if (object.getAttributes().containsKey("BEARBEITUNGSSTATUS")) {
+                    createStatusProtokoll(object.getAttributes().get("BEARBEITUNGSSTATUS"), newMessung, mstId);
+                }
+            }
+        }
+        catch(InvalidTargetObjectTypeException e) {
+            ReportItem err = new ReportItem();
+            err.setCode(604);
+            err.setKey("not valid");
+            err.setValue("Messung: " + messung.getNebenprobenNr());
+            currentErrors.add(err);
+            return;
+        }
+        List<KommentarM> kommentare = new ArrayList<KommentarM>();
+        for (int i = 0; i < object.getKommentare().size(); i++) {
+            KommentarM tmp = createMessungKommentar(object.getKommentare().get(i), newMessung.getId());
+            if (tmp != null) {
+                kommentare.add(tmp);
+            }
+        }
+        merger.mergeMessungKommentare(newMessung, kommentare);
+        List<Messwert> messwerte = new ArrayList<Messwert>();
+        for (int i = 0; i < object.getMesswerte().size(); i++) {
+            Messwert tmp = createMesswert(object.getMesswerte().get(i), newMessung.getId());
+            if (tmp != null) {
+                messwerte.add(tmp);
+            }
+        }
+        merger.mergeMesswerte(newMessung, messwerte);
+        // Check for warnings and errors
+        Violation violation = messungValidator.validate(newMessung);
+        for (Entry<String, List<Integer>> err : violation.getErrors().entrySet()) {
+            for (Integer code : err.getValue()) {
+                currentErrors.add(new ReportItem("validation", err.getKey(), code));
+            }
+        }
+        for (Entry<String, List<Integer>> warn : violation.getWarnings().entrySet()) {
+            for (Integer code : warn.getValue()) {
+                currentWarnings.add(new ReportItem("validation", warn.getKey(), code));
+            }
+        }
+    }
+
+    private KommentarP createProbeKommentar(Map<String, String> attributes, int probeId) {
+        KommentarP kommentar = new KommentarP();
+        kommentar.setProbeId(probeId);
+        kommentar.setMstId(attributes.get("MST_ID"));
+        kommentar.setText(attributes.get("TEXT"));
+        DateFormat format = new SimpleDateFormat("yyyyMMdd HHmm");
+        String date = attributes.get("DATE") + " " + attributes.get("TIME");
+        Date d;
+        try {
+            d = format.parse(date);
+            kommentar.setDatum(new Timestamp(d.getTime()));
+        }
+        catch (ParseException e) {
+            ReportItem warn = new ReportItem();
+            warn.setCode(674);
+            warn.setKey("not valid");
+            warn.setValue("Date: " + date);
+            currentWarnings.add(warn);
+        }
+        if (!userInfo.getMessstellen().contains(kommentar.getMstId())) {
+            ReportItem warn = new ReportItem();
+            warn.setCode(699);
+            warn.setKey("auth");
+            warn.setValue(kommentar.getMstId());
+            currentWarnings.add(warn);
+            return null;
+        }
+        return kommentar;
+    }
+
+    private ZusatzWert createZusatzwert(Map<String, String> attributes, int probeId) {
+        ZusatzWert zusatzwert = new ZusatzWert();
+        zusatzwert.setProbeId(probeId);
+        zusatzwert.setMessfehler(Float.valueOf(attributes.get("MESSFEHLER")));
+        zusatzwert.setMesswertPzs(Double.valueOf(attributes.get("MESSWERT_PZS")));
+        QueryBuilder<ProbenZusatz> builder =
+            new QueryBuilder<ProbenZusatz>(
+                repository.entityManager("stamm"),
+                ProbenZusatz.class);
+        builder.and("zusatzwert", attributes.get("PZS"));
+        List<ProbenZusatz> zusatz =
+            (List<ProbenZusatz>)repository.filter(
+                builder.getQuery(),
+                "stamm").getData();
+
+        if (zusatz == null || zusatz.isEmpty()) {
+            ReportItem warn = new ReportItem();
+            warn.setCode(673);
+            warn.setKey("zusatzwert");
+            warn.setValue(attributes.get("PZS"));
+            currentWarnings.add(warn);
+            return null;
+        }
+        zusatzwert.setPzsId(zusatz.get(0).getId());
+        return zusatzwert;
+    }
+
+    private Messwert createMesswert(Map<String, String> attributes, int messungsId) {
+        Messwert messwert = new Messwert();
+        messwert.setMessungsId(messungsId);
+        if (attributes.containsKey("MESSGROESSE_ID")) {
+            messwert.setMessgroesseId(Integer.valueOf(attributes.get("MESSGROESSE_ID")));
+        }
+        else if (attributes.containsKey("MESSGROESSE")) {
+            QueryBuilder<Messgroesse> builder =
+                new QueryBuilder<Messgroesse>(
+                    repository.entityManager("stamm"),
+                    Messgroesse.class);
+            builder.and("messgroesse", attributes.get("MESSGROESSE"));
+            List<Messgroesse> groesse =
+                (List<Messgroesse>)repository.filter(
+                    builder.getQuery(),
+                    "stamm").getData();
+
+            if (groesse == null || groesse.isEmpty()) {
+                ReportItem warn = new ReportItem();
+                warn.setCode(673);
+                warn.setKey("messwert");
+                warn.setValue(attributes.get("MESSGROESSE"));
+                currentWarnings.add(warn);
+                return null;
+            }
+            messwert.setMessgroesseId(groesse.get(0).getId());
+        }
+        if (attributes.containsKey("MEH_ID")) {
+            messwert.setMehId(Integer.valueOf(attributes.get("MEH_ID")));
+        }
+        else if (attributes.containsKey("MEH")) {
+            QueryBuilder<MessEinheit> builder =
+                new QueryBuilder<MessEinheit>(
+                    repository.entityManager("stamm"),
+                    MessEinheit.class);
+            builder.and("einheit", attributes.get("MEH"));
+            List<MessEinheit> einheit =
+                (List<MessEinheit>)repository.filter(
+                    builder.getQuery(),
+                    "stamm").getData();
+
+            if (einheit == null || einheit.isEmpty()) {
+                ReportItem warn = new ReportItem();
+                warn.setCode(673);
+                warn.setKey("messwert");
+                warn.setValue(attributes.get("MEH"));
+                currentWarnings.add(warn);
+                return null;
+            }
+            messwert.setMehId(einheit.get(0).getId());
+        }
+
+        String wert = attributes.get("MESSWERT");
+        if (wert.startsWith("<")) {
+            wert = wert.substring(1);
+            messwert.setMesswertNwg("<");
+        }
+        messwert.setMesswert(Double.valueOf(wert));
+        messwert.setMessfehler(Double.valueOf(attributes.get("MESSFEHLER")).floatValue());
+        if (attributes.containsKey("NWG")) {
+            messwert.setNwgZuMesswert(Double.valueOf(attributes.get("NWG")));
+        }
+        if (attributes.containsKey("GRENZWERT")) {
+            messwert.setGrenzwertueberschreitung(attributes.get("GRENZWERT").toUpperCase() == "J" ? true : false);
+        }
+        return messwert;
+    }
+
+    private KommentarM createMessungKommentar(Map<String, String> attributes, int messungsId) {
+        KommentarM kommentar = new KommentarM();
+        kommentar.setMessungsId(messungsId);
+        kommentar.setMstId(attributes.get("MST_ID"));
+        kommentar.setText(attributes.get("TEXT"));
+        DateFormat format = new SimpleDateFormat("yyyyMMdd HHmm");
+        String date = attributes.get("DATE") + " " + attributes.get("TIME");
+        Date d;
+        try {
+            d = format.parse(date);
+            kommentar.setDatum(new Timestamp(d.getTime()));
+        }
+        catch (ParseException e) {
+            ReportItem warn = new ReportItem();
+            warn.setCode(674);
+            warn.setKey("kommentar");
+            warn.setValue("Date: " + date);
+            currentWarnings.add(warn);
+        }
+        if (!userInfo.getMessstellen().contains(kommentar.getMstId())) {
+            return null;
+        }
+        return kommentar;
+    }
+
+    private void createStatusProtokoll(String status, Messung messung, String mstId) {
+        int mst = Integer.valueOf(status.substring(0, 1));
+        int land = Integer.valueOf(status.substring(1, 2));
+        int lst = Integer.valueOf(status.substring(2, 3));
+
+        boolean hasMst = false;
+        boolean hasLand = false;
+
+        StatusProtokoll last = null;
+        if (userInfo.getFunktionenForMst(mstId).contains(1)) {
+            QueryBuilder<StatusKombi> builder =
+                new QueryBuilder<StatusKombi>(
+                    repository.entityManager("stamm"),
+                    StatusKombi.class);
+            builder.and("statusWert", mst);
+            builder.and("statusStufe", 1);
+            List<StatusKombi> kombi =
+                (List<StatusKombi>)repository.filter(
+                    builder.getQuery(),
+                    "stamm").getData();
+            if (kombi != null && !kombi.isEmpty()) {
+                StatusProtokoll statusMst = new StatusProtokoll();
+                statusMst.setDatum(new Timestamp(new Date().getTime()));
+                statusMst.setMessungsId(messung.getId());
+                statusMst.setMstId(mstId);
+                statusMst.setStatusKombi(kombi.get(0).getId());
+                Response r = repository.create(statusMst, "land");
+                last = (StatusProtokoll)r.getData();
+            }
+            hasMst = true;
+        }
+        MessStelle messStelle = repository.getByIdPlain(MessStelle.class, mstId, "stamm");
+        if (userInfo.getNetzbetreiber().contains(messStelle.getNetzbetreiberId()) &&
+            userInfo.getFunktionenForNetzbetreiber(messStelle.getNetzbetreiberId()).contains(2) &&
+            hasMst) {
+                // Set status for stufe land.
+            QueryBuilder<StatusKombi> builder =
+                new QueryBuilder<StatusKombi>(
+                    repository.entityManager("stamm"),
+                    StatusKombi.class);
+            builder.and("statusWert", land);
+            builder.and("statusStufe", 2);
+            List<StatusKombi> kombi =
+                (List<StatusKombi>)repository.filter(
+                    builder.getQuery(),
+                    "stamm").getData();
+            if (kombi != null && !kombi.isEmpty()) {
+                StatusProtokoll statusLand = new StatusProtokoll();
+                statusLand.setDatum(new Timestamp(new Date().getTime()));
+                statusLand.setMessungsId(messung.getId());
+                statusLand.setMstId(mstId);
+                statusLand.setStatusKombi(kombi.get(0).getId());
+                Response r = repository.create(statusLand, "land");
+                last = (StatusProtokoll)r.getData();
+            }
+        }
+        if (userInfo.getFunktionen().contains(3) &&
+            hasLand) {
+            // Set status for stufe lst.
+            QueryBuilder<StatusKombi> builder =
+                new QueryBuilder<StatusKombi>(
+                    repository.entityManager("stamm"),
+                    StatusKombi.class);
+            builder.and("statusWert", lst);
+            builder.and("statusStufe", 3);
+            List<StatusKombi> kombi =
+                (List<StatusKombi>)repository.filter(
+                    builder.getQuery(),
+                    "stamm").getData();
+            if (kombi != null && !kombi.isEmpty()) {
+                StatusProtokoll statusLst = new StatusProtokoll();
+                statusLst.setDatum(new Timestamp(new Date().getTime()));
+                statusLst.setMessungsId(messung.getId());
+                statusLst.setMstId(mstId);
+                statusLst.setStatusKombi(kombi.get(0).getId());
+                Response r = repository.create(statusLst, "land");
+                last = (StatusProtokoll)r.getData();
+            }
+        }
+        if (last != null) {
+            messung.setStatus(last.getId());
+            repository.update(messung, "land");
+        }
+    }
+
+    private void logProbe(Probe probe) {
+        logger.debug("%PROBE%");
+        logger.debug("datenbasis: " + probe.getDatenbasisId());
+        logger.debug("betriebsart: " + probe.getBaId());
+        logger.debug("erzeuger: " + probe.getErzeugerId());
+        logger.debug("hauptprobennummer: " + probe.getHauptprobenNr());
+        logger.debug("idalt: " + probe.getIdAlt());
+        logger.debug("labor: " + probe.getLaborMstId());
+        logger.debug("deskriptoren: " + probe.getMediaDesk());
+        logger.debug("media: " + probe.getMedia());
+        logger.debug("mittelung: " + probe.getMittelungsdauer());
+        logger.debug("mpl: " + probe.getMplId());
+        logger.debug("mpr: " + probe.getMprId());
+        logger.debug("mst: " + probe.getMstId());
+        logger.debug("pnbeginn: " + probe.getProbeentnahmeBeginn());
+        logger.debug("pnende: " + probe.getProbeentnahmeEnde());
+        logger.debug("probenart: " + probe.getProbenartId());
+        logger.debug("probenehmer: " + probe.getProbeNehmerId());
+        logger.debug("sbeginn: " + probe.getSolldatumBeginn());
+        logger.debug("sende: " + probe.getSolldatumEnde());
+        logger.debug("test: " + probe.getTest());
+        logger.debug("umw: " + probe.getUmwId());
+    }
+
+    private void addProbeAttribute(Entry<String, String> attribute, Probe probe) {
+        String key = attribute.getKey();
+        String value = attribute.getValue();
+
+        DateFormat format = new SimpleDateFormat("yyyyMMdd HHmm");
+        if ("DATENBASIS_S".equals(key) && probe.getDatenbasisId() == null) {
+            Integer v = Integer.valueOf(value.toString());
+            probe.setDatenbasisId(v);
+        }
+        else if ("DATENBASIS_S".equals(key) && probe.getDatenbasisId() != null){
+            currentWarnings.add(new ReportItem(key, value.toString(), 672));
+        }
+
+
+        if ("DATENBASIS".equals(key) && probe.getDatenbasisId() == null) {
+            QueryBuilder<Datenbasis> builder =
+                new QueryBuilder<Datenbasis>(
+                    repository.entityManager("stamm"),
+                    Datenbasis.class);
+            builder.and("datenbasis", value.toString());
+            List<Datenbasis> datenbasis =
+                (List<Datenbasis>)repository.filter(
+                    builder.getQuery(),
+                    "stamm").getData();
+            if (datenbasis == null || datenbasis.isEmpty()) {
+                ReportItem err = new ReportItem();
+                err.setCode(673);
+                err.setKey("datenbasis");
+                err.setValue(key);
+                currentErrors.add(err);
+                return;
+            }
+            Integer v = datenbasis.get(0).getId();
+            probe.setDatenbasisId(v);
+        }
+        else if ("DATENBASIS".equals(key) && probe.getDatenbasisId() != null){
+            currentWarnings.add(new ReportItem(key, value.toString(), 672));
+        }
+
+        if ("PROBE_ID".equals(key)) {
+            probe.setIdAlt(value);
+        }
+
+        if ("HAUPTPROBENNUMMER".equals(key)) {
+            probe.setHauptprobenNr(value.toString());
+        }
+
+        if ("MPR_ID".equals(key)) {
+            Integer v = Integer.valueOf(value.toString());
+            probe.setMprId(v);
+        }
+
+        if ("MESSSTELLE".equals(key)) {
+            probe.setMstId(value.toString());
+        }
+
+        if ("MESSLABOR".equals(key)) {
+            probe.setLaborMstId(value.toString());
+        }
+
+        if ("MESSPROGRAMM_S".equals(key) && probe.getBaId() == null) {
+            QueryBuilder<MessprogrammTransfer> builder =
+                new QueryBuilder<MessprogrammTransfer>(
+                    repository.entityManager("stamm"),
+                    MessprogrammTransfer.class);
+            builder.and("messprogrammS", value);
+            List<MessprogrammTransfer> transfer=
+                (List<MessprogrammTransfer>)repository.filter(
+                    builder.getQuery(),
+                    "stamm").getData();
+            if (transfer == null || transfer.isEmpty()) {
+                ReportItem warn = new ReportItem();
+                warn.setCode(673);
+                warn.setKey("messprogramm");
+                warn.setValue(key);
+                currentWarnings.add(warn);
+                return;
+            }
+            probe.setBaId(transfer.get(0).getBaId());
+        }
+        if ("MESSPROGRAMM_C".equals(key)){
+            QueryBuilder<MessprogrammTransfer> builder =
+                new QueryBuilder<MessprogrammTransfer>(
+                    repository.entityManager("stamm"),
+                    MessprogrammTransfer.class);
+            builder.and("messprogrammC", value);
+            List<MessprogrammTransfer> transfer=
+                (List<MessprogrammTransfer>)repository.filter(
+                    builder.getQuery(),
+                    "stamm").getData();
+            if (transfer == null || transfer.isEmpty()) {
+                ReportItem warn = new ReportItem();
+                warn.setCode(673);
+                warn.setKey("messprogramm");
+                warn.setValue(key);
+                currentWarnings.add(warn);
+                return;
+            }
+            probe.setBaId(transfer.get(0).getBaId());
+        }
+
+        if ("MESSPROGRAMM_LAND".equals(key)) {
+            QueryBuilder<MessprogrammKategorie> builder =
+                new QueryBuilder<MessprogrammKategorie>(
+                    repository.entityManager("stamm"),
+                    MessprogrammKategorie.class);
+            builder.or("netzbetreiberId", userInfo.getNetzbetreiber());
+            builder.and("code", value);
+            List<MessprogrammKategorie> kategorie =
+                (List<MessprogrammKategorie>)repository.filter(
+                    builder.getQuery(),
+                    "stamm").getData();
+            if (kategorie == null || kategorie.isEmpty()) {
+                ReportItem warn = new ReportItem();
+                warn.setCode(673);
+                warn.setKey("messprogramm_land");
+                warn.setValue(key);
+                currentWarnings.add(warn);
+                return;
+            }
+            probe.setMplId(kategorie.get(0).getId());
+        }
+
+        if ("SOLL_DATUM_UHRZEIT_A".equals(key)) {
+            try {
+                Date d = format.parse(value.toString());
+                probe.setSolldatumBeginn(new Timestamp(d.getTime()));
+            }
+            catch (ParseException e) {
+                currentWarnings.add(new ReportItem(key, value.toString(), 674));
+            }
+        }
+        if ("SOLL_DATUM_UHRZEIT_E".equals(key)) {
+            try {
+                Date d = format.parse(value.toString());
+                probe.setSolldatumEnde(new Timestamp(d.getTime()));
+            }
+            catch (ParseException e) {
+                currentWarnings.add(new ReportItem(key, value.toString(), 674));
+            }
+        }
+        if ("PROBENAHME_DATUM_UHRZEIT_A".equals(key)) {
+            try {
+                Date d = format.parse(value.toString());
+                probe.setProbeentnahmeBeginn(new Timestamp(d.getTime()));
+            }
+            catch (ParseException e) {
+                currentWarnings.add(new ReportItem(key, value.toString(), 674));
+            }
+        }
+        if ("PROBENAHME_DATUM_UHRZEIT_E".equals(key)) {
+            try {
+                Date d = format.parse(value.toString());
+                probe.setProbeentnahmeEnde(new Timestamp(d.getTime()));
+            }
+            catch (ParseException e) {
+                currentWarnings.add(new ReportItem(key, value.toString(), 674));
+            }
+        }
+
+        if ("UMWELTBEREICH_S".equals(key) && probe.getUmwId() == null) {
+            probe.setUmwId(value.toString());
+        }
+        else if ("UMWELTBEREICH_S".equals(key) && probe.getUmwId() != null){
+            currentWarnings.add(new ReportItem(key, value.toString(), 672));
+        }
+        if ("UMWELTBEREICH_C".equals(key) && probe.getUmwId() == null) {
+            QueryBuilder<Umwelt> builder =
+                new QueryBuilder<Umwelt>(
+                    repository.entityManager("stamm"),
+                    Umwelt.class);
+            int length = value.toString().length() > 80 ? 80 : value.toString().length();
+            builder.and("umweltBereich", value.toString().substring(0, length));
+            List<Umwelt> umwelt =
+                (List<Umwelt>)repository.filter(
+                    builder.getQuery(),
+                    "stamm").getData();
+            if (umwelt == null || umwelt.isEmpty()) {
+                ReportItem warn = new ReportItem();
+                warn.setCode(673);
+                warn.setKey("umwelt");
+                warn.setValue(key);
+                currentWarnings.add(warn);
+                return;
+            }
+            probe.setUmwId(umwelt.get(0).getId());
+        }
+        else if ("UMWELTBEREICH_C".equals(key) && probe.getUmwId() != null){
+            currentWarnings.add(new ReportItem(key, value.toString(), 672));
+        }
+
+        if ("DESKRIPTOREN".equals(key)) {
+            value = value.replace(" ", "0");
+            List<String> tmp = new ArrayList<String>();
+            tmp.add("D:");
+            for (int i =  0; i < value.length() - 2; i += 2) {
+                tmp.add(value.substring(i, i+2));
+            }
+            probe.setMediaDesk(StringUtils.join(tmp.toArray(), " "));
+        }
+
+        if ("TESTDATEN".equals(key)) {
+            if (!value.toString().equals("0")) {
+                probe.setTest(true);
+            }
+            else {
+                probe.setTest(false);
+            }
+        }
+
+        if ("MEDIUM".equals(key)) {
+            probe.setMedia(value.toString());
+        }
+
+        if ("PROBENART".equals(key)) {
+            QueryBuilder<Probenart> builder =
+                new QueryBuilder<Probenart>(
+                    repository.entityManager("stamm"),
+                    Probenart.class);
+            builder.and("probenart", value.toString());
+            List<Probenart> probenart =
+                (List<Probenart>)repository.filter(
+                    builder.getQuery(),
+                    "stamm").getData();
+            if (probenart == null || probenart.isEmpty()) {
+                ReportItem warn = new ReportItem();
+                warn.setCode(673);
+                warn.setKey("probenart");
+                warn.setValue(key);
+                currentWarnings.add(warn);
+                return;
+            }
+            probe.setProbenartId(probenart.get(0).getId());
+        }
+    }
+    /**
+     * Add an attribute to the given LMessung object.
+     *
+     * @param key       The key mapping to a object member.
+     * @param value     The value to set.
+     * @param messung   The entity object.
+     * @return The updated entity object.
+     */
+    public Messung addMessungAttribute(
+        Entry<String, String> attribute,
+        Messung messung
+    ) {
+        String key = attribute.getKey();
+        String value = attribute.getValue();
+        DateFormat format = new SimpleDateFormat("yyyyMMdd HHmm");
+        if ("MESSUNGS_ID".equals(key)) {
+            messung.setIdAlt(Integer.valueOf(value));
+        }
+        if ("NEBENPROBENNUMMER".equals(key)) {
+            messung.setNebenprobenNr(value.toString());
+        }
+        else if ("MESS_DATUM_UHRZEIT".equals(key)) {
+            try {
+                Date d = format.parse(value.toString());
+                messung.setMesszeitpunkt(new Timestamp(d.getTime()));
+            }
+            catch (ParseException e) {
+                currentWarnings.add(new ReportItem(key, value.toString(), 674));
+            }
+        }
+        else if ("MESSZEIT_SEKUNDEN".equals(key)) {
+            Integer i = Integer.valueOf(value.toString());
+            messung.setMessdauer(i);
+        }
+        else if ("MESSMETHODE_S".equals(key)) {
+            messung.setMmtId(value.toString());
+        }
+        else if ("ERFASSUNG_ABGESCHLOSSEN".equals(key)) {
+            if(!value.toString().equals("0")) {
+                messung.setFertig(true);
+            }
+            else {
+                messung.setFertig(false);
+            }
+        }
+        return messung;
     }
 
     /**
@@ -40,6 +873,24 @@
      * @return the warnings
      */
     public Map<String, List<ReportItem>> getWarnings() {
+        System.out.println(warnings.size());
         return warnings;
     }
+
+    /**
+     * @return the userInfo
+     */
+    public UserInfo getUserInfo() {
+        return userInfo;
+    }
+
+    /**
+     * @param userInfo the userInfo to set
+     */
+    public void setUserInfo(UserInfo userInfo) {
+        this.userInfo = userInfo;
+    }
 }
+
+
+
--- a/src/main/java/de/intevation/lada/importer/laf/LafParser.java	Mon Oct 24 11:47:55 2016 +0200
+++ b/src/main/java/de/intevation/lada/importer/laf/LafParser.java	Mon Oct 24 11:52:17 2016 +0200
@@ -327,7 +327,7 @@
 				setState(245); 
 				_errHandler.sync(this);
 				_la = _input.LA(1);
-			} while ( (((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << T__2) | (1L << T__3) | (1L << VERSION) | (1L << UEBERTRAGUNGSFORMAT) | (1L << DATENBASIS) | (1L << DATENBASIS_S) | (1L << NETZKENNUNG) | (1L << ERZEUGER) | (1L << STAAT_DER_MESSSTELLE_LANG) | (1L << STAAT_DER_MESSSTELLE_KURZ) | (1L << STAAT_DER_MESSSTELLE_S) | (1L << MESSSTELLE) | (1L << MESSLABOR) | (1L << PROBE_ID) | (1L << MESSUNGS_ID) | (1L << PROBEN_NR) | (1L << HAUPTPROBENNUMMER) | (1L << NEBENPROBENNUMMER) | (1L << MESSPROGRAMM_C) | (1L << MESSPROGRAMM_S) | (1L << MESSPROGRAMM_LAND) | (1L << PROBENAHMEINSTITUTION) | (1L << PROBENART) | (1L << ZEITBASIS) | (1L << ZEITBASIS_S) | (1L << SOLL_DATUM_UHRZEIT_A) | (1L << SOLL_DATUM_UHRZEIT_E) | (1L << PROBENAHME_DATUM_UHRZEIT_A) | (1L << PROBENAHME_DATUM_UHRZEIT_E) | (1L << UMWELTBEREICH_C) | (1L << UMWELTBEREICH_S) | (1L << DESKRIPTOREN) | (1L << REI_PROGRAMMPUNKT) | (1L << REI_PROGRAMMPUNKTGRUPPE) | (1L << REFERENZ_DATUM_UHRZEIT) | (1L << TESTDATEN) | (1L << SZENARIO) | (1L << SEK_DATENBASIS) | (1L << P_HERKUNFTSLAND_LANG) | (1L << P_HERKUNFTSLAND_KURZ) | (1L << P_HERKUNFTSLAND_S) | (1L << P_GEMEINDESCHLUESSEL) | (1L << P_GEMEINDENAME) | (1L << P_ORTS_ZUSATZKENNZAHL) | (1L << P_KOORDINATEN) | (1L << P_KOORDINATEN_S) | (1L << P_ORTS_ZUSATZCODE))) != 0) || ((((_la - 64)) & ~0x3f) == 0 && ((1L << (_la - 64)) & ((1L << (P_ORTS_ZUSATZTEXT - 64)) | (1L << (P_NUTS_CODE - 64)) | (1L << (P_SITE_ID - 64)) | (1L << (P_SITE_NAME - 64)) | (1L << (P_HOEHE_NN - 64)) | (1L << (P_HOEHE_LAND - 64)) | (1L << (MEHRZWECKFELD - 64)) | (1L << (MESS_DATUM_UHRZEIT - 64)) | (1L << (MESSZEIT_SEKUNDEN - 64)) | (1L << (MESSMETHODE_C - 64)) | (1L << (MESSMETHODE_S - 64)) | (1L << (BEARBEITUNGSSTATUS - 64)) | (1L << (PEP_FLAG - 64)) | (1L << (ERFASSUNG_ABGESCHLOSSEN - 64)) | (1L << (PROBENZUSATZBESCHREIBUNG - 64)) | (1L << (PZB_S - 64)) | (1L << (MESSWERT - 64)) | (1L << (KOMMENTAR - 64)) | (1L << (KOMMENTAR_T - 64)) | (1L << (PROBENKOMMENTAR - 64)) | (1L << (PROBENKOMMENTAR_T - 64)))) != 0) );
+			} while ( (((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << T__2) | (1L << T__3) | (1L << VERSION) | (1L << UEBERTRAGUNGSFORMAT) | (1L << DATENBASIS) | (1L << DATENBASIS_S) | (1L << NETZKENNUNG) | (1L << ERZEUGER) | (1L << STAAT_DER_MESSSTELLE_LANG) | (1L << STAAT_DER_MESSSTELLE_KURZ) | (1L << STAAT_DER_MESSSTELLE_S) | (1L << MESSSTELLE) | (1L << MESSLABOR) | (1L << PROBE_ID) | (1L << MESSUNGS_ID) | (1L << PROBEN_NR) | (1L << HAUPTPROBENNUMMER) | (1L << NEBENPROBENNUMMER) | (1L << MESSPROGRAMM_C) | (1L << MESSPROGRAMM_S) | (1L << MESSPROGRAMM_LAND) | (1L << PROBENAHMEINSTITUTION) | (1L << PROBENART) | (1L << ZEITBASIS) | (1L << ZEITBASIS_S) | (1L << SOLL_DATUM_UHRZEIT_A) | (1L << SOLL_DATUM_UHRZEIT_E) | (1L << PROBENAHME_DATUM_UHRZEIT_A) | (1L << PROBENAHME_DATUM_UHRZEIT_E) | (1L << UMWELTBEREICH_C) | (1L << UMWELTBEREICH_S) | (1L << DESKRIPTOREN) | (1L << REI_PROGRAMMPUNKT) | (1L << REI_PROGRAMMPUNKTGRUPPE) | (1L << REFERENZ_DATUM_UHRZEIT) | (1L << TESTDATEN) | (1L << SZENARIO) | (1L << SEK_DATENBASIS) | (1L << SEK_DATENBASIS_S) | (1L << P_HERKUNFTSLAND_LANG) | (1L << P_HERKUNFTSLAND_KURZ) | (1L << P_HERKUNFTSLAND_S) | (1L << P_GEMEINDESCHLUESSEL) | (1L << P_GEMEINDENAME) | (1L << P_ORTS_ZUSATZKENNZAHL) | (1L << P_KOORDINATEN) | (1L << P_KOORDINATEN_S) | (1L << P_ORTS_ZUSATZCODE))) != 0) || ((((_la - 64)) & ~0x3f) == 0 && ((1L << (_la - 64)) & ((1L << (P_ORTS_ZUSATZTEXT - 64)) | (1L << (P_NUTS_CODE - 64)) | (1L << (P_SITE_ID - 64)) | (1L << (P_SITE_NAME - 64)) | (1L << (P_HOEHE_NN - 64)) | (1L << (P_HOEHE_LAND - 64)) | (1L << (MEHRZWECKFELD - 64)) | (1L << (MESS_DATUM_UHRZEIT - 64)) | (1L << (MESSZEIT_SEKUNDEN - 64)) | (1L << (MESSMETHODE_C - 64)) | (1L << (MESSMETHODE_S - 64)) | (1L << (BEARBEITUNGSSTATUS - 64)) | (1L << (PEP_FLAG - 64)) | (1L << (ERFASSUNG_ABGESCHLOSSEN - 64)) | (1L << (PROBENZUSATZBESCHREIBUNG - 64)) | (1L << (PZB_S - 64)) | (1L << (MESSWERT - 64)) | (1L << (MESSWERT_S - 64)) | (1L << (MESSWERT_I - 64)) | (1L << (MESSWERT_G - 64)) | (1L << (MESSWERT_NWG - 64)) | (1L << (MESSWERT_NWG_S - 64)) | (1L << (MESSWERT_NWG_I - 64)) | (1L << (MESSWERT_NWG_G - 64)) | (1L << (KOMMENTAR - 64)) | (1L << (KOMMENTAR_T - 64)) | (1L << (PROBENKOMMENTAR - 64)) | (1L << (PROBENKOMMENTAR_T - 64)))) != 0) );
 			}
 		}
 		catch (RecognitionException re) {
@@ -420,6 +420,9 @@
 		public Sek_datenbasisContext sek_datenbasis() {
 			return getRuleContext(Sek_datenbasisContext.class,0);
 		}
+		public Sek_datenbasis_sContext sek_datenbasis_s() {
+			return getRuleContext(Sek_datenbasis_sContext.class,0);
+		}
 		public UsContext us() {
 			return getRuleContext(UsContext.class,0);
 		}
@@ -486,7 +489,7 @@
 		ProbedatenContext _localctx = new ProbedatenContext(_ctx, getState());
 		enterRule(_localctx, 6, RULE_probedaten);
 		try {
-			setState(289);
+			setState(290);
 			switch ( getInterpreter().adaptivePredict(_input,3,_ctx) ) {
 			case 1:
 				enterOuterAlt(_localctx, 1);
@@ -674,111 +677,118 @@
 				enterOuterAlt(_localctx, 27);
 				{
 				setState(273);
-				us();
+				sek_datenbasis_s();
 				}
 				break;
 			case 28:
 				enterOuterAlt(_localctx, 28);
 				{
 				setState(274);
-				ph();
+				us();
 				}
 				break;
 			case 29:
 				enterOuterAlt(_localctx, 29);
 				{
 				setState(275);
-				pg();
+				ph();
 				}
 				break;
 			case 30:
 				enterOuterAlt(_localctx, 30);
 				{
 				setState(276);
-				p_orts_zusatzkennzahl();
+				pg();
 				}
 				break;
 			case 31:
 				enterOuterAlt(_localctx, 31);
 				{
 				setState(277);
-				pk();
+				p_orts_zusatzkennzahl();
 				}
 				break;
 			case 32:
 				enterOuterAlt(_localctx, 32);
 				{
 				setState(278);
-				p_orts_zusatzcode();
+				pk();
 				}
 				break;
 			case 33:
 				enterOuterAlt(_localctx, 33);
 				{
 				setState(279);
-				p_orts_zusatztext();
+				p_orts_zusatzcode();
 				}
 				break;
 			case 34:
 				enterOuterAlt(_localctx, 34);
 				{
 				setState(280);
-				p_nuts_code();
+				p_orts_zusatztext();
 				}
 				break;
 			case 35:
 				enterOuterAlt(_localctx, 35);
 				{
 				setState(281);
-				p_site_id();
+				p_nuts_code();
 				}
 				break;
 			case 36:
 				enterOuterAlt(_localctx, 36);
 				{
 				setState(282);
-				p_site_name();
+				p_site_id();
 				}
 				break;
 			case 37:
 				enterOuterAlt(_localctx, 37);
 				{
 				setState(283);
-				p_hoehe_nn();
+				p_site_name();
 				}
 				break;
 			case 38:
 				enterOuterAlt(_localctx, 38);
 				{
 				setState(284);
-				p_hoehe_land();
+				p_hoehe_nn();
 				}
 				break;
 			case 39:
 				enterOuterAlt(_localctx, 39);
 				{
 				setState(285);
-				mehrzweckfeld();
+				p_hoehe_land();
 				}
 				break;
 			case 40:
 				enterOuterAlt(_localctx, 40);
 				{
 				setState(286);
-				messung();
+				mehrzweckfeld();
 				}
 				break;
 			case 41:
 				enterOuterAlt(_localctx, 41);
 				{
 				setState(287);
-				pzb();
+				messung();
 				}
 				break;
 			case 42:
 				enterOuterAlt(_localctx, 42);
 				{
 				setState(288);
+				pzb();
+				}
+				break;
+			case 43:
+				enterOuterAlt(_localctx, 43);
+				{
+				setState(289);
 				pkom();
 				}
 				break;
@@ -827,16 +837,16 @@
 			int _alt;
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(292);
+			setState(293);
 			_la = _input.LA(1);
 			if (_la==T__2) {
 				{
-				setState(291);
+				setState(292);
 				mess_header();
 				}
 			}
 
-			setState(295); 
+			setState(296); 
 			_errHandler.sync(this);
 			_alt = 1;
 			do {
@@ -844,7 +854,7 @@
 				case 1:
 					{
 					{
-					setState(294);
+					setState(295);
 					messungdaten();
 					}
 					}
@@ -852,7 +862,7 @@
 				default:
 					throw new NoViableAltException(this);
 				}
-				setState(297); 
+				setState(298); 
 				_errHandler.sync(this);
 				_alt = getInterpreter().adaptivePredict(_input,5,_ctx);
 			} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
@@ -890,7 +900,7 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(299);
+			setState(300);
 			match(T__2);
 			}
 		}
@@ -930,8 +940,8 @@
 		public Erfassung_abgeschlossenContext erfassung_abgeschlossen() {
 			return getRuleContext(Erfassung_abgeschlossenContext.class,0);
 		}
-		public MesswertContext messwert() {
-			return getRuleContext(MesswertContext.class,0);
+		public MwContext mw() {
+			return getRuleContext(MwContext.class,0);
 		}
 		public Mess_kommentarContext mess_kommentar() {
 			return getRuleContext(Mess_kommentarContext.class,0);
@@ -954,12 +964,12 @@
 		MessungdatenContext _localctx = new MessungdatenContext(_ctx, getState());
 		enterRule(_localctx, 12, RULE_messungdaten);
 		try {
-			setState(311);
+			setState(312);
 			switch (_input.LA(1)) {
 			case MESSUNGS_ID:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(301);
+				setState(302);
 				messungs_id();
 				}
 				break;
@@ -967,21 +977,21 @@
 			case NEBENPROBENNUMMER:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(302);
+				setState(303);
 				pn();
 				}
 				break;
 			case MESS_DATUM_UHRZEIT:
 				enterOuterAlt(_localctx, 3);
 				{
-				setState(303);
+				setState(304);
 				mess_datum_uhrzeit();
 				}
 				break;
 			case MESSZEIT_SEKUNDEN:
 				enterOuterAlt(_localctx, 4);
 				{
-				setState(304);
+				setState(305);
 				messzeit_sekunden();
 				}
 				break;
@@ -989,43 +999,50 @@
 			case MESSMETHODE_S:
 				enterOuterAlt(_localctx, 5);
 				{
-				setState(305);
+				setState(306);
 				mm();
 				}
 				break;
 			case BEARBEITUNGSSTATUS:
 				enterOuterAlt(_localctx, 6);
 				{
-				setState(306);
+				setState(307);
 				bearbeitungsstatus();
 				}
 				break;
 			case PEP_FLAG:
 				enterOuterAlt(_localctx, 7);
 				{
-				setState(307);
+				setState(308);
 				pep_flag();
 				}
 				break;
 			case ERFASSUNG_ABGESCHLOSSEN:
 				enterOuterAlt(_localctx, 8);
 				{
-				setState(308);
+				setState(309);
 				erfassung_abgeschlossen();
 				}
 				break;
 			case MESSWERT:
+			case MESSWERT_S:
+			case MESSWERT_I:
+			case MESSWERT_G:
+			case MESSWERT_NWG:
+			case MESSWERT_NWG_S:
+			case MESSWERT_NWG_I:
+			case MESSWERT_NWG_G:
 				enterOuterAlt(_localctx, 9);
 				{
-				setState(309);
-				messwert();
+				setState(310);
+				mw();
 				}
 				break;
 			case KOMMENTAR:
 			case KOMMENTAR_T:
 				enterOuterAlt(_localctx, 10);
 				{
-				setState(310);
+				setState(311);
 				mess_kommentar();
 				}
 				break;
@@ -1069,19 +1086,19 @@
 		DbContext _localctx = new DbContext(_ctx, getState());
 		enterRule(_localctx, 14, RULE_db);
 		try {
-			setState(315);
+			setState(316);
 			switch (_input.LA(1)) {
 			case DATENBASIS:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(313);
+				setState(314);
 				datenbasis();
 				}
 				break;
 			case DATENBASIS_S:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(314);
+				setState(315);
 				datenbasis_s();
 				}
 				break;
@@ -1125,19 +1142,19 @@
 		MpContext _localctx = new MpContext(_ctx, getState());
 		enterRule(_localctx, 16, RULE_mp);
 		try {
-			setState(319);
+			setState(320);
 			switch (_input.LA(1)) {
 			case MESSPROGRAMM_C:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(317);
+				setState(318);
 				messprogramm_c();
 				}
 				break;
 			case MESSPROGRAMM_S:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(318);
+				setState(319);
 				messprogramm_s();
 				}
 				break;
@@ -1181,19 +1198,19 @@
 		UbContext _localctx = new UbContext(_ctx, getState());
 		enterRule(_localctx, 18, RULE_ub);
 		try {
-			setState(323);
+			setState(324);
 			switch (_input.LA(1)) {
 			case UMWELTBEREICH_C:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(321);
+				setState(322);
 				umweltbereich_c();
 				}
 				break;
 			case UMWELTBEREICH_S:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(322);
+				setState(323);
 				umweltbereich_s();
 				}
 				break;
@@ -1237,19 +1254,19 @@
 		ReiContext _localctx = new ReiContext(_ctx, getState());
 		enterRule(_localctx, 20, RULE_rei);
 		try {
-			setState(327);
+			setState(328);
 			switch (_input.LA(1)) {
 			case REI_PROGRAMMPUNKT:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(325);
+				setState(326);
 				rei_programmpunkt();
 				}
 				break;
 			case REI_PROGRAMMPUNKTGRUPPE:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(326);
+				setState(327);
 				rei_programmpunktgruppe();
 				}
 				break;
@@ -1296,26 +1313,26 @@
 		PhContext _localctx = new PhContext(_ctx, getState());
 		enterRule(_localctx, 22, RULE_ph);
 		try {
-			setState(332);
+			setState(333);
 			switch (_input.LA(1)) {
 			case P_HERKUNFTSLAND_LANG:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(329);
+				setState(330);
 				p_herkunftsland_lang();
 				}
 				break;
 			case P_HERKUNFTSLAND_KURZ:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(330);
+				setState(331);
 				p_herkunftsland_kurz();
 				}
 				break;
 			case P_HERKUNFTSLAND_S:
 				enterOuterAlt(_localctx, 3);
 				{
-				setState(331);
+				setState(332);
 				p_herkunftsland_s();
 				}
 				break;
@@ -1359,19 +1376,19 @@
 		PgContext _localctx = new PgContext(_ctx, getState());
 		enterRule(_localctx, 24, RULE_pg);
 		try {
-			setState(336);
+			setState(337);
 			switch (_input.LA(1)) {
 			case P_GEMEINDESCHLUESSEL:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(334);
+				setState(335);
 				p_gemeindeschluessel();
 				}
 				break;
 			case P_GEMEINDENAME:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(335);
+				setState(336);
 				p_gemeindename();
 				}
 				break;
@@ -1415,19 +1432,19 @@
 		PkContext _localctx = new PkContext(_ctx, getState());
 		enterRule(_localctx, 26, RULE_pk);
 		try {
-			setState(340);
+			setState(341);
 			switch (_input.LA(1)) {
 			case P_KOORDINATEN:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(338);
+				setState(339);
 				p_koordinaten();
 				}
 				break;
 			case P_KOORDINATEN_S:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(339);
+				setState(340);
 				p_koordinaten_s();
 				}
 				break;
@@ -1471,19 +1488,19 @@
 		ZbContext _localctx = new ZbContext(_ctx, getState());
 		enterRule(_localctx, 28, RULE_zb);
 		try {
-			setState(344);
+			setState(345);
 			switch (_input.LA(1)) {
 			case ZEITBASIS:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(342);
+				setState(343);
 				zeitbasis();
 				}
 				break;
 			case ZEITBASIS_S:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(343);
+				setState(344);
 				zeitbasis_s();
 				}
 				break;
@@ -1527,19 +1544,19 @@
 		PzbContext _localctx = new PzbContext(_ctx, getState());
 		enterRule(_localctx, 30, RULE_pzb);
 		try {
-			setState(348);
+			setState(349);
 			switch (_input.LA(1)) {
 			case PROBENZUSATZBESCHREIBUNG:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(346);
+				setState(347);
 				probenzusatzbeschreibung();
 				}
 				break;
 			case PZB_S:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(347);
+				setState(348);
 				pzb_s();
 				}
 				break;
@@ -1583,19 +1600,19 @@
 		PkomContext _localctx = new PkomContext(_ctx, getState());
 		enterRule(_localctx, 32, RULE_pkom);
 		try {
-			setState(352);
+			setState(353);
 			switch (_input.LA(1)) {
 			case PROBENKOMMENTAR:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(350);
+				setState(351);
 				probenkommentar();
 				}
 				break;
 			case PROBENKOMMENTAR_T:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(351);
+				setState(352);
 				probenkommentar_t();
 				}
 				break;
@@ -1642,26 +1659,26 @@
 		SdmContext _localctx = new SdmContext(_ctx, getState());
 		enterRule(_localctx, 34, RULE_sdm);
 		try {
-			setState(357);
+			setState(358);
 			switch (_input.LA(1)) {
 			case STAAT_DER_MESSSTELLE_LANG:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(354);
+				setState(355);
 				staat_der_messstelle_lang();
 				}
 				break;
 			case STAAT_DER_MESSSTELLE_KURZ:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(355);
+				setState(356);
 				staat_der_messstelle_kurz();
 				}
 				break;
 			case STAAT_DER_MESSSTELLE_S:
 				enterOuterAlt(_localctx, 3);
 				{
-				setState(356);
+				setState(357);
 				staat_der_messstelle_s();
 				}
 				break;
@@ -1705,19 +1722,19 @@
 		PnhContext _localctx = new PnhContext(_ctx, getState());
 		enterRule(_localctx, 36, RULE_pnh);
 		try {
-			setState(361);
+			setState(362);
 			switch (_input.LA(1)) {
 			case PROBEN_NR:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(359);
+				setState(360);
 				proben_nr();
 				}
 				break;
 			case HAUPTPROBENNUMMER:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(360);
+				setState(361);
 				hauptprobennummer();
 				}
 				break;
@@ -1761,19 +1778,19 @@
 		MmContext _localctx = new MmContext(_ctx, getState());
 		enterRule(_localctx, 38, RULE_mm);
 		try {
-			setState(365);
+			setState(366);
 			switch (_input.LA(1)) {
 			case MESSMETHODE_C:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(363);
+				setState(364);
 				messmethode_c();
 				}
 				break;
 			case MESSMETHODE_S:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(364);
+				setState(365);
 				messmethode_s();
 				}
 				break;
@@ -1835,61 +1852,61 @@
 		MwContext _localctx = new MwContext(_ctx, getState());
 		enterRule(_localctx, 40, RULE_mw);
 		try {
-			setState(375);
+			setState(376);
 			switch (_input.LA(1)) {
 			case MESSWERT:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(367);
+				setState(368);
 				messwert();
 				}
 				break;
 			case MESSWERT_S:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(368);
+				setState(369);
 				messwert_s();
 				}
 				break;
 			case MESSWERT_I:
 				enterOuterAlt(_localctx, 3);
 				{
-				setState(369);
+				setState(370);
 				messwert_i();
 				}
 				break;
 			case MESSWERT_G:
 				enterOuterAlt(_localctx, 4);
 				{
-				setState(370);
+				setState(371);
 				messwert_g();
 				}
 				break;
 			case MESSWERT_NWG:
 				enterOuterAlt(_localctx, 5);
 				{
-				setState(371);
+				setState(372);
 				messwert_nwg();
 				}
 				break;
 			case MESSWERT_NWG_S:
 				enterOuterAlt(_localctx, 6);
 				{
-				setState(372);
+				setState(373);
 				messwert_nwg_s();
 				}
 				break;
 			case MESSWERT_NWG_I:
 				enterOuterAlt(_localctx, 7);
 				{
-				setState(373);
+				setState(374);
 				messwert_nwg_i();
 				}
 				break;
 			case MESSWERT_NWG_G:
 				enterOuterAlt(_localctx, 8);
 				{
-				setState(374);
+				setState(375);
 				messwert_nwg_g();
 				}
 				break;
@@ -1933,19 +1950,19 @@
 		Mess_kommentarContext _localctx = new Mess_kommentarContext(_ctx, getState());
 		enterRule(_localctx, 42, RULE_mess_kommentar);
 		try {
-			setState(379);
+			setState(380);
 			switch (_input.LA(1)) {
 			case KOMMENTAR:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(377);
+				setState(378);
 				kommentar();
 				}
 				break;
 			case KOMMENTAR_T:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(378);
+				setState(379);
 				kommentar_t();
 				}
 				break;
@@ -1989,19 +2006,19 @@
 		PnContext _localctx = new PnContext(_ctx, getState());
 		enterRule(_localctx, 44, RULE_pn);
 		try {
-			setState(383);
+			setState(384);
 			switch (_input.LA(1)) {
 			case PROBEN_NR:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(381);
+				setState(382);
 				proben_nr();
 				}
 				break;
 			case NEBENPROBENNUMMER:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(382);
+				setState(383);
 				nebenprobennummer();
 				}
 				break;
@@ -2048,19 +2065,19 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(385);
+			setState(386);
 			match(T__3);
-			setState(389);
+			setState(390);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while ((((_la) & ~0x3f) == 0 && ((1L << _la) & ((1L << U_HERKUNFTSLAND_LANG) | (1L << U_HERKUNFTSLAND_KURZ) | (1L << U_HERKUNFTSLAND_S) | (1L << U_GEMEINDESCHLUESSEL) | (1L << U_GEMEINDENAME) | (1L << U_ORTS_ZUSATZKENNZAHL) | (1L << U_KOORDINATEN) | (1L << U_KOORDINATEN_S) | (1L << U_ORTS_ZUSATZCODE) | (1L << U_ORTS_ZUSATZTEXT) | (1L << U_NUTS_CODE))) != 0)) {
 				{
 				{
-				setState(386);
+				setState(387);
 				ursprungsortdaten();
 				}
 				}
-				setState(391);
+				setState(392);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
@@ -2117,14 +2134,14 @@
 		UrsprungsortdatenContext _localctx = new UrsprungsortdatenContext(_ctx, getState());
 		enterRule(_localctx, 48, RULE_ursprungsortdaten);
 		try {
-			setState(399);
+			setState(400);
 			switch (_input.LA(1)) {
 			case U_HERKUNFTSLAND_LANG:
 			case U_HERKUNFTSLAND_KURZ:
 			case U_HERKUNFTSLAND_S:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(392);
+				setState(393);
 				uh();
 				}
 				break;
@@ -2132,14 +2149,14 @@
 			case U_GEMEINDENAME:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(393);
+				setState(394);
 				ug();
 				}
 				break;
 			case U_ORTS_ZUSATZKENNZAHL:
 				enterOuterAlt(_localctx, 3);
 				{
-				setState(394);
+				setState(395);
 				u_orts_zusatzkennzahl();
 				}
 				break;
@@ -2147,28 +2164,28 @@
 			case U_KOORDINATEN_S:
 				enterOuterAlt(_localctx, 4);
 				{
-				setState(395);
+				setState(396);
 				uk();
 				}
 				break;
 			case U_ORTS_ZUSATZCODE:
 				enterOuterAlt(_localctx, 5);
 				{
-				setState(396);
+				setState(397);
 				u_orts_zusatzcode();
 				}
 				break;
 			case U_ORTS_ZUSATZTEXT:
 				enterOuterAlt(_localctx, 6);
 				{
-				setState(397);
+				setState(398);
 				u_orts_zusatztext();
 				}
 				break;
 			case U_NUTS_CODE:
 				enterOuterAlt(_localctx, 7);
 				{
-				setState(398);
+				setState(399);
 				u_nuts_code();
 				}
 				break;
@@ -2215,26 +2232,26 @@
 		UhContext _localctx = new UhContext(_ctx, getState());
 		enterRule(_localctx, 50, RULE_uh);
 		try {
-			setState(404);
+			setState(405);
 			switch (_input.LA(1)) {
 			case U_HERKUNFTSLAND_LANG:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(401);
+				setState(402);
 				u_herkunftsland_lang();
 				}
 				break;
 			case U_HERKUNFTSLAND_KURZ:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(402);
+				setState(403);
 				u_herkunftsland_kurz();
 				}
 				break;
 			case U_HERKUNFTSLAND_S:
 				enterOuterAlt(_localctx, 3);
 				{
-				setState(403);
+				setState(404);
 				u_herkunftsland_s();
 				}
 				break;
@@ -2278,19 +2295,19 @@
 		UgContext _localctx = new UgContext(_ctx, getState());
 		enterRule(_localctx, 52, RULE_ug);
 		try {
-			setState(408);
+			setState(409);
 			switch (_input.LA(1)) {
 			case U_GEMEINDESCHLUESSEL:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(406);
+				setState(407);
 				u_gemeindeschluessel();
 				}
 				break;
 			case U_GEMEINDENAME:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(407);
+				setState(408);
 				u_gemeindename();
 				}
 				break;
@@ -2334,19 +2351,19 @@
 		UkContext _localctx = new UkContext(_ctx, getState());
 		enterRule(_localctx, 54, RULE_uk);
 		try {
-			setState(412);
+			setState(413);
 			switch (_input.LA(1)) {
 			case U_KOORDINATEN:
 				enterOuterAlt(_localctx, 1);
 				{
-				setState(410);
+				setState(411);
 				u_koordinaten();
 				}
 				break;
 			case U_KOORDINATEN_S:
 				enterOuterAlt(_localctx, 2);
 				{
-				setState(411);
+				setState(412);
 				u_koordinaten_s();
 				}
 				break;
@@ -2390,9 +2407,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(414);
+			setState(415);
 			match(VERSION);
-			setState(415);
+			setState(416);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -2437,9 +2454,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(417);
+			setState(418);
 			match(UEBERTRAGUNGSFORMAT);
-			setState(418);
+			setState(419);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -2484,9 +2501,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(420);
+			setState(421);
 			match(DATENBASIS);
-			setState(421);
+			setState(422);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -2529,9 +2546,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(423);
+			setState(424);
 			match(DATENBASIS_S);
-			setState(424);
+			setState(425);
 			match(STRING);
 			}
 		}
@@ -2571,9 +2588,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(426);
+			setState(427);
 			match(NETZKENNUNG);
-			setState(427);
+			setState(428);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -2618,9 +2635,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(429);
+			setState(430);
 			match(ERZEUGER);
-			setState(430);
+			setState(431);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -2665,9 +2682,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(432);
+			setState(433);
 			match(STAAT_DER_MESSSTELLE_LANG);
-			setState(433);
+			setState(434);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -2712,9 +2729,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(435);
+			setState(436);
 			match(STAAT_DER_MESSSTELLE_KURZ);
-			setState(436);
+			setState(437);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -2757,9 +2774,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(438);
+			setState(439);
 			match(STAAT_DER_MESSSTELLE_S);
-			setState(439);
+			setState(440);
 			match(STRING);
 			}
 		}
@@ -2799,9 +2816,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(441);
+			setState(442);
 			match(MESSSTELLE);
-			setState(442);
+			setState(443);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -2846,9 +2863,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(444);
+			setState(445);
 			match(MESSLABOR);
-			setState(445);
+			setState(446);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -2893,9 +2910,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(447);
+			setState(448);
 			match(PROBE_ID);
-			setState(448);
+			setState(449);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -2938,9 +2955,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(450);
+			setState(451);
 			match(MESSUNGS_ID);
-			setState(451);
+			setState(452);
 			match(STRING);
 			}
 		}
@@ -2980,9 +2997,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(453);
+			setState(454);
 			match(PROBEN_NR);
-			setState(454);
+			setState(455);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3027,9 +3044,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(456);
+			setState(457);
 			match(HAUPTPROBENNUMMER);
-			setState(457);
+			setState(458);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3074,9 +3091,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(459);
+			setState(460);
 			match(NEBENPROBENNUMMER);
-			setState(460);
+			setState(461);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3121,9 +3138,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(462);
+			setState(463);
 			match(MESSPROGRAMM_C);
-			setState(463);
+			setState(464);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3168,9 +3185,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(465);
+			setState(466);
 			match(MESSPROGRAMM_S);
-			setState(466);
+			setState(467);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3215,9 +3232,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(468);
+			setState(469);
 			match(MESSPROGRAMM_LAND);
-			setState(469);
+			setState(470);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3262,9 +3279,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(471);
+			setState(472);
 			match(PROBENAHMEINSTITUTION);
-			setState(472);
+			setState(473);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3309,9 +3326,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(474);
+			setState(475);
 			match(PROBENART);
-			setState(475);
+			setState(476);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3356,9 +3373,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(477);
+			setState(478);
 			match(ZEITBASIS);
-			setState(478);
+			setState(479);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3401,9 +3418,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(480);
+			setState(481);
 			match(ZEITBASIS_S);
-			setState(481);
+			setState(482);
 			match(STRING);
 			}
 		}
@@ -3445,25 +3462,25 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(483);
+			setState(484);
 			match(SOLL_DATUM_UHRZEIT_A);
-			setState(484);
+			setState(485);
 			match(STRING);
-			setState(488);
+			setState(489);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(485);
+				setState(486);
 				match(T__4);
 				}
 				}
-				setState(490);
+				setState(491);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(491);
+			setState(492);
 			match(STRING);
 			}
 		}
@@ -3505,25 +3522,25 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(493);
+			setState(494);
 			match(SOLL_DATUM_UHRZEIT_E);
-			setState(494);
+			setState(495);
 			match(STRING);
-			setState(498);
+			setState(499);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(495);
+				setState(496);
 				match(T__4);
 				}
 				}
-				setState(500);
+				setState(501);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(501);
+			setState(502);
 			match(STRING);
 			}
 		}
@@ -3565,25 +3582,25 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(503);
+			setState(504);
 			match(URSPRUNGS_DATUM_UHRZEIT);
-			setState(504);
+			setState(505);
 			match(STRING);
-			setState(508);
+			setState(509);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(505);
+				setState(506);
 				match(T__4);
 				}
 				}
-				setState(510);
+				setState(511);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(511);
+			setState(512);
 			match(STRING);
 			}
 		}
@@ -3625,25 +3642,25 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(513);
+			setState(514);
 			match(PROBENAHME_DATUM_UHRZEIT_A);
-			setState(514);
+			setState(515);
 			match(STRING);
-			setState(518);
+			setState(519);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(515);
+				setState(516);
 				match(T__4);
 				}
 				}
-				setState(520);
+				setState(521);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(521);
+			setState(522);
 			match(STRING);
 			}
 		}
@@ -3685,25 +3702,25 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(523);
+			setState(524);
 			match(PROBENAHME_DATUM_UHRZEIT_E);
-			setState(524);
+			setState(525);
 			match(STRING);
-			setState(528);
+			setState(529);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(525);
+				setState(526);
 				match(T__4);
 				}
 				}
-				setState(530);
+				setState(531);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(531);
+			setState(532);
 			match(STRING);
 			}
 		}
@@ -3743,9 +3760,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(533);
+			setState(534);
 			match(UMWELTBEREICH_C);
-			setState(534);
+			setState(535);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3790,9 +3807,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(536);
+			setState(537);
 			match(UMWELTBEREICH_S);
-			setState(537);
+			setState(538);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3837,9 +3854,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(539);
+			setState(540);
 			match(DESKRIPTOREN);
-			setState(540);
+			setState(541);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3884,9 +3901,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(542);
+			setState(543);
 			match(REI_PROGRAMMPUNKT);
-			setState(543);
+			setState(544);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3931,9 +3948,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(545);
+			setState(546);
 			match(REI_PROGRAMMPUNKTGRUPPE);
-			setState(546);
+			setState(547);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -3980,25 +3997,25 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(548);
+			setState(549);
 			match(REFERENZ_DATUM_UHRZEIT);
-			setState(549);
+			setState(550);
 			match(STRING);
-			setState(553);
+			setState(554);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(550);
+				setState(551);
 				match(T__4);
 				}
 				}
-				setState(555);
+				setState(556);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(556);
+			setState(557);
 			match(STRING);
 			}
 		}
@@ -4036,9 +4053,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(558);
+			setState(559);
 			match(TESTDATEN);
-			setState(559);
+			setState(560);
 			match(STRING);
 			}
 		}
@@ -4078,9 +4095,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(561);
+			setState(562);
 			match(SZENARIO);
-			setState(562);
+			setState(563);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -4125,9 +4142,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(564);
+			setState(565);
 			match(SEK_DATENBASIS);
-			setState(565);
+			setState(566);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -4170,9 +4187,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(567);
+			setState(568);
 			match(SEK_DATENBASIS_S);
-			setState(568);
+			setState(569);
 			match(STRING);
 			}
 		}
@@ -4212,9 +4229,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(570);
+			setState(571);
 			match(U_HERKUNFTSLAND_LANG);
-			setState(571);
+			setState(572);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -4259,9 +4276,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(573);
+			setState(574);
 			match(U_HERKUNFTSLAND_KURZ);
-			setState(574);
+			setState(575);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -4304,9 +4321,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(576);
+			setState(577);
 			match(U_HERKUNFTSLAND_S);
-			setState(577);
+			setState(578);
 			match(STRING);
 			}
 		}
@@ -4344,9 +4361,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(579);
+			setState(580);
 			match(U_GEMEINDESCHLUESSEL);
-			setState(580);
+			setState(581);
 			match(STRING);
 			}
 		}
@@ -4386,9 +4403,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(582);
+			setState(583);
 			match(U_GEMEINDENAME);
-			setState(583);
+			setState(584);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -4431,9 +4448,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(585);
+			setState(586);
 			match(U_ORTS_ZUSATZKENNZAHL);
-			setState(586);
+			setState(587);
 			match(STRING);
 			}
 		}
@@ -4479,51 +4496,51 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(588);
+			setState(589);
 			match(U_KOORDINATEN);
-			setState(589);
+			setState(590);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(593);
+			setState(594);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(590);
+				setState(591);
 				match(T__4);
 				}
 				}
-				setState(595);
+				setState(596);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(596);
+			setState(597);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(600);
+			setState(601);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(597);
+				setState(598);
 				match(T__4);
 				}
 				}
-				setState(602);
+				setState(603);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(603);
+			setState(604);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -4574,46 +4591,46 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(605);
+			setState(606);
 			match(U_KOORDINATEN_S);
-			setState(606);
+			setState(607);
 			match(STRING);
-			setState(610);
+			setState(611);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(607);
+				setState(608);
 				match(T__4);
 				}
 				}
-				setState(612);
+				setState(613);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(613);
+			setState(614);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(617);
+			setState(618);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(614);
+				setState(615);
 				match(T__4);
 				}
 				}
-				setState(619);
+				setState(620);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(620);
+			setState(621);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -4658,9 +4675,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(622);
+			setState(623);
 			match(U_ORTS_ZUSATZCODE);
-			setState(623);
+			setState(624);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -4705,9 +4722,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(625);
+			setState(626);
 			match(U_ORTS_ZUSATZTEXT);
-			setState(626);
+			setState(627);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -4729,6 +4746,7 @@
 
 	public static class U_nuts_codeContext extends ParserRuleContext {
 		public TerminalNode U_NUTS_CODE() { return getToken(LafParser.U_NUTS_CODE, 0); }
+		public TerminalNode STRING_ESC() { return getToken(LafParser.STRING_ESC, 0); }
 		public TerminalNode STRING() { return getToken(LafParser.STRING, 0); }
 		public U_nuts_codeContext(ParserRuleContext parent, int invokingState) {
 			super(parent, invokingState);
@@ -4747,13 +4765,19 @@
 	public final U_nuts_codeContext u_nuts_code() throws RecognitionException {
 		U_nuts_codeContext _localctx = new U_nuts_codeContext(_ctx, getState());
 		enterRule(_localctx, 152, RULE_u_nuts_code);
+		int _la;
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(628);
+			setState(629);
 			match(U_NUTS_CODE);
-			setState(629);
-			match(STRING);
+			setState(630);
+			_la = _input.LA(1);
+			if ( !(_la==STRING_ESC || _la==STRING) ) {
+			_errHandler.recoverInline(this);
+			} else {
+				consume();
+			}
 			}
 		}
 		catch (RecognitionException re) {
@@ -4792,9 +4816,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(631);
+			setState(632);
 			match(P_HERKUNFTSLAND_LANG);
-			setState(632);
+			setState(633);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -4839,9 +4863,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(634);
+			setState(635);
 			match(P_HERKUNFTSLAND_KURZ);
-			setState(635);
+			setState(636);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -4884,9 +4908,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(637);
+			setState(638);
 			match(P_HERKUNFTSLAND_S);
-			setState(638);
+			setState(639);
 			match(STRING);
 			}
 		}
@@ -4924,9 +4948,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(640);
+			setState(641);
 			match(P_GEMEINDESCHLUESSEL);
-			setState(641);
+			setState(642);
 			match(STRING);
 			}
 		}
@@ -4966,9 +4990,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(643);
+			setState(644);
 			match(P_GEMEINDENAME);
-			setState(644);
+			setState(645);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -5011,9 +5035,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(646);
+			setState(647);
 			match(P_ORTS_ZUSATZKENNZAHL);
-			setState(647);
+			setState(648);
 			match(STRING);
 			}
 		}
@@ -5059,51 +5083,51 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(649);
+			setState(650);
 			match(P_KOORDINATEN);
-			setState(650);
+			setState(651);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(654);
+			setState(655);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(651);
+				setState(652);
 				match(T__4);
 				}
 				}
-				setState(656);
+				setState(657);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(657);
+			setState(658);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(661);
+			setState(662);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(658);
+				setState(659);
 				match(T__4);
 				}
 				}
-				setState(663);
+				setState(664);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(664);
+			setState(665);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -5154,46 +5178,46 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(666);
+			setState(667);
 			match(P_KOORDINATEN_S);
-			setState(667);
+			setState(668);
 			match(STRING);
-			setState(671);
+			setState(672);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(668);
+				setState(669);
 				match(T__4);
 				}
 				}
-				setState(673);
+				setState(674);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(674);
+			setState(675);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(678);
+			setState(679);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(675);
+				setState(676);
 				match(T__4);
 				}
 				}
-				setState(680);
+				setState(681);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(681);
+			setState(682);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -5238,9 +5262,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(683);
+			setState(684);
 			match(P_ORTS_ZUSATZCODE);
-			setState(684);
+			setState(685);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -5285,9 +5309,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(686);
+			setState(687);
 			match(P_ORTS_ZUSATZTEXT);
-			setState(687);
+			setState(688);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -5309,6 +5333,7 @@
 
 	public static class P_nuts_codeContext extends ParserRuleContext {
 		public TerminalNode P_NUTS_CODE() { return getToken(LafParser.P_NUTS_CODE, 0); }
+		public TerminalNode STRING_ESC() { return getToken(LafParser.STRING_ESC, 0); }
 		public TerminalNode STRING() { return getToken(LafParser.STRING, 0); }
 		public P_nuts_codeContext(ParserRuleContext parent, int invokingState) {
 			super(parent, invokingState);
@@ -5327,13 +5352,19 @@
 	public final P_nuts_codeContext p_nuts_code() throws RecognitionException {
 		P_nuts_codeContext _localctx = new P_nuts_codeContext(_ctx, getState());
 		enterRule(_localctx, 174, RULE_p_nuts_code);
+		int _la;
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(689);
+			setState(690);
 			match(P_NUTS_CODE);
-			setState(690);
-			match(STRING);
+			setState(691);
+			_la = _input.LA(1);
+			if ( !(_la==STRING_ESC || _la==STRING) ) {
+			_errHandler.recoverInline(this);
+			} else {
+				consume();
+			}
 			}
 		}
 		catch (RecognitionException re) {
@@ -5372,9 +5403,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(692);
+			setState(693);
 			match(P_SITE_ID);
-			setState(693);
+			setState(694);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -5419,9 +5450,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(695);
+			setState(696);
 			match(P_SITE_NAME);
-			setState(696);
+			setState(697);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -5464,9 +5495,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(698);
+			setState(699);
 			match(P_HOEHE_NN);
-			setState(699);
+			setState(700);
 			match(STRING);
 			}
 		}
@@ -5504,9 +5535,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(701);
+			setState(702);
 			match(P_HOEHE_LAND);
-			setState(702);
+			setState(703);
 			match(STRING);
 			}
 		}
@@ -5546,9 +5577,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(704);
+			setState(705);
 			match(MEHRZWECKFELD);
-			setState(705);
+			setState(706);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -5595,25 +5626,25 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(707);
+			setState(708);
 			match(MESS_DATUM_UHRZEIT);
-			setState(708);
+			setState(709);
 			match(STRING);
-			setState(712);
+			setState(713);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(709);
+				setState(710);
 				match(T__4);
 				}
 				}
-				setState(714);
+				setState(715);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(715);
+			setState(716);
 			match(STRING);
 			}
 		}
@@ -5651,9 +5682,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(717);
+			setState(718);
 			match(MESSZEIT_SEKUNDEN);
-			setState(718);
+			setState(719);
 			match(STRING);
 			}
 		}
@@ -5693,9 +5724,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(720);
+			setState(721);
 			match(MESSMETHODE_C);
-			setState(721);
+			setState(722);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -5740,9 +5771,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(723);
+			setState(724);
 			match(MESSMETHODE_S);
-			setState(724);
+			setState(725);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -5787,9 +5818,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(726);
+			setState(727);
 			match(BEARBEITUNGSSTATUS);
-			setState(727);
+			setState(728);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -5832,9 +5863,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(729);
+			setState(730);
 			match(PEP_FLAG);
-			setState(730);
+			setState(731);
 			match(STRING);
 			}
 		}
@@ -5872,9 +5903,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(732);
+			setState(733);
 			match(ERFASSUNG_ABGESCHLOSSEN);
-			setState(733);
+			setState(734);
 			match(STRING);
 			}
 		}
@@ -5920,67 +5951,67 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(735);
+			setState(736);
 			match(PROBENZUSATZBESCHREIBUNG);
-			setState(736);
+			setState(737);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(740);
+			setState(741);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(737);
+				setState(738);
 				match(T__4);
 				}
 				}
-				setState(742);
+				setState(743);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(743);
+			setState(744);
 			match(STRING);
-			setState(747);
+			setState(748);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(744);
+				setState(745);
 				match(T__4);
 				}
 				}
-				setState(749);
+				setState(750);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(750);
+			setState(751);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(754);
+			setState(755);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(751);
+				setState(752);
 				match(T__4);
 				}
 				}
-				setState(756);
+				setState(757);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(757);
+			setState(758);
 			match(STRING);
 			}
 		}
@@ -6023,62 +6054,62 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(759);
+			setState(760);
 			match(PZB_S);
-			setState(760);
+			setState(761);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(764);
-			_errHandler.sync(this);
-			_la = _input.LA(1);
-			while (_la==T__4) {
-				{
-				{
-				setState(761);
-				match(T__4);
-				}
-				}
-				setState(766);
-				_errHandler.sync(this);
-				_la = _input.LA(1);
-			}
-			setState(767);
-			match(STRING);
-			setState(771);
+			setState(765);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(768);
+				setState(762);
 				match(T__4);
 				}
 				}
-				setState(773);
+				setState(767);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(774);
+			setState(768);
 			match(STRING);
-			setState(778);
+			setState(772);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(775);
+				setState(769);
 				match(T__4);
 				}
 				}
-				setState(780);
+				setState(774);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(781);
+			setState(775);
+			match(STRING);
+			setState(779);
+			_errHandler.sync(this);
+			_la = _input.LA(1);
+			while (_la==T__4) {
+				{
+				{
+				setState(776);
+				match(T__4);
+				}
+				}
+				setState(781);
+				_errHandler.sync(this);
+				_la = _input.LA(1);
+			}
+			setState(782);
 			match(STRING);
 			}
 		}
@@ -6124,71 +6155,71 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(783);
+			setState(784);
 			match(MESSWERT);
-			setState(784);
+			setState(785);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(788);
+			setState(789);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(785);
+				setState(786);
 				match(T__4);
 				}
 				}
-				setState(790);
+				setState(791);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(791);
+			setState(792);
 			match(STRING);
-			setState(795);
+			setState(796);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(792);
+				setState(793);
 				match(T__4);
 				}
 				}
-				setState(797);
+				setState(798);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(798);
+			setState(799);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(802);
+			setState(803);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(799);
+				setState(800);
 				match(T__4);
 				}
 				}
-				setState(804);
+				setState(805);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(806);
+			setState(807);
 			_la = _input.LA(1);
 			if (_la==STRING) {
 				{
-				setState(805);
+				setState(806);
 				match(STRING);
 				}
 			}
@@ -6233,61 +6264,61 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(808);
+			setState(809);
 			match(MESSWERT_S);
-			setState(809);
+			setState(810);
 			match(STRING);
-			setState(813);
-			_errHandler.sync(this);
-			_la = _input.LA(1);
-			while (_la==T__4) {
-				{
-				{
-				setState(810);
-				match(T__4);
-				}
-				}
-				setState(815);
-				_errHandler.sync(this);
-				_la = _input.LA(1);
-			}
-			setState(816);
-			match(STRING);
-			setState(820);
+			setState(814);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(817);
+				setState(811);
 				match(T__4);
 				}
 				}
-				setState(822);
+				setState(816);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(823);
+			setState(817);
 			match(STRING);
-			setState(827);
+			setState(821);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(824);
+				setState(818);
 				match(T__4);
 				}
 				}
-				setState(829);
+				setState(823);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(831);
+			setState(824);
+			match(STRING);
+			setState(828);
+			_errHandler.sync(this);
+			_la = _input.LA(1);
+			while (_la==T__4) {
+				{
+				{
+				setState(825);
+				match(T__4);
+				}
+				}
+				setState(830);
+				_errHandler.sync(this);
+				_la = _input.LA(1);
+			}
+			setState(832);
 			_la = _input.LA(1);
 			if (_la==STRING) {
 				{
-				setState(830);
+				setState(831);
 				match(STRING);
 				}
 			}
@@ -6336,140 +6367,140 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(833);
-			match(MESSWERT_I);
 			setState(834);
-			_la = _input.LA(1);
-			if ( !(_la==STRING_ESC || _la==STRING) ) {
-			_errHandler.recoverInline(this);
-			} else {
-				consume();
-			}
-			setState(838);
-			_errHandler.sync(this);
-			_la = _input.LA(1);
-			while (_la==T__4) {
-				{
-				{
-				setState(835);
-				match(T__4);
-				}
-				}
-				setState(840);
-				_errHandler.sync(this);
-				_la = _input.LA(1);
-			}
-			setState(841);
-			match(STRING);
-			setState(845);
-			_errHandler.sync(this);
-			_la = _input.LA(1);
-			while (_la==T__4) {
-				{
-				{
-				setState(842);
-				match(T__4);
-				}
-				}
-				setState(847);
-				_errHandler.sync(this);
-				_la = _input.LA(1);
-			}
-			setState(848);
+			match(MESSWERT_I);
+			setState(835);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(852);
+			setState(839);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(849);
+				setState(836);
 				match(T__4);
 				}
 				}
-				setState(854);
+				setState(841);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(862);
+			setState(842);
+			match(STRING);
+			setState(846);
+			_errHandler.sync(this);
+			_la = _input.LA(1);
+			while (_la==T__4) {
+				{
+				{
+				setState(843);
+				match(T__4);
+				}
+				}
+				setState(848);
+				_errHandler.sync(this);
+				_la = _input.LA(1);
+			}
+			setState(849);
+			_la = _input.LA(1);
+			if ( !(_la==STRING_ESC || _la==STRING) ) {
+			_errHandler.recoverInline(this);
+			} else {
+				consume();
+			}
+			setState(853);
+			_errHandler.sync(this);
+			_la = _input.LA(1);
+			while (_la==T__4) {
+				{
+				{
+				setState(850);
+				match(T__4);
+				}
+				}
+				setState(855);
+				_errHandler.sync(this);
+				_la = _input.LA(1);
+			}
+			setState(863);
 			switch ( getInterpreter().adaptivePredict(_input,61,_ctx) ) {
 			case 1:
 				{
-				setState(855);
+				setState(856);
 				match(STRING);
-				setState(859);
+				setState(860);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(856);
+					setState(857);
 					match(T__4);
 					}
 					}
-					setState(861);
+					setState(862);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(871);
+			setState(872);
 			switch ( getInterpreter().adaptivePredict(_input,63,_ctx) ) {
 			case 1:
 				{
-				setState(864);
+				setState(865);
 				match(STRING);
-				setState(868);
+				setState(869);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(865);
+					setState(866);
 					match(T__4);
 					}
 					}
-					setState(870);
+					setState(871);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(880);
+			setState(881);
 			switch ( getInterpreter().adaptivePredict(_input,65,_ctx) ) {
 			case 1:
 				{
-				setState(873);
+				setState(874);
 				match(STRING);
-				setState(877);
+				setState(878);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(874);
+					setState(875);
 					match(T__4);
 					}
 					}
-					setState(879);
+					setState(880);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(883);
+			setState(884);
 			_la = _input.LA(1);
 			if (_la==STRING_ESC || _la==STRING) {
 				{
-				setState(882);
+				setState(883);
 				_la = _input.LA(1);
 				if ( !(_la==STRING_ESC || _la==STRING) ) {
 				_errHandler.recoverInline(this);
@@ -6523,140 +6554,140 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(885);
-			match(MESSWERT_G);
 			setState(886);
-			_la = _input.LA(1);
-			if ( !(_la==STRING_ESC || _la==STRING) ) {
-			_errHandler.recoverInline(this);
-			} else {
-				consume();
-			}
-			setState(890);
-			_errHandler.sync(this);
-			_la = _input.LA(1);
-			while (_la==T__4) {
-				{
-				{
-				setState(887);
-				match(T__4);
-				}
-				}
-				setState(892);
-				_errHandler.sync(this);
-				_la = _input.LA(1);
-			}
-			setState(893);
-			match(STRING);
-			setState(897);
-			_errHandler.sync(this);
-			_la = _input.LA(1);
-			while (_la==T__4) {
-				{
-				{
-				setState(894);
-				match(T__4);
-				}
-				}
-				setState(899);
-				_errHandler.sync(this);
-				_la = _input.LA(1);
-			}
-			setState(900);
+			match(MESSWERT_G);
+			setState(887);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(904);
+			setState(891);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(901);
+				setState(888);
 				match(T__4);
 				}
 				}
-				setState(906);
+				setState(893);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(914);
+			setState(894);
+			match(STRING);
+			setState(898);
+			_errHandler.sync(this);
+			_la = _input.LA(1);
+			while (_la==T__4) {
+				{
+				{
+				setState(895);
+				match(T__4);
+				}
+				}
+				setState(900);
+				_errHandler.sync(this);
+				_la = _input.LA(1);
+			}
+			setState(901);
+			_la = _input.LA(1);
+			if ( !(_la==STRING_ESC || _la==STRING) ) {
+			_errHandler.recoverInline(this);
+			} else {
+				consume();
+			}
+			setState(905);
+			_errHandler.sync(this);
+			_la = _input.LA(1);
+			while (_la==T__4) {
+				{
+				{
+				setState(902);
+				match(T__4);
+				}
+				}
+				setState(907);
+				_errHandler.sync(this);
+				_la = _input.LA(1);
+			}
+			setState(915);
 			switch ( getInterpreter().adaptivePredict(_input,71,_ctx) ) {
 			case 1:
 				{
-				setState(907);
+				setState(908);
 				match(STRING);
-				setState(911);
+				setState(912);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(908);
+					setState(909);
 					match(T__4);
 					}
 					}
-					setState(913);
+					setState(914);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(923);
+			setState(924);
 			switch ( getInterpreter().adaptivePredict(_input,73,_ctx) ) {
 			case 1:
 				{
-				setState(916);
+				setState(917);
 				match(STRING);
-				setState(920);
+				setState(921);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(917);
+					setState(918);
 					match(T__4);
 					}
 					}
-					setState(922);
+					setState(923);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(932);
+			setState(933);
 			switch ( getInterpreter().adaptivePredict(_input,75,_ctx) ) {
 			case 1:
 				{
-				setState(925);
+				setState(926);
 				match(STRING);
-				setState(929);
+				setState(930);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(926);
+					setState(927);
 					match(T__4);
 					}
 					}
-					setState(931);
+					setState(932);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(935);
+			setState(936);
 			_la = _input.LA(1);
 			if (_la==STRING_ESC || _la==STRING) {
 				{
-				setState(934);
+				setState(935);
 				_la = _input.LA(1);
 				if ( !(_la==STRING_ESC || _la==STRING) ) {
 				_errHandler.recoverInline(this);
@@ -6710,94 +6741,94 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(937);
+			setState(938);
 			match(MESSWERT_NWG);
-			setState(938);
+			setState(939);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(942);
+			setState(943);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(939);
+				setState(940);
 				match(T__4);
 				}
 				}
-				setState(944);
+				setState(945);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(945);
+			setState(946);
 			match(STRING);
-			setState(949);
+			setState(950);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(946);
+				setState(947);
 				match(T__4);
 				}
 				}
-				setState(951);
+				setState(952);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(952);
+			setState(953);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(956);
+			setState(957);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(953);
+				setState(954);
 				match(T__4);
 				}
 				}
-				setState(958);
+				setState(959);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(966);
+			setState(967);
 			switch ( getInterpreter().adaptivePredict(_input,81,_ctx) ) {
 			case 1:
 				{
-				setState(959);
+				setState(960);
 				match(STRING);
-				setState(963);
+				setState(964);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(960);
+					setState(961);
 					match(T__4);
 					}
 					}
-					setState(965);
+					setState(966);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(969);
+			setState(970);
 			_la = _input.LA(1);
 			if (_la==STRING) {
 				{
-				setState(968);
+				setState(969);
 				match(STRING);
 				}
 			}
@@ -6842,84 +6873,84 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(971);
+			setState(972);
 			match(MESSWERT_NWG_S);
-			setState(972);
+			setState(973);
 			match(STRING);
-			setState(976);
-			_errHandler.sync(this);
-			_la = _input.LA(1);
-			while (_la==T__4) {
-				{
-				{
-				setState(973);
-				match(T__4);
-				}
-				}
-				setState(978);
-				_errHandler.sync(this);
-				_la = _input.LA(1);
-			}
-			setState(979);
-			match(STRING);
-			setState(983);
+			setState(977);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(980);
+				setState(974);
 				match(T__4);
 				}
 				}
-				setState(985);
+				setState(979);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(986);
+			setState(980);
 			match(STRING);
-			setState(990);
+			setState(984);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(987);
+				setState(981);
 				match(T__4);
 				}
 				}
-				setState(992);
+				setState(986);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(1000);
+			setState(987);
+			match(STRING);
+			setState(991);
+			_errHandler.sync(this);
+			_la = _input.LA(1);
+			while (_la==T__4) {
+				{
+				{
+				setState(988);
+				match(T__4);
+				}
+				}
+				setState(993);
+				_errHandler.sync(this);
+				_la = _input.LA(1);
+			}
+			setState(1001);
 			switch ( getInterpreter().adaptivePredict(_input,87,_ctx) ) {
 			case 1:
 				{
-				setState(993);
+				setState(994);
 				match(STRING);
-				setState(997);
+				setState(998);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(994);
+					setState(995);
 					match(T__4);
 					}
 					}
-					setState(999);
+					setState(1000);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(1003);
+			setState(1004);
 			_la = _input.LA(1);
 			if (_la==STRING) {
 				{
-				setState(1002);
+				setState(1003);
 				match(STRING);
 				}
 			}
@@ -6968,159 +6999,159 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(1005);
+			setState(1006);
 			match(MESSWERT_NWG_I);
-			setState(1006);
+			setState(1007);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(1010);
+			setState(1011);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(1007);
+				setState(1008);
 				match(T__4);
 				}
 				}
-				setState(1012);
+				setState(1013);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(1013);
+			setState(1014);
 			match(STRING);
-			setState(1017);
+			setState(1018);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(1014);
+				setState(1015);
 				match(T__4);
 				}
 				}
-				setState(1019);
+				setState(1020);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(1020);
+			setState(1021);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(1024);
+			setState(1025);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(1021);
+				setState(1022);
 				match(T__4);
 				}
 				}
-				setState(1026);
+				setState(1027);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(1034);
+			setState(1035);
 			switch ( getInterpreter().adaptivePredict(_input,93,_ctx) ) {
 			case 1:
 				{
-				setState(1027);
+				setState(1028);
 				match(STRING);
-				setState(1031);
+				setState(1032);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(1028);
+					setState(1029);
 					match(T__4);
 					}
 					}
-					setState(1033);
-					_errHandler.sync(this);
-					_la = _input.LA(1);
-				}
-				}
-				break;
-			}
-			setState(1043);
-			switch ( getInterpreter().adaptivePredict(_input,95,_ctx) ) {
-			case 1:
-				{
-				setState(1036);
-				match(STRING);
-				setState(1040);
-				_errHandler.sync(this);
-				_la = _input.LA(1);
-				while (_la==T__4) {
-					{
-					{
-					setState(1037);
-					match(T__4);
-					}
-					}
-					setState(1042);
+					setState(1034);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(1052);
-			switch ( getInterpreter().adaptivePredict(_input,97,_ctx) ) {
+			setState(1044);
+			switch ( getInterpreter().adaptivePredict(_input,95,_ctx) ) {
 			case 1:
 				{
-				setState(1045);
+				setState(1037);
 				match(STRING);
-				setState(1049);
+				setState(1041);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(1046);
+					setState(1038);
 					match(T__4);
 					}
 					}
-					setState(1051);
+					setState(1043);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(1061);
-			switch ( getInterpreter().adaptivePredict(_input,99,_ctx) ) {
+			setState(1053);
+			switch ( getInterpreter().adaptivePredict(_input,97,_ctx) ) {
 			case 1:
 				{
-				setState(1054);
+				setState(1046);
 				match(STRING);
-				setState(1058);
+				setState(1050);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(1055);
+					setState(1047);
 					match(T__4);
 					}
 					}
-					setState(1060);
+					setState(1052);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(1063);
+			setState(1062);
+			switch ( getInterpreter().adaptivePredict(_input,99,_ctx) ) {
+			case 1:
+				{
+				setState(1055);
+				match(STRING);
+				setState(1059);
+				_errHandler.sync(this);
+				_la = _input.LA(1);
+				while (_la==T__4) {
+					{
+					{
+					setState(1056);
+					match(T__4);
+					}
+					}
+					setState(1061);
+					_errHandler.sync(this);
+					_la = _input.LA(1);
+				}
+				}
+				break;
+			}
+			setState(1064);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -7171,156 +7202,156 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(1065);
+			setState(1066);
 			match(MESSWERT_NWG_G);
-			setState(1066);
+			setState(1067);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(1070);
+			setState(1071);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(1067);
+				setState(1068);
 				match(T__4);
 				}
 				}
-				setState(1072);
+				setState(1073);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(1073);
+			setState(1074);
 			match(STRING);
-			setState(1077);
+			setState(1078);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(1074);
+				setState(1075);
 				match(T__4);
 				}
 				}
-				setState(1079);
+				setState(1080);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(1080);
+			setState(1081);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(1084);
+			setState(1085);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(1081);
+				setState(1082);
 				match(T__4);
 				}
 				}
-				setState(1086);
+				setState(1087);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(1094);
+			setState(1095);
 			switch ( getInterpreter().adaptivePredict(_input,104,_ctx) ) {
 			case 1:
 				{
-				setState(1087);
+				setState(1088);
 				match(STRING);
-				setState(1091);
+				setState(1092);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(1088);
+					setState(1089);
 					match(T__4);
 					}
 					}
-					setState(1093);
+					setState(1094);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(1096);
+			setState(1097);
 			match(STRING);
-			setState(1100);
+			setState(1101);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(1097);
+				setState(1098);
 				match(T__4);
 				}
 				}
-				setState(1102);
+				setState(1103);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(1110);
+			setState(1111);
 			switch ( getInterpreter().adaptivePredict(_input,107,_ctx) ) {
 			case 1:
 				{
-				setState(1103);
+				setState(1104);
 				match(STRING);
-				setState(1107);
+				setState(1108);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(1104);
+					setState(1105);
 					match(T__4);
 					}
 					}
-					setState(1109);
+					setState(1110);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(1119);
+			setState(1120);
 			switch ( getInterpreter().adaptivePredict(_input,109,_ctx) ) {
 			case 1:
 				{
-				setState(1112);
+				setState(1113);
 				match(STRING);
-				setState(1116);
+				setState(1117);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 				while (_la==T__4) {
 					{
 					{
-					setState(1113);
+					setState(1114);
 					match(T__4);
 					}
 					}
-					setState(1118);
+					setState(1119);
 					_errHandler.sync(this);
 					_la = _input.LA(1);
 				}
 				}
 				break;
 			}
-			setState(1122);
+			setState(1123);
 			_la = _input.LA(1);
 			if (_la==STRING_ESC || _la==STRING) {
 				{
-				setState(1121);
+				setState(1122);
 				_la = _input.LA(1);
 				if ( !(_la==STRING_ESC || _la==STRING) ) {
 				_errHandler.recoverInline(this);
@@ -7374,62 +7405,62 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(1124);
+			setState(1125);
 			match(KOMMENTAR);
-			setState(1125);
+			setState(1126);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(1129);
-			_errHandler.sync(this);
-			_la = _input.LA(1);
-			while (_la==T__4) {
-				{
-				{
-				setState(1126);
-				match(T__4);
-				}
-				}
-				setState(1131);
-				_errHandler.sync(this);
-				_la = _input.LA(1);
-			}
-			setState(1132);
-			match(STRING);
-			setState(1136);
+			setState(1130);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(1133);
+				setState(1127);
 				match(T__4);
 				}
 				}
-				setState(1138);
+				setState(1132);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(1139);
+			setState(1133);
 			match(STRING);
-			setState(1143);
+			setState(1137);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(1140);
+				setState(1134);
 				match(T__4);
 				}
 				}
-				setState(1145);
+				setState(1139);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(1146);
+			setState(1140);
+			match(STRING);
+			setState(1144);
+			_errHandler.sync(this);
+			_la = _input.LA(1);
+			while (_la==T__4) {
+				{
+				{
+				setState(1141);
+				match(T__4);
+				}
+				}
+				setState(1146);
+				_errHandler.sync(this);
+				_la = _input.LA(1);
+			}
+			setState(1147);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -7474,9 +7505,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(1148);
+			setState(1149);
 			match(KOMMENTAR_T);
-			setState(1149);
+			setState(1150);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -7527,62 +7558,62 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(1151);
+			setState(1152);
 			match(PROBENKOMMENTAR);
-			setState(1152);
+			setState(1153);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
 			} else {
 				consume();
 			}
-			setState(1156);
-			_errHandler.sync(this);
-			_la = _input.LA(1);
-			while (_la==T__4) {
-				{
-				{
-				setState(1153);
-				match(T__4);
-				}
-				}
-				setState(1158);
-				_errHandler.sync(this);
-				_la = _input.LA(1);
-			}
-			setState(1159);
-			match(STRING);
-			setState(1163);
+			setState(1157);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(1160);
+				setState(1154);
 				match(T__4);
 				}
 				}
-				setState(1165);
+				setState(1159);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(1166);
+			setState(1160);
 			match(STRING);
-			setState(1170);
+			setState(1164);
 			_errHandler.sync(this);
 			_la = _input.LA(1);
 			while (_la==T__4) {
 				{
 				{
-				setState(1167);
+				setState(1161);
 				match(T__4);
 				}
 				}
-				setState(1172);
+				setState(1166);
 				_errHandler.sync(this);
 				_la = _input.LA(1);
 			}
-			setState(1173);
+			setState(1167);
+			match(STRING);
+			setState(1171);
+			_errHandler.sync(this);
+			_la = _input.LA(1);
+			while (_la==T__4) {
+				{
+				{
+				setState(1168);
+				match(T__4);
+				}
+				}
+				setState(1173);
+				_errHandler.sync(this);
+				_la = _input.LA(1);
+			}
+			setState(1174);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -7627,9 +7658,9 @@
 		try {
 			enterOuterAlt(_localctx, 1);
 			{
-			setState(1175);
+			setState(1176);
 			match(PROBENKOMMENTAR_T);
-			setState(1176);
+			setState(1177);
 			_la = _input.LA(1);
 			if ( !(_la==STRING_ESC || _la==STRING) ) {
 			_errHandler.recoverInline(this);
@@ -7650,7 +7681,7 @@
 	}
 
 	public static final String _serializedATN =
-		"\3\u0430\ud6d1\u8206\uad2d\u4417\uaef1\u8d80\uaadd\3b\u049d\4\2\t\2\4"+
+		"\3\u0430\ud6d1\u8206\uad2d\u4417\uaef1\u8d80\uaadd\3b\u049e\4\2\t\2\4"+
 		"\3\t\3\4\4\t\4\4\5\t\5\4\6\t\6\4\7\t\7\4\b\t\b\4\t\t\t\4\n\t\n\4\13\t"+
 		"\13\4\f\t\f\4\r\t\r\4\16\t\16\4\17\t\17\4\20\t\20\4\21\t\21\4\22\t\22"+
 		"\4\23\t\23\4\24\t\24\4\25\t\25\4\26\t\26\4\27\t\27\4\30\t\30\4\31\t\31"+
@@ -7666,429 +7697,430 @@
 		"\2\16\2\u00eb\13\2\3\2\5\2\u00ee\n\2\3\2\3\2\3\3\3\3\3\4\3\4\6\4\u00f6"+
 		"\n\4\r\4\16\4\u00f7\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3"+
 		"\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5"+
-		"\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\5\5\u0124\n\5\3\6\5\6"+
-		"\u0127\n\6\3\6\6\6\u012a\n\6\r\6\16\6\u012b\3\7\3\7\3\b\3\b\3\b\3\b\3"+
-		"\b\3\b\3\b\3\b\3\b\3\b\5\b\u013a\n\b\3\t\3\t\5\t\u013e\n\t\3\n\3\n\5\n"+
-		"\u0142\n\n\3\13\3\13\5\13\u0146\n\13\3\f\3\f\5\f\u014a\n\f\3\r\3\r\3\r"+
-		"\5\r\u014f\n\r\3\16\3\16\5\16\u0153\n\16\3\17\3\17\5\17\u0157\n\17\3\20"+
-		"\3\20\5\20\u015b\n\20\3\21\3\21\5\21\u015f\n\21\3\22\3\22\5\22\u0163\n"+
-		"\22\3\23\3\23\3\23\5\23\u0168\n\23\3\24\3\24\5\24\u016c\n\24\3\25\3\25"+
-		"\5\25\u0170\n\25\3\26\3\26\3\26\3\26\3\26\3\26\3\26\3\26\5\26\u017a\n"+
-		"\26\3\27\3\27\5\27\u017e\n\27\3\30\3\30\5\30\u0182\n\30\3\31\3\31\7\31"+
-		"\u0186\n\31\f\31\16\31\u0189\13\31\3\32\3\32\3\32\3\32\3\32\3\32\3\32"+
-		"\5\32\u0192\n\32\3\33\3\33\3\33\5\33\u0197\n\33\3\34\3\34\5\34\u019b\n"+
-		"\34\3\35\3\35\5\35\u019f\n\35\3\36\3\36\3\36\3\37\3\37\3\37\3 \3 \3 \3"+
-		"!\3!\3!\3\"\3\"\3\"\3#\3#\3#\3$\3$\3$\3%\3%\3%\3&\3&\3&\3\'\3\'\3\'\3"+
-		"(\3(\3(\3)\3)\3)\3*\3*\3*\3+\3+\3+\3,\3,\3,\3-\3-\3-\3.\3.\3.\3/\3/\3"+
-		"/\3\60\3\60\3\60\3\61\3\61\3\61\3\62\3\62\3\62\3\63\3\63\3\63\3\64\3\64"+
-		"\3\64\3\65\3\65\3\65\7\65\u01e9\n\65\f\65\16\65\u01ec\13\65\3\65\3\65"+
-		"\3\66\3\66\3\66\7\66\u01f3\n\66\f\66\16\66\u01f6\13\66\3\66\3\66\3\67"+
-		"\3\67\3\67\7\67\u01fd\n\67\f\67\16\67\u0200\13\67\3\67\3\67\38\38\38\7"+
-		"8\u0207\n8\f8\168\u020a\138\38\38\39\39\39\79\u0211\n9\f9\169\u0214\13"+
-		"9\39\39\3:\3:\3:\3;\3;\3;\3<\3<\3<\3=\3=\3=\3>\3>\3>\3?\3?\3?\7?\u022a"+
-		"\n?\f?\16?\u022d\13?\3?\3?\3@\3@\3@\3A\3A\3A\3B\3B\3B\3C\3C\3C\3D\3D\3"+
-		"D\3E\3E\3E\3F\3F\3F\3G\3G\3G\3H\3H\3H\3I\3I\3I\3J\3J\3J\7J\u0252\nJ\f"+
-		"J\16J\u0255\13J\3J\3J\7J\u0259\nJ\fJ\16J\u025c\13J\3J\3J\3K\3K\3K\7K\u0263"+
-		"\nK\fK\16K\u0266\13K\3K\3K\7K\u026a\nK\fK\16K\u026d\13K\3K\3K\3L\3L\3"+
+		"\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\3\5\5\5\u0125\n\5\3\6"+
+		"\5\6\u0128\n\6\3\6\6\6\u012b\n\6\r\6\16\6\u012c\3\7\3\7\3\b\3\b\3\b\3"+
+		"\b\3\b\3\b\3\b\3\b\3\b\3\b\5\b\u013b\n\b\3\t\3\t\5\t\u013f\n\t\3\n\3\n"+
+		"\5\n\u0143\n\n\3\13\3\13\5\13\u0147\n\13\3\f\3\f\5\f\u014b\n\f\3\r\3\r"+
+		"\3\r\5\r\u0150\n\r\3\16\3\16\5\16\u0154\n\16\3\17\3\17\5\17\u0158\n\17"+
+		"\3\20\3\20\5\20\u015c\n\20\3\21\3\21\5\21\u0160\n\21\3\22\3\22\5\22\u0164"+
+		"\n\22\3\23\3\23\3\23\5\23\u0169\n\23\3\24\3\24\5\24\u016d\n\24\3\25\3"+
+		"\25\5\25\u0171\n\25\3\26\3\26\3\26\3\26\3\26\3\26\3\26\3\26\5\26\u017b"+
+		"\n\26\3\27\3\27\5\27\u017f\n\27\3\30\3\30\5\30\u0183\n\30\3\31\3\31\7"+
+		"\31\u0187\n\31\f\31\16\31\u018a\13\31\3\32\3\32\3\32\3\32\3\32\3\32\3"+
+		"\32\5\32\u0193\n\32\3\33\3\33\3\33\5\33\u0198\n\33\3\34\3\34\5\34\u019c"+
+		"\n\34\3\35\3\35\5\35\u01a0\n\35\3\36\3\36\3\36\3\37\3\37\3\37\3 \3 \3"+
+		" \3!\3!\3!\3\"\3\"\3\"\3#\3#\3#\3$\3$\3$\3%\3%\3%\3&\3&\3&\3\'\3\'\3\'"+
+		"\3(\3(\3(\3)\3)\3)\3*\3*\3*\3+\3+\3+\3,\3,\3,\3-\3-\3-\3.\3.\3.\3/\3/"+
+		"\3/\3\60\3\60\3\60\3\61\3\61\3\61\3\62\3\62\3\62\3\63\3\63\3\63\3\64\3"+
+		"\64\3\64\3\65\3\65\3\65\7\65\u01ea\n\65\f\65\16\65\u01ed\13\65\3\65\3"+
+		"\65\3\66\3\66\3\66\7\66\u01f4\n\66\f\66\16\66\u01f7\13\66\3\66\3\66\3"+
+		"\67\3\67\3\67\7\67\u01fe\n\67\f\67\16\67\u0201\13\67\3\67\3\67\38\38\3"+
+		"8\78\u0208\n8\f8\168\u020b\138\38\38\39\39\39\79\u0212\n9\f9\169\u0215"+
+		"\139\39\39\3:\3:\3:\3;\3;\3;\3<\3<\3<\3=\3=\3=\3>\3>\3>\3?\3?\3?\7?\u022b"+
+		"\n?\f?\16?\u022e\13?\3?\3?\3@\3@\3@\3A\3A\3A\3B\3B\3B\3C\3C\3C\3D\3D\3"+
+		"D\3E\3E\3E\3F\3F\3F\3G\3G\3G\3H\3H\3H\3I\3I\3I\3J\3J\3J\7J\u0253\nJ\f"+
+		"J\16J\u0256\13J\3J\3J\7J\u025a\nJ\fJ\16J\u025d\13J\3J\3J\3K\3K\3K\7K\u0264"+
+		"\nK\fK\16K\u0267\13K\3K\3K\7K\u026b\nK\fK\16K\u026e\13K\3K\3K\3L\3L\3"+
 		"L\3M\3M\3M\3N\3N\3N\3O\3O\3O\3P\3P\3P\3Q\3Q\3Q\3R\3R\3R\3S\3S\3S\3T\3"+
-		"T\3T\3U\3U\3U\7U\u028f\nU\fU\16U\u0292\13U\3U\3U\7U\u0296\nU\fU\16U\u0299"+
-		"\13U\3U\3U\3V\3V\3V\7V\u02a0\nV\fV\16V\u02a3\13V\3V\3V\7V\u02a7\nV\fV"+
-		"\16V\u02aa\13V\3V\3V\3W\3W\3W\3X\3X\3X\3Y\3Y\3Y\3Z\3Z\3Z\3[\3[\3[\3\\"+
-		"\3\\\3\\\3]\3]\3]\3^\3^\3^\3_\3_\3_\7_\u02c9\n_\f_\16_\u02cc\13_\3_\3"+
-		"_\3`\3`\3`\3a\3a\3a\3b\3b\3b\3c\3c\3c\3d\3d\3d\3e\3e\3e\3f\3f\3f\7f\u02e5"+
-		"\nf\ff\16f\u02e8\13f\3f\3f\7f\u02ec\nf\ff\16f\u02ef\13f\3f\3f\7f\u02f3"+
-		"\nf\ff\16f\u02f6\13f\3f\3f\3g\3g\3g\7g\u02fd\ng\fg\16g\u0300\13g\3g\3"+
-		"g\7g\u0304\ng\fg\16g\u0307\13g\3g\3g\7g\u030b\ng\fg\16g\u030e\13g\3g\3"+
-		"g\3h\3h\3h\7h\u0315\nh\fh\16h\u0318\13h\3h\3h\7h\u031c\nh\fh\16h\u031f"+
-		"\13h\3h\3h\7h\u0323\nh\fh\16h\u0326\13h\3h\5h\u0329\nh\3i\3i\3i\7i\u032e"+
-		"\ni\fi\16i\u0331\13i\3i\3i\7i\u0335\ni\fi\16i\u0338\13i\3i\3i\7i\u033c"+
-		"\ni\fi\16i\u033f\13i\3i\5i\u0342\ni\3j\3j\3j\7j\u0347\nj\fj\16j\u034a"+
-		"\13j\3j\3j\7j\u034e\nj\fj\16j\u0351\13j\3j\3j\7j\u0355\nj\fj\16j\u0358"+
-		"\13j\3j\3j\7j\u035c\nj\fj\16j\u035f\13j\5j\u0361\nj\3j\3j\7j\u0365\nj"+
-		"\fj\16j\u0368\13j\5j\u036a\nj\3j\3j\7j\u036e\nj\fj\16j\u0371\13j\5j\u0373"+
-		"\nj\3j\5j\u0376\nj\3k\3k\3k\7k\u037b\nk\fk\16k\u037e\13k\3k\3k\7k\u0382"+
-		"\nk\fk\16k\u0385\13k\3k\3k\7k\u0389\nk\fk\16k\u038c\13k\3k\3k\7k\u0390"+
-		"\nk\fk\16k\u0393\13k\5k\u0395\nk\3k\3k\7k\u0399\nk\fk\16k\u039c\13k\5"+
-		"k\u039e\nk\3k\3k\7k\u03a2\nk\fk\16k\u03a5\13k\5k\u03a7\nk\3k\5k\u03aa"+
-		"\nk\3l\3l\3l\7l\u03af\nl\fl\16l\u03b2\13l\3l\3l\7l\u03b6\nl\fl\16l\u03b9"+
-		"\13l\3l\3l\7l\u03bd\nl\fl\16l\u03c0\13l\3l\3l\7l\u03c4\nl\fl\16l\u03c7"+
-		"\13l\5l\u03c9\nl\3l\5l\u03cc\nl\3m\3m\3m\7m\u03d1\nm\fm\16m\u03d4\13m"+
-		"\3m\3m\7m\u03d8\nm\fm\16m\u03db\13m\3m\3m\7m\u03df\nm\fm\16m\u03e2\13"+
-		"m\3m\3m\7m\u03e6\nm\fm\16m\u03e9\13m\5m\u03eb\nm\3m\5m\u03ee\nm\3n\3n"+
-		"\3n\7n\u03f3\nn\fn\16n\u03f6\13n\3n\3n\7n\u03fa\nn\fn\16n\u03fd\13n\3"+
-		"n\3n\7n\u0401\nn\fn\16n\u0404\13n\3n\3n\7n\u0408\nn\fn\16n\u040b\13n\5"+
-		"n\u040d\nn\3n\3n\7n\u0411\nn\fn\16n\u0414\13n\5n\u0416\nn\3n\3n\7n\u041a"+
-		"\nn\fn\16n\u041d\13n\5n\u041f\nn\3n\3n\7n\u0423\nn\fn\16n\u0426\13n\5"+
-		"n\u0428\nn\3n\3n\3o\3o\3o\7o\u042f\no\fo\16o\u0432\13o\3o\3o\7o\u0436"+
-		"\no\fo\16o\u0439\13o\3o\3o\7o\u043d\no\fo\16o\u0440\13o\3o\3o\7o\u0444"+
-		"\no\fo\16o\u0447\13o\5o\u0449\no\3o\3o\7o\u044d\no\fo\16o\u0450\13o\3"+
-		"o\3o\7o\u0454\no\fo\16o\u0457\13o\5o\u0459\no\3o\3o\7o\u045d\no\fo\16"+
-		"o\u0460\13o\5o\u0462\no\3o\5o\u0465\no\3p\3p\3p\7p\u046a\np\fp\16p\u046d"+
-		"\13p\3p\3p\7p\u0471\np\fp\16p\u0474\13p\3p\3p\7p\u0478\np\fp\16p\u047b"+
-		"\13p\3p\3p\3q\3q\3q\3r\3r\3r\7r\u0485\nr\fr\16r\u0488\13r\3r\3r\7r\u048c"+
-		"\nr\fr\16r\u048f\13r\3r\3r\7r\u0493\nr\fr\16r\u0496\13r\3r\3r\3s\3s\3"+
+		"T\3T\3U\3U\3U\7U\u0290\nU\fU\16U\u0293\13U\3U\3U\7U\u0297\nU\fU\16U\u029a"+
+		"\13U\3U\3U\3V\3V\3V\7V\u02a1\nV\fV\16V\u02a4\13V\3V\3V\7V\u02a8\nV\fV"+
+		"\16V\u02ab\13V\3V\3V\3W\3W\3W\3X\3X\3X\3Y\3Y\3Y\3Z\3Z\3Z\3[\3[\3[\3\\"+
+		"\3\\\3\\\3]\3]\3]\3^\3^\3^\3_\3_\3_\7_\u02ca\n_\f_\16_\u02cd\13_\3_\3"+
+		"_\3`\3`\3`\3a\3a\3a\3b\3b\3b\3c\3c\3c\3d\3d\3d\3e\3e\3e\3f\3f\3f\7f\u02e6"+
+		"\nf\ff\16f\u02e9\13f\3f\3f\7f\u02ed\nf\ff\16f\u02f0\13f\3f\3f\7f\u02f4"+
+		"\nf\ff\16f\u02f7\13f\3f\3f\3g\3g\3g\7g\u02fe\ng\fg\16g\u0301\13g\3g\3"+
+		"g\7g\u0305\ng\fg\16g\u0308\13g\3g\3g\7g\u030c\ng\fg\16g\u030f\13g\3g\3"+
+		"g\3h\3h\3h\7h\u0316\nh\fh\16h\u0319\13h\3h\3h\7h\u031d\nh\fh\16h\u0320"+
+		"\13h\3h\3h\7h\u0324\nh\fh\16h\u0327\13h\3h\5h\u032a\nh\3i\3i\3i\7i\u032f"+
+		"\ni\fi\16i\u0332\13i\3i\3i\7i\u0336\ni\fi\16i\u0339\13i\3i\3i\7i\u033d"+
+		"\ni\fi\16i\u0340\13i\3i\5i\u0343\ni\3j\3j\3j\7j\u0348\nj\fj\16j\u034b"+
+		"\13j\3j\3j\7j\u034f\nj\fj\16j\u0352\13j\3j\3j\7j\u0356\nj\fj\16j\u0359"+
+		"\13j\3j\3j\7j\u035d\nj\fj\16j\u0360\13j\5j\u0362\nj\3j\3j\7j\u0366\nj"+
+		"\fj\16j\u0369\13j\5j\u036b\nj\3j\3j\7j\u036f\nj\fj\16j\u0372\13j\5j\u0374"+
+		"\nj\3j\5j\u0377\nj\3k\3k\3k\7k\u037c\nk\fk\16k\u037f\13k\3k\3k\7k\u0383"+
+		"\nk\fk\16k\u0386\13k\3k\3k\7k\u038a\nk\fk\16k\u038d\13k\3k\3k\7k\u0391"+
+		"\nk\fk\16k\u0394\13k\5k\u0396\nk\3k\3k\7k\u039a\nk\fk\16k\u039d\13k\5"+
+		"k\u039f\nk\3k\3k\7k\u03a3\nk\fk\16k\u03a6\13k\5k\u03a8\nk\3k\5k\u03ab"+
+		"\nk\3l\3l\3l\7l\u03b0\nl\fl\16l\u03b3\13l\3l\3l\7l\u03b7\nl\fl\16l\u03ba"+
+		"\13l\3l\3l\7l\u03be\nl\fl\16l\u03c1\13l\3l\3l\7l\u03c5\nl\fl\16l\u03c8"+
+		"\13l\5l\u03ca\nl\3l\5l\u03cd\nl\3m\3m\3m\7m\u03d2\nm\fm\16m\u03d5\13m"+
+		"\3m\3m\7m\u03d9\nm\fm\16m\u03dc\13m\3m\3m\7m\u03e0\nm\fm\16m\u03e3\13"+
+		"m\3m\3m\7m\u03e7\nm\fm\16m\u03ea\13m\5m\u03ec\nm\3m\5m\u03ef\nm\3n\3n"+
+		"\3n\7n\u03f4\nn\fn\16n\u03f7\13n\3n\3n\7n\u03fb\nn\fn\16n\u03fe\13n\3"+
+		"n\3n\7n\u0402\nn\fn\16n\u0405\13n\3n\3n\7n\u0409\nn\fn\16n\u040c\13n\5"+
+		"n\u040e\nn\3n\3n\7n\u0412\nn\fn\16n\u0415\13n\5n\u0417\nn\3n\3n\7n\u041b"+
+		"\nn\fn\16n\u041e\13n\5n\u0420\nn\3n\3n\7n\u0424\nn\fn\16n\u0427\13n\5"+
+		"n\u0429\nn\3n\3n\3o\3o\3o\7o\u0430\no\fo\16o\u0433\13o\3o\3o\7o\u0437"+
+		"\no\fo\16o\u043a\13o\3o\3o\7o\u043e\no\fo\16o\u0441\13o\3o\3o\7o\u0445"+
+		"\no\fo\16o\u0448\13o\5o\u044a\no\3o\3o\7o\u044e\no\fo\16o\u0451\13o\3"+
+		"o\3o\7o\u0455\no\fo\16o\u0458\13o\5o\u045a\no\3o\3o\7o\u045e\no\fo\16"+
+		"o\u0461\13o\5o\u0463\no\3o\5o\u0466\no\3p\3p\3p\7p\u046b\np\fp\16p\u046e"+
+		"\13p\3p\3p\7p\u0472\np\fp\16p\u0475\13p\3p\3p\7p\u0479\np\fp\16p\u047c"+
+		"\13p\3p\3p\3q\3q\3q\3r\3r\3r\7r\u0486\nr\fr\16r\u0489\13r\3r\3r\7r\u048d"+
+		"\nr\fr\16r\u0490\13r\3r\3r\7r\u0494\nr\fr\16r\u0497\13r\3r\3r\3s\3s\3"+
 		"s\3s\2\2t\2\4\6\b\n\f\16\20\22\24\26\30\32\34\36 \"$&(*,.\60\62\64\66"+
 		"8:<>@BDFHJLNPRTVXZ\\^`bdfhjlnprtvxz|~\u0080\u0082\u0084\u0086\u0088\u008a"+
 		"\u008c\u008e\u0090\u0092\u0094\u0096\u0098\u009a\u009c\u009e\u00a0\u00a2"+
 		"\u00a4\u00a6\u00a8\u00aa\u00ac\u00ae\u00b0\u00b2\u00b4\u00b6\u00b8\u00ba"+
 		"\u00bc\u00be\u00c0\u00c2\u00c4\u00c6\u00c8\u00ca\u00cc\u00ce\u00d0\u00d2"+
-		"\u00d4\u00d6\u00d8\u00da\u00dc\u00de\u00e0\u00e2\u00e4\2\3\3\2`a\u04dd"+
-		"\2\u00e9\3\2\2\2\4\u00f1\3\2\2\2\6\u00f3\3\2\2\2\b\u0123\3\2\2\2\n\u0126"+
-		"\3\2\2\2\f\u012d\3\2\2\2\16\u0139\3\2\2\2\20\u013d\3\2\2\2\22\u0141\3"+
-		"\2\2\2\24\u0145\3\2\2\2\26\u0149\3\2\2\2\30\u014e\3\2\2\2\32\u0152\3\2"+
-		"\2\2\34\u0156\3\2\2\2\36\u015a\3\2\2\2 \u015e\3\2\2\2\"\u0162\3\2\2\2"+
-		"$\u0167\3\2\2\2&\u016b\3\2\2\2(\u016f\3\2\2\2*\u0179\3\2\2\2,\u017d\3"+
-		"\2\2\2.\u0181\3\2\2\2\60\u0183\3\2\2\2\62\u0191\3\2\2\2\64\u0196\3\2\2"+
-		"\2\66\u019a\3\2\2\28\u019e\3\2\2\2:\u01a0\3\2\2\2<\u01a3\3\2\2\2>\u01a6"+
-		"\3\2\2\2@\u01a9\3\2\2\2B\u01ac\3\2\2\2D\u01af\3\2\2\2F\u01b2\3\2\2\2H"+
-		"\u01b5\3\2\2\2J\u01b8\3\2\2\2L\u01bb\3\2\2\2N\u01be\3\2\2\2P\u01c1\3\2"+
-		"\2\2R\u01c4\3\2\2\2T\u01c7\3\2\2\2V\u01ca\3\2\2\2X\u01cd\3\2\2\2Z\u01d0"+
-		"\3\2\2\2\\\u01d3\3\2\2\2^\u01d6\3\2\2\2`\u01d9\3\2\2\2b\u01dc\3\2\2\2"+
-		"d\u01df\3\2\2\2f\u01e2\3\2\2\2h\u01e5\3\2\2\2j\u01ef\3\2\2\2l\u01f9\3"+
-		"\2\2\2n\u0203\3\2\2\2p\u020d\3\2\2\2r\u0217\3\2\2\2t\u021a\3\2\2\2v\u021d"+
-		"\3\2\2\2x\u0220\3\2\2\2z\u0223\3\2\2\2|\u0226\3\2\2\2~\u0230\3\2\2\2\u0080"+
-		"\u0233\3\2\2\2\u0082\u0236\3\2\2\2\u0084\u0239\3\2\2\2\u0086\u023c\3\2"+
-		"\2\2\u0088\u023f\3\2\2\2\u008a\u0242\3\2\2\2\u008c\u0245\3\2\2\2\u008e"+
-		"\u0248\3\2\2\2\u0090\u024b\3\2\2\2\u0092\u024e\3\2\2\2\u0094\u025f\3\2"+
-		"\2\2\u0096\u0270\3\2\2\2\u0098\u0273\3\2\2\2\u009a\u0276\3\2\2\2\u009c"+
-		"\u0279\3\2\2\2\u009e\u027c\3\2\2\2\u00a0\u027f\3\2\2\2\u00a2\u0282\3\2"+
-		"\2\2\u00a4\u0285\3\2\2\2\u00a6\u0288\3\2\2\2\u00a8\u028b\3\2\2\2\u00aa"+
-		"\u029c\3\2\2\2\u00ac\u02ad\3\2\2\2\u00ae\u02b0\3\2\2\2\u00b0\u02b3\3\2"+
-		"\2\2\u00b2\u02b6\3\2\2\2\u00b4\u02b9\3\2\2\2\u00b6\u02bc\3\2\2\2\u00b8"+
-		"\u02bf\3\2\2\2\u00ba\u02c2\3\2\2\2\u00bc\u02c5\3\2\2\2\u00be\u02cf\3\2"+
-		"\2\2\u00c0\u02d2\3\2\2\2\u00c2\u02d5\3\2\2\2\u00c4\u02d8\3\2\2\2\u00c6"+
-		"\u02db\3\2\2\2\u00c8\u02de\3\2\2\2\u00ca\u02e1\3\2\2\2\u00cc\u02f9\3\2"+
-		"\2\2\u00ce\u0311\3\2\2\2\u00d0\u032a\3\2\2\2\u00d2\u0343\3\2\2\2\u00d4"+
-		"\u0377\3\2\2\2\u00d6\u03ab\3\2\2\2\u00d8\u03cd\3\2\2\2\u00da\u03ef\3\2"+
-		"\2\2\u00dc\u042b\3\2\2\2\u00de\u0466\3\2\2\2\u00e0\u047e\3\2\2\2\u00e2"+
-		"\u0481\3\2\2\2\u00e4\u0499\3\2\2\2\u00e6\u00e8\5\6\4\2\u00e7\u00e6\3\2"+
+		"\u00d4\u00d6\u00d8\u00da\u00dc\u00de\u00e0\u00e2\u00e4\2\3\3\2`a\u04df"+
+		"\2\u00e9\3\2\2\2\4\u00f1\3\2\2\2\6\u00f3\3\2\2\2\b\u0124\3\2\2\2\n\u0127"+
+		"\3\2\2\2\f\u012e\3\2\2\2\16\u013a\3\2\2\2\20\u013e\3\2\2\2\22\u0142\3"+
+		"\2\2\2\24\u0146\3\2\2\2\26\u014a\3\2\2\2\30\u014f\3\2\2\2\32\u0153\3\2"+
+		"\2\2\34\u0157\3\2\2\2\36\u015b\3\2\2\2 \u015f\3\2\2\2\"\u0163\3\2\2\2"+
+		"$\u0168\3\2\2\2&\u016c\3\2\2\2(\u0170\3\2\2\2*\u017a\3\2\2\2,\u017e\3"+
+		"\2\2\2.\u0182\3\2\2\2\60\u0184\3\2\2\2\62\u0192\3\2\2\2\64\u0197\3\2\2"+
+		"\2\66\u019b\3\2\2\28\u019f\3\2\2\2:\u01a1\3\2\2\2<\u01a4\3\2\2\2>\u01a7"+
+		"\3\2\2\2@\u01aa\3\2\2\2B\u01ad\3\2\2\2D\u01b0\3\2\2\2F\u01b3\3\2\2\2H"+
+		"\u01b6\3\2\2\2J\u01b9\3\2\2\2L\u01bc\3\2\2\2N\u01bf\3\2\2\2P\u01c2\3\2"+
+		"\2\2R\u01c5\3\2\2\2T\u01c8\3\2\2\2V\u01cb\3\2\2\2X\u01ce\3\2\2\2Z\u01d1"+
+		"\3\2\2\2\\\u01d4\3\2\2\2^\u01d7\3\2\2\2`\u01da\3\2\2\2b\u01dd\3\2\2\2"+
+		"d\u01e0\3\2\2\2f\u01e3\3\2\2\2h\u01e6\3\2\2\2j\u01f0\3\2\2\2l\u01fa\3"+
+		"\2\2\2n\u0204\3\2\2\2p\u020e\3\2\2\2r\u0218\3\2\2\2t\u021b\3\2\2\2v\u021e"+
+		"\3\2\2\2x\u0221\3\2\2\2z\u0224\3\2\2\2|\u0227\3\2\2\2~\u0231\3\2\2\2\u0080"+
+		"\u0234\3\2\2\2\u0082\u0237\3\2\2\2\u0084\u023a\3\2\2\2\u0086\u023d\3\2"+
+		"\2\2\u0088\u0240\3\2\2\2\u008a\u0243\3\2\2\2\u008c\u0246\3\2\2\2\u008e"+
+		"\u0249\3\2\2\2\u0090\u024c\3\2\2\2\u0092\u024f\3\2\2\2\u0094\u0260\3\2"+
+		"\2\2\u0096\u0271\3\2\2\2\u0098\u0274\3\2\2\2\u009a\u0277\3\2\2\2\u009c"+
+		"\u027a\3\2\2\2\u009e\u027d\3\2\2\2\u00a0\u0280\3\2\2\2\u00a2\u0283\3\2"+
+		"\2\2\u00a4\u0286\3\2\2\2\u00a6\u0289\3\2\2\2\u00a8\u028c\3\2\2\2\u00aa"+
+		"\u029d\3\2\2\2\u00ac\u02ae\3\2\2\2\u00ae\u02b1\3\2\2\2\u00b0\u02b4\3\2"+
+		"\2\2\u00b2\u02b7\3\2\2\2\u00b4\u02ba\3\2\2\2\u00b6\u02bd\3\2\2\2\u00b8"+
+		"\u02c0\3\2\2\2\u00ba\u02c3\3\2\2\2\u00bc\u02c6\3\2\2\2\u00be\u02d0\3\2"+
+		"\2\2\u00c0\u02d3\3\2\2\2\u00c2\u02d6\3\2\2\2\u00c4\u02d9\3\2\2\2\u00c6"+
+		"\u02dc\3\2\2\2\u00c8\u02df\3\2\2\2\u00ca\u02e2\3\2\2\2\u00cc\u02fa\3\2"+
+		"\2\2\u00ce\u0312\3\2\2\2\u00d0\u032b\3\2\2\2\u00d2\u0344\3\2\2\2\u00d4"+
+		"\u0378\3\2\2\2\u00d6\u03ac\3\2\2\2\u00d8\u03ce\3\2\2\2\u00da\u03f0\3\2"+
+		"\2\2\u00dc\u042c\3\2\2\2\u00de\u0467\3\2\2\2\u00e0\u047f\3\2\2\2\u00e2"+
+		"\u0482\3\2\2\2\u00e4\u049a\3\2\2\2\u00e6\u00e8\5\6\4\2\u00e7\u00e6\3\2"+
 		"\2\2\u00e8\u00eb\3\2\2\2\u00e9\u00e7\3\2\2\2\u00e9\u00ea\3\2\2\2\u00ea"+
 		"\u00ed\3\2\2\2\u00eb\u00e9\3\2\2\2\u00ec\u00ee\5\4\3\2\u00ed\u00ec\3\2"+
 		"\2\2\u00ed\u00ee\3\2\2\2\u00ee\u00ef\3\2\2\2\u00ef\u00f0\7\2\2\3\u00f0"+
 		"\3\3\2\2\2\u00f1\u00f2\7\3\2\2\u00f2\5\3\2\2\2\u00f3\u00f5\7\4\2\2\u00f4"+
 		"\u00f6\5\b\5\2\u00f5\u00f4\3\2\2\2\u00f6\u00f7\3\2\2\2\u00f7\u00f5\3\2"+
-		"\2\2\u00f7\u00f8\3\2\2\2\u00f8\7\3\2\2\2\u00f9\u0124\5\20\t\2\u00fa\u0124"+
-		"\5:\36\2\u00fb\u0124\5<\37\2\u00fc\u0124\5B\"\2\u00fd\u0124\5D#\2\u00fe"+
-		"\u0124\5$\23\2\u00ff\u0124\5L\'\2\u0100\u0124\5N(\2\u0101\u0124\5P)\2"+
-		"\u0102\u0124\5&\24\2\u0103\u0124\5\22\n\2\u0104\u0124\5^\60\2\u0105\u0124"+
-		"\5`\61\2\u0106\u0124\5b\62\2\u0107\u0124\5\36\20\2\u0108\u0124\5n8\2\u0109"+
-		"\u0124\5p9\2\u010a\u0124\5h\65\2\u010b\u0124\5j\66\2\u010c\u0124\5\24"+
-		"\13\2\u010d\u0124\5v<\2\u010e\u0124\5\26\f\2\u010f\u0124\5|?\2\u0110\u0124"+
-		"\5~@\2\u0111\u0124\5\u0080A\2\u0112\u0124\5\u0082B\2\u0113\u0124\5\60"+
-		"\31\2\u0114\u0124\5\30\r\2\u0115\u0124\5\32\16\2\u0116\u0124\5\u00a6T"+
-		"\2\u0117\u0124\5\34\17\2\u0118\u0124\5\u00acW\2\u0119\u0124\5\u00aeX\2"+
-		"\u011a\u0124\5\u00b0Y\2\u011b\u0124\5\u00b2Z\2\u011c\u0124\5\u00b4[\2"+
-		"\u011d\u0124\5\u00b6\\\2\u011e\u0124\5\u00b8]\2\u011f\u0124\5\u00ba^\2"+
-		"\u0120\u0124\5\n\6\2\u0121\u0124\5 \21\2\u0122\u0124\5\"\22\2\u0123\u00f9"+
-		"\3\2\2\2\u0123\u00fa\3\2\2\2\u0123\u00fb\3\2\2\2\u0123\u00fc\3\2\2\2\u0123"+
-		"\u00fd\3\2\2\2\u0123\u00fe\3\2\2\2\u0123\u00ff\3\2\2\2\u0123\u0100\3\2"+
-		"\2\2\u0123\u0101\3\2\2\2\u0123\u0102\3\2\2\2\u0123\u0103\3\2\2\2\u0123"+
-		"\u0104\3\2\2\2\u0123\u0105\3\2\2\2\u0123\u0106\3\2\2\2\u0123\u0107\3\2"+
-		"\2\2\u0123\u0108\3\2\2\2\u0123\u0109\3\2\2\2\u0123\u010a\3\2\2\2\u0123"+
-		"\u010b\3\2\2\2\u0123\u010c\3\2\2\2\u0123\u010d\3\2\2\2\u0123\u010e\3\2"+
-		"\2\2\u0123\u010f\3\2\2\2\u0123\u0110\3\2\2\2\u0123\u0111\3\2\2\2\u0123"+
-		"\u0112\3\2\2\2\u0123\u0113\3\2\2\2\u0123\u0114\3\2\2\2\u0123\u0115\3\2"+
-		"\2\2\u0123\u0116\3\2\2\2\u0123\u0117\3\2\2\2\u0123\u0118\3\2\2\2\u0123"+
-		"\u0119\3\2\2\2\u0123\u011a\3\2\2\2\u0123\u011b\3\2\2\2\u0123\u011c\3\2"+
-		"\2\2\u0123\u011d\3\2\2\2\u0123\u011e\3\2\2\2\u0123\u011f\3\2\2\2\u0123"+
-		"\u0120\3\2\2\2\u0123\u0121\3\2\2\2\u0123\u0122\3\2\2\2\u0124\t\3\2\2\2"+
-		"\u0125\u0127\5\f\7\2\u0126\u0125\3\2\2\2\u0126\u0127\3\2\2\2\u0127\u0129"+
-		"\3\2\2\2\u0128\u012a\5\16\b\2\u0129\u0128\3\2\2\2\u012a\u012b\3\2\2\2"+
-		"\u012b\u0129\3\2\2\2\u012b\u012c\3\2\2\2\u012c\13\3\2\2\2\u012d\u012e"+
-		"\7\5\2\2\u012e\r\3\2\2\2\u012f\u013a\5R*\2\u0130\u013a\5.\30\2\u0131\u013a"+
-		"\5\u00bc_\2\u0132\u013a\5\u00be`\2\u0133\u013a\5(\25\2\u0134\u013a\5\u00c4"+
-		"c\2\u0135\u013a\5\u00c6d\2\u0136\u013a\5\u00c8e\2\u0137\u013a\5\u00ce"+
-		"h\2\u0138\u013a\5,\27\2\u0139\u012f\3\2\2\2\u0139\u0130\3\2\2\2\u0139"+
-		"\u0131\3\2\2\2\u0139\u0132\3\2\2\2\u0139\u0133\3\2\2\2\u0139\u0134\3\2"+
-		"\2\2\u0139\u0135\3\2\2\2\u0139\u0136\3\2\2\2\u0139\u0137\3\2\2\2\u0139"+
-		"\u0138\3\2\2\2\u013a\17\3\2\2\2\u013b\u013e\5> \2\u013c\u013e\5@!\2\u013d"+
-		"\u013b\3\2\2\2\u013d\u013c\3\2\2\2\u013e\21\3\2\2\2\u013f\u0142\5Z.\2"+
-		"\u0140\u0142\5\\/\2\u0141\u013f\3\2\2\2\u0141\u0140\3\2\2\2\u0142\23\3"+
-		"\2\2\2\u0143\u0146\5r:\2\u0144\u0146\5t;\2\u0145\u0143\3\2\2\2\u0145\u0144"+
-		"\3\2\2\2\u0146\25\3\2\2\2\u0147\u014a\5x=\2\u0148\u014a\5z>\2\u0149\u0147"+
-		"\3\2\2\2\u0149\u0148\3\2\2\2\u014a\27\3\2\2\2\u014b\u014f\5\u009cO\2\u014c"+
-		"\u014f\5\u009eP\2\u014d\u014f\5\u00a0Q\2\u014e\u014b\3\2\2\2\u014e\u014c"+
-		"\3\2\2\2\u014e\u014d\3\2\2\2\u014f\31\3\2\2\2\u0150\u0153\5\u00a2R\2\u0151"+
-		"\u0153\5\u00a4S\2\u0152\u0150\3\2\2\2\u0152\u0151\3\2\2\2\u0153\33\3\2"+
-		"\2\2\u0154\u0157\5\u00a8U\2\u0155\u0157\5\u00aaV\2\u0156\u0154\3\2\2\2"+
-		"\u0156\u0155\3\2\2\2\u0157\35\3\2\2\2\u0158\u015b\5d\63\2\u0159\u015b"+
-		"\5f\64\2\u015a\u0158\3\2\2\2\u015a\u0159\3\2\2\2\u015b\37\3\2\2\2\u015c"+
-		"\u015f\5\u00caf\2\u015d\u015f\5\u00ccg\2\u015e\u015c\3\2\2\2\u015e\u015d"+
-		"\3\2\2\2\u015f!\3\2\2\2\u0160\u0163\5\u00e2r\2\u0161\u0163\5\u00e4s\2"+
-		"\u0162\u0160\3\2\2\2\u0162\u0161\3\2\2\2\u0163#\3\2\2\2\u0164\u0168\5"+
-		"F$\2\u0165\u0168\5H%\2\u0166\u0168\5J&\2\u0167\u0164\3\2\2\2\u0167\u0165"+
-		"\3\2\2\2\u0167\u0166\3\2\2\2\u0168%\3\2\2\2\u0169\u016c\5T+\2\u016a\u016c"+
-		"\5V,\2\u016b\u0169\3\2\2\2\u016b\u016a\3\2\2\2\u016c\'\3\2\2\2\u016d\u0170"+
-		"\5\u00c0a\2\u016e\u0170\5\u00c2b\2\u016f\u016d\3\2\2\2\u016f\u016e\3\2"+
-		"\2\2\u0170)\3\2\2\2\u0171\u017a\5\u00ceh\2\u0172\u017a\5\u00d0i\2\u0173"+
-		"\u017a\5\u00d2j\2\u0174\u017a\5\u00d4k\2\u0175\u017a\5\u00d6l\2\u0176"+
-		"\u017a\5\u00d8m\2\u0177\u017a\5\u00dan\2\u0178\u017a\5\u00dco\2\u0179"+
-		"\u0171\3\2\2\2\u0179\u0172\3\2\2\2\u0179\u0173\3\2\2\2\u0179\u0174\3\2"+
-		"\2\2\u0179\u0175\3\2\2\2\u0179\u0176\3\2\2\2\u0179\u0177\3\2\2\2\u0179"+
-		"\u0178\3\2\2\2\u017a+\3\2\2\2\u017b\u017e\5\u00dep\2\u017c\u017e\5\u00e0"+
-		"q\2\u017d\u017b\3\2\2\2\u017d\u017c\3\2\2\2\u017e-\3\2\2\2\u017f\u0182"+
-		"\5T+\2\u0180\u0182\5X-\2\u0181\u017f\3\2\2\2\u0181\u0180\3\2\2\2\u0182"+
-		"/\3\2\2\2\u0183\u0187\7\6\2\2\u0184\u0186\5\62\32\2\u0185\u0184\3\2\2"+
-		"\2\u0186\u0189\3\2\2\2\u0187\u0185\3\2\2\2\u0187\u0188\3\2\2\2\u0188\61"+
-		"\3\2\2\2\u0189\u0187\3\2\2\2\u018a\u0192\5\64\33\2\u018b\u0192\5\66\34"+
-		"\2\u018c\u0192\5\u0090I\2\u018d\u0192\58\35\2\u018e\u0192\5\u0096L\2\u018f"+
-		"\u0192\5\u0098M\2\u0190\u0192\5\u009aN\2\u0191\u018a\3\2\2\2\u0191\u018b"+
-		"\3\2\2\2\u0191\u018c\3\2\2\2\u0191\u018d\3\2\2\2\u0191\u018e\3\2\2\2\u0191"+
-		"\u018f\3\2\2\2\u0191\u0190\3\2\2\2\u0192\63\3\2\2\2\u0193\u0197\5\u0086"+
-		"D\2\u0194\u0197\5\u0088E\2\u0195\u0197\5\u008aF\2\u0196\u0193\3\2\2\2"+
-		"\u0196\u0194\3\2\2\2\u0196\u0195\3\2\2\2\u0197\65\3\2\2\2\u0198\u019b"+
-		"\5\u008cG\2\u0199\u019b\5\u008eH\2\u019a\u0198\3\2\2\2\u019a\u0199\3\2"+
-		"\2\2\u019b\67\3\2\2\2\u019c\u019f\5\u0092J\2\u019d\u019f\5\u0094K\2\u019e"+
-		"\u019c\3\2\2\2\u019e\u019d\3\2\2\2\u019f9\3\2\2\2\u01a0\u01a1\7\b\2\2"+
-		"\u01a1\u01a2\t\2\2\2\u01a2;\3\2\2\2\u01a3\u01a4\7\t\2\2\u01a4\u01a5\t"+
-		"\2\2\2\u01a5=\3\2\2\2\u01a6\u01a7\7\n\2\2\u01a7\u01a8\t\2\2\2\u01a8?\3"+
-		"\2\2\2\u01a9\u01aa\7\13\2\2\u01aa\u01ab\7a\2\2\u01abA\3\2\2\2\u01ac\u01ad"+
-		"\7\f\2\2\u01ad\u01ae\t\2\2\2\u01aeC\3\2\2\2\u01af\u01b0\7\r\2\2\u01b0"+
-		"\u01b1\t\2\2\2\u01b1E\3\2\2\2\u01b2\u01b3\7\16\2\2\u01b3\u01b4\t\2\2\2"+
-		"\u01b4G\3\2\2\2\u01b5\u01b6\7\17\2\2\u01b6\u01b7\t\2\2\2\u01b7I\3\2\2"+
-		"\2\u01b8\u01b9\7\20\2\2\u01b9\u01ba\7a\2\2\u01baK\3\2\2\2\u01bb\u01bc"+
-		"\7\21\2\2\u01bc\u01bd\t\2\2\2\u01bdM\3\2\2\2\u01be\u01bf\7\22\2\2\u01bf"+
-		"\u01c0\t\2\2\2\u01c0O\3\2\2\2\u01c1\u01c2\7\23\2\2\u01c2\u01c3\t\2\2\2"+
-		"\u01c3Q\3\2\2\2\u01c4\u01c5\7\24\2\2\u01c5\u01c6\7a\2\2\u01c6S\3\2\2\2"+
-		"\u01c7\u01c8\7\25\2\2\u01c8\u01c9\t\2\2\2\u01c9U\3\2\2\2\u01ca\u01cb\7"+
-		"\26\2\2\u01cb\u01cc\t\2\2\2\u01ccW\3\2\2\2\u01cd\u01ce\7\27\2\2\u01ce"+
-		"\u01cf\t\2\2\2\u01cfY\3\2\2\2\u01d0\u01d1\7\30\2\2\u01d1\u01d2\t\2\2\2"+
-		"\u01d2[\3\2\2\2\u01d3\u01d4\7\31\2\2\u01d4\u01d5\t\2\2\2\u01d5]\3\2\2"+
-		"\2\u01d6\u01d7\7\32\2\2\u01d7\u01d8\t\2\2\2\u01d8_\3\2\2\2\u01d9\u01da"+
-		"\7\33\2\2\u01da\u01db\t\2\2\2\u01dba\3\2\2\2\u01dc\u01dd\7\34\2\2\u01dd"+
-		"\u01de\t\2\2\2\u01dec\3\2\2\2\u01df\u01e0\7\35\2\2\u01e0\u01e1\t\2\2\2"+
-		"\u01e1e\3\2\2\2\u01e2\u01e3\7\36\2\2\u01e3\u01e4\7a\2\2\u01e4g\3\2\2\2"+
-		"\u01e5\u01e6\7\37\2\2\u01e6\u01ea\7a\2\2\u01e7\u01e9\7\7\2\2\u01e8\u01e7"+
-		"\3\2\2\2\u01e9\u01ec\3\2\2\2\u01ea\u01e8\3\2\2\2\u01ea\u01eb\3\2\2\2\u01eb"+
-		"\u01ed\3\2\2\2\u01ec\u01ea\3\2\2\2\u01ed\u01ee\7a\2\2\u01eei\3\2\2\2\u01ef"+
-		"\u01f0\7 \2\2\u01f0\u01f4\7a\2\2\u01f1\u01f3\7\7\2\2\u01f2\u01f1\3\2\2"+
-		"\2\u01f3\u01f6\3\2\2\2\u01f4\u01f2\3\2\2\2\u01f4\u01f5\3\2\2\2\u01f5\u01f7"+
-		"\3\2\2\2\u01f6\u01f4\3\2\2\2\u01f7\u01f8\7a\2\2\u01f8k\3\2\2\2\u01f9\u01fa"+
-		"\7!\2\2\u01fa\u01fe\7a\2\2\u01fb\u01fd\7\7\2\2\u01fc\u01fb\3\2\2\2\u01fd"+
-		"\u0200\3\2\2\2\u01fe\u01fc\3\2\2\2\u01fe\u01ff\3\2\2\2\u01ff\u0201\3\2"+
-		"\2\2\u0200\u01fe\3\2\2\2\u0201\u0202\7a\2\2\u0202m\3\2\2\2\u0203\u0204"+
-		"\7\"\2\2\u0204\u0208\7a\2\2\u0205\u0207\7\7\2\2\u0206\u0205\3\2\2\2\u0207"+
-		"\u020a\3\2\2\2\u0208\u0206\3\2\2\2\u0208\u0209\3\2\2\2\u0209\u020b\3\2"+
-		"\2\2\u020a\u0208\3\2\2\2\u020b\u020c\7a\2\2\u020co\3\2\2\2\u020d\u020e"+
-		"\7#\2\2\u020e\u0212\7a\2\2\u020f\u0211\7\7\2\2\u0210\u020f\3\2\2\2\u0211"+
-		"\u0214\3\2\2\2\u0212\u0210\3\2\2\2\u0212\u0213\3\2\2\2\u0213\u0215\3\2"+
-		"\2\2\u0214\u0212\3\2\2\2\u0215\u0216\7a\2\2\u0216q\3\2\2\2\u0217\u0218"+
-		"\7$\2\2\u0218\u0219\t\2\2\2\u0219s\3\2\2\2\u021a\u021b\7%\2\2\u021b\u021c"+
-		"\t\2\2\2\u021cu\3\2\2\2\u021d\u021e\7&\2\2\u021e\u021f\t\2\2\2\u021fw"+
-		"\3\2\2\2\u0220\u0221\7\'\2\2\u0221\u0222\t\2\2\2\u0222y\3\2\2\2\u0223"+
-		"\u0224\7(\2\2\u0224\u0225\t\2\2\2\u0225{\3\2\2\2\u0226\u0227\7)\2\2\u0227"+
-		"\u022b\7a\2\2\u0228\u022a\7\7\2\2\u0229\u0228\3\2\2\2\u022a\u022d\3\2"+
-		"\2\2\u022b\u0229\3\2\2\2\u022b\u022c\3\2\2\2\u022c\u022e\3\2\2\2\u022d"+
-		"\u022b\3\2\2\2\u022e\u022f\7a\2\2\u022f}\3\2\2\2\u0230\u0231\7*\2\2\u0231"+
-		"\u0232\7a\2\2\u0232\177\3\2\2\2\u0233\u0234\7+\2\2\u0234\u0235\t\2\2\2"+
-		"\u0235\u0081\3\2\2\2\u0236\u0237\7,\2\2\u0237\u0238\t\2\2\2\u0238\u0083"+
-		"\3\2\2\2\u0239\u023a\7-\2\2\u023a\u023b\7a\2\2\u023b\u0085\3\2\2\2\u023c"+
-		"\u023d\7.\2\2\u023d\u023e\t\2\2\2\u023e\u0087\3\2\2\2\u023f\u0240\7/\2"+
-		"\2\u0240\u0241\t\2\2\2\u0241\u0089\3\2\2\2\u0242\u0243\7\60\2\2\u0243"+
-		"\u0244\7a\2\2\u0244\u008b\3\2\2\2\u0245\u0246\7\61\2\2\u0246\u0247\7a"+
-		"\2\2\u0247\u008d\3\2\2\2\u0248\u0249\7\62\2\2\u0249\u024a\t\2\2\2\u024a"+
-		"\u008f\3\2\2\2\u024b\u024c\7\63\2\2\u024c\u024d\7a\2\2\u024d\u0091\3\2"+
-		"\2\2\u024e\u024f\7\64\2\2\u024f\u0253\t\2\2\2\u0250\u0252\7\7\2\2\u0251"+
-		"\u0250\3\2\2\2\u0252\u0255\3\2\2\2\u0253\u0251\3\2\2\2\u0253\u0254\3\2"+
-		"\2\2\u0254\u0256\3\2\2\2\u0255\u0253\3\2\2\2\u0256\u025a\t\2\2\2\u0257"+
-		"\u0259\7\7\2\2\u0258\u0257\3\2\2\2\u0259\u025c\3\2\2\2\u025a\u0258\3\2"+
-		"\2\2\u025a\u025b\3\2\2\2\u025b\u025d\3\2\2\2\u025c\u025a\3\2\2\2\u025d"+
-		"\u025e\t\2\2\2\u025e\u0093\3\2\2\2\u025f\u0260\7\65\2\2\u0260\u0264\7"+
-		"a\2\2\u0261\u0263\7\7\2\2\u0262\u0261\3\2\2\2\u0263\u0266\3\2\2\2\u0264"+
-		"\u0262\3\2\2\2\u0264\u0265\3\2\2\2\u0265\u0267\3\2\2\2\u0266\u0264\3\2"+
-		"\2\2\u0267\u026b\t\2\2\2\u0268\u026a\7\7\2\2\u0269\u0268\3\2\2\2\u026a"+
-		"\u026d\3\2\2\2\u026b\u0269\3\2\2\2\u026b\u026c\3\2\2\2\u026c\u026e\3\2"+
-		"\2\2\u026d\u026b\3\2\2\2\u026e\u026f\t\2\2\2\u026f\u0095\3\2\2\2\u0270"+
-		"\u0271\7\66\2\2\u0271\u0272\t\2\2\2\u0272\u0097\3\2\2\2\u0273\u0274\7"+
-		"\67\2\2\u0274\u0275\t\2\2\2\u0275\u0099\3\2\2\2\u0276\u0277\78\2\2\u0277"+
-		"\u0278\7a\2\2\u0278\u009b\3\2\2\2\u0279\u027a\79\2\2\u027a\u027b\t\2\2"+
-		"\2\u027b\u009d\3\2\2\2\u027c\u027d\7:\2\2\u027d\u027e\t\2\2\2\u027e\u009f"+
-		"\3\2\2\2\u027f\u0280\7;\2\2\u0280\u0281\7a\2\2\u0281\u00a1\3\2\2\2\u0282"+
-		"\u0283\7<\2\2\u0283\u0284\7a\2\2\u0284\u00a3\3\2\2\2\u0285\u0286\7=\2"+
-		"\2\u0286\u0287\t\2\2\2\u0287\u00a5\3\2\2\2\u0288\u0289\7>\2\2\u0289\u028a"+
-		"\7a\2\2\u028a\u00a7\3\2\2\2\u028b\u028c\7?\2\2\u028c\u0290\t\2\2\2\u028d"+
-		"\u028f\7\7\2\2\u028e\u028d\3\2\2\2\u028f\u0292\3\2\2\2\u0290\u028e\3\2"+
-		"\2\2\u0290\u0291\3\2\2\2\u0291\u0293\3\2\2\2\u0292\u0290\3\2\2\2\u0293"+
-		"\u0297\t\2\2\2\u0294\u0296\7\7\2\2\u0295\u0294\3\2\2\2\u0296\u0299\3\2"+
-		"\2\2\u0297\u0295\3\2\2\2\u0297\u0298\3\2\2\2\u0298\u029a\3\2\2\2\u0299"+
-		"\u0297\3\2\2\2\u029a\u029b\t\2\2\2\u029b\u00a9\3\2\2\2\u029c\u029d\7@"+
-		"\2\2\u029d\u02a1\7a\2\2\u029e\u02a0\7\7\2\2\u029f\u029e\3\2\2\2\u02a0"+
-		"\u02a3\3\2\2\2\u02a1\u029f\3\2\2\2\u02a1\u02a2\3\2\2\2\u02a2\u02a4\3\2"+
-		"\2\2\u02a3\u02a1\3\2\2\2\u02a4\u02a8\t\2\2\2\u02a5\u02a7\7\7\2\2\u02a6"+
-		"\u02a5\3\2\2\2\u02a7\u02aa\3\2\2\2\u02a8\u02a6\3\2\2\2\u02a8\u02a9\3\2"+
-		"\2\2\u02a9\u02ab\3\2\2\2\u02aa\u02a8\3\2\2\2\u02ab\u02ac\t\2\2\2\u02ac"+
-		"\u00ab\3\2\2\2\u02ad\u02ae\7A\2\2\u02ae\u02af\t\2\2\2\u02af\u00ad\3\2"+
-		"\2\2\u02b0\u02b1\7B\2\2\u02b1\u02b2\t\2\2\2\u02b2\u00af\3\2\2\2\u02b3"+
-		"\u02b4\7C\2\2\u02b4\u02b5\7a\2\2\u02b5\u00b1\3\2\2\2\u02b6\u02b7\7D\2"+
-		"\2\u02b7\u02b8\t\2\2\2\u02b8\u00b3\3\2\2\2\u02b9\u02ba\7E\2\2\u02ba\u02bb"+
-		"\t\2\2\2\u02bb\u00b5\3\2\2\2\u02bc\u02bd\7F\2\2\u02bd\u02be\7a\2\2\u02be"+
-		"\u00b7\3\2\2\2\u02bf\u02c0\7G\2\2\u02c0\u02c1\7a\2\2\u02c1\u00b9\3\2\2"+
-		"\2\u02c2\u02c3\7H\2\2\u02c3\u02c4\t\2\2\2\u02c4\u00bb\3\2\2\2\u02c5\u02c6"+
-		"\7I\2\2\u02c6\u02ca\7a\2\2\u02c7\u02c9\7\7\2\2\u02c8\u02c7\3\2\2\2\u02c9"+
-		"\u02cc\3\2\2\2\u02ca\u02c8\3\2\2\2\u02ca\u02cb\3\2\2\2\u02cb\u02cd\3\2"+
-		"\2\2\u02cc\u02ca\3\2\2\2\u02cd\u02ce\7a\2\2\u02ce\u00bd\3\2\2\2\u02cf"+
-		"\u02d0\7J\2\2\u02d0\u02d1\7a\2\2\u02d1\u00bf\3\2\2\2\u02d2\u02d3\7K\2"+
-		"\2\u02d3\u02d4\t\2\2\2\u02d4\u00c1\3\2\2\2\u02d5\u02d6\7L\2\2\u02d6\u02d7"+
-		"\t\2\2\2\u02d7\u00c3\3\2\2\2\u02d8\u02d9\7M\2\2\u02d9\u02da\t\2\2\2\u02da"+
-		"\u00c5\3\2\2\2\u02db\u02dc\7N\2\2\u02dc\u02dd\7a\2\2\u02dd\u00c7\3\2\2"+
-		"\2\u02de\u02df\7O\2\2\u02df\u02e0\7a\2\2\u02e0\u00c9\3\2\2\2\u02e1\u02e2"+
-		"\7P\2\2\u02e2\u02e6\t\2\2\2\u02e3\u02e5\7\7\2\2\u02e4\u02e3\3\2\2\2\u02e5"+
-		"\u02e8\3\2\2\2\u02e6\u02e4\3\2\2\2\u02e6\u02e7\3\2\2\2\u02e7\u02e9\3\2"+
-		"\2\2\u02e8\u02e6\3\2\2\2\u02e9\u02ed\7a\2\2\u02ea\u02ec\7\7\2\2\u02eb"+
-		"\u02ea\3\2\2\2\u02ec\u02ef\3\2\2\2\u02ed\u02eb\3\2\2\2\u02ed\u02ee\3\2"+
-		"\2\2\u02ee\u02f0\3\2\2\2\u02ef\u02ed\3\2\2\2\u02f0\u02f4\t\2\2\2\u02f1"+
-		"\u02f3\7\7\2\2\u02f2\u02f1\3\2\2\2\u02f3\u02f6\3\2\2\2\u02f4\u02f2\3\2"+
-		"\2\2\u02f4\u02f5\3\2\2\2\u02f5\u02f7\3\2\2\2\u02f6\u02f4\3\2\2\2\u02f7"+
-		"\u02f8\7a\2\2\u02f8\u00cb\3\2\2\2\u02f9\u02fa\7Q\2\2\u02fa\u02fe\t\2\2"+
-		"\2\u02fb\u02fd\7\7\2\2\u02fc\u02fb\3\2\2\2\u02fd\u0300\3\2\2\2\u02fe\u02fc"+
-		"\3\2\2\2\u02fe\u02ff\3\2\2\2\u02ff\u0301\3\2\2\2\u0300\u02fe\3\2\2\2\u0301"+
-		"\u0305\7a\2\2\u0302\u0304\7\7\2\2\u0303\u0302\3\2\2\2\u0304\u0307\3\2"+
-		"\2\2\u0305\u0303\3\2\2\2\u0305\u0306\3\2\2\2\u0306\u0308\3\2\2\2\u0307"+
-		"\u0305\3\2\2\2\u0308\u030c\7a\2\2\u0309\u030b\7\7\2\2\u030a\u0309\3\2"+
-		"\2\2\u030b\u030e\3\2\2\2\u030c\u030a\3\2\2\2\u030c\u030d\3\2\2\2\u030d"+
-		"\u030f\3\2\2\2\u030e\u030c\3\2\2\2\u030f\u0310\7a\2\2\u0310\u00cd\3\2"+
-		"\2\2\u0311\u0312\7R\2\2\u0312\u0316\t\2\2\2\u0313\u0315\7\7\2\2\u0314"+
-		"\u0313\3\2\2\2\u0315\u0318\3\2\2\2\u0316\u0314\3\2\2\2\u0316\u0317\3\2"+
-		"\2\2\u0317\u0319\3\2\2\2\u0318\u0316\3\2\2\2\u0319\u031d\7a\2\2\u031a"+
-		"\u031c\7\7\2\2\u031b\u031a\3\2\2\2\u031c\u031f\3\2\2\2\u031d\u031b\3\2"+
-		"\2\2\u031d\u031e\3\2\2\2\u031e\u0320\3\2\2\2\u031f\u031d\3\2\2\2\u0320"+
-		"\u0324\t\2\2\2\u0321\u0323\7\7\2\2\u0322\u0321\3\2\2\2\u0323\u0326\3\2"+
-		"\2\2\u0324\u0322\3\2\2\2\u0324\u0325\3\2\2\2\u0325\u0328\3\2\2\2\u0326"+
-		"\u0324\3\2\2\2\u0327\u0329\7a\2\2\u0328\u0327\3\2\2\2\u0328\u0329\3\2"+
-		"\2\2\u0329\u00cf\3\2\2\2\u032a\u032b\7S\2\2\u032b\u032f\7a\2\2\u032c\u032e"+
-		"\7\7\2\2\u032d\u032c\3\2\2\2\u032e\u0331\3\2\2\2\u032f\u032d\3\2\2\2\u032f"+
-		"\u0330\3\2\2\2\u0330\u0332\3\2\2\2\u0331\u032f\3\2\2\2\u0332\u0336\7a"+
-		"\2\2\u0333\u0335\7\7\2\2\u0334\u0333\3\2\2\2\u0335\u0338\3\2\2\2\u0336"+
-		"\u0334\3\2\2\2\u0336\u0337\3\2\2\2\u0337\u0339\3\2\2\2\u0338\u0336\3\2"+
-		"\2\2\u0339\u033d\7a\2\2\u033a\u033c\7\7\2\2\u033b\u033a\3\2\2\2\u033c"+
-		"\u033f\3\2\2\2\u033d\u033b\3\2\2\2\u033d\u033e\3\2\2\2\u033e\u0341\3\2"+
-		"\2\2\u033f\u033d\3\2\2\2\u0340\u0342\7a\2\2\u0341\u0340\3\2\2\2\u0341"+
-		"\u0342\3\2\2\2\u0342\u00d1\3\2\2\2\u0343\u0344\7T\2\2\u0344\u0348\t\2"+
-		"\2\2\u0345\u0347\7\7\2\2\u0346\u0345\3\2\2\2\u0347\u034a\3\2\2\2\u0348"+
-		"\u0346\3\2\2\2\u0348\u0349\3\2\2\2\u0349\u034b\3\2\2\2\u034a\u0348\3\2"+
-		"\2\2\u034b\u034f\7a\2\2\u034c\u034e\7\7\2\2\u034d\u034c\3\2\2\2\u034e"+
-		"\u0351\3\2\2\2\u034f\u034d\3\2\2\2\u034f\u0350\3\2\2\2\u0350\u0352\3\2"+
-		"\2\2\u0351\u034f\3\2\2\2\u0352\u0356\t\2\2\2\u0353\u0355\7\7\2\2\u0354"+
-		"\u0353\3\2\2\2\u0355\u0358\3\2\2\2\u0356\u0354\3\2\2\2\u0356\u0357\3\2"+
-		"\2\2\u0357\u0360\3\2\2\2\u0358\u0356\3\2\2\2\u0359\u035d\7a\2\2\u035a"+
-		"\u035c\7\7\2\2\u035b\u035a\3\2\2\2\u035c\u035f\3\2\2\2\u035d\u035b\3\2"+
-		"\2\2\u035d\u035e\3\2\2\2\u035e\u0361\3\2\2\2\u035f\u035d\3\2\2\2\u0360"+
-		"\u0359\3\2\2\2\u0360\u0361\3\2\2\2\u0361\u0369\3\2\2\2\u0362\u0366\7a"+
-		"\2\2\u0363\u0365\7\7\2\2\u0364\u0363\3\2\2\2\u0365\u0368\3\2\2\2\u0366"+
-		"\u0364\3\2\2\2\u0366\u0367\3\2\2\2\u0367\u036a\3\2\2\2\u0368\u0366\3\2"+
-		"\2\2\u0369\u0362\3\2\2\2\u0369\u036a\3\2\2\2\u036a\u0372\3\2\2\2\u036b"+
-		"\u036f\7a\2\2\u036c\u036e\7\7\2\2\u036d\u036c\3\2\2\2\u036e\u0371\3\2"+
-		"\2\2\u036f\u036d\3\2\2\2\u036f\u0370\3\2\2\2\u0370\u0373\3\2\2\2\u0371"+
-		"\u036f\3\2\2\2\u0372\u036b\3\2\2\2\u0372\u0373\3\2\2\2\u0373\u0375\3\2"+
-		"\2\2\u0374\u0376\t\2\2\2\u0375\u0374\3\2\2\2\u0375\u0376\3\2\2\2\u0376"+
-		"\u00d3\3\2\2\2\u0377\u0378\7U\2\2\u0378\u037c\t\2\2\2\u0379\u037b\7\7"+
-		"\2\2\u037a\u0379\3\2\2\2\u037b\u037e\3\2\2\2\u037c\u037a\3\2\2\2\u037c"+
-		"\u037d\3\2\2\2\u037d\u037f\3\2\2\2\u037e\u037c\3\2\2\2\u037f\u0383\7a"+
-		"\2\2\u0380\u0382\7\7\2\2\u0381\u0380\3\2\2\2\u0382\u0385\3\2\2\2\u0383"+
-		"\u0381\3\2\2\2\u0383\u0384\3\2\2\2\u0384\u0386\3\2\2\2\u0385\u0383\3\2"+
-		"\2\2\u0386\u038a\t\2\2\2\u0387\u0389\7\7\2\2\u0388\u0387\3\2\2\2\u0389"+
-		"\u038c\3\2\2\2\u038a\u0388\3\2\2\2\u038a\u038b\3\2\2\2\u038b\u0394\3\2"+
-		"\2\2\u038c\u038a\3\2\2\2\u038d\u0391\7a\2\2\u038e\u0390\7\7\2\2\u038f"+
-		"\u038e\3\2\2\2\u0390\u0393\3\2\2\2\u0391\u038f\3\2\2\2\u0391\u0392\3\2"+
-		"\2\2\u0392\u0395\3\2\2\2\u0393\u0391\3\2\2\2\u0394\u038d\3\2\2\2\u0394"+
-		"\u0395\3\2\2\2\u0395\u039d\3\2\2\2\u0396\u039a\7a\2\2\u0397\u0399\7\7"+
-		"\2\2\u0398\u0397\3\2\2\2\u0399\u039c\3\2\2\2\u039a\u0398\3\2\2\2\u039a"+
-		"\u039b\3\2\2\2\u039b\u039e\3\2\2\2\u039c\u039a\3\2\2\2\u039d\u0396\3\2"+
-		"\2\2\u039d\u039e\3\2\2\2\u039e\u03a6\3\2\2\2\u039f\u03a3\7a\2\2\u03a0"+
-		"\u03a2\7\7\2\2\u03a1\u03a0\3\2\2\2\u03a2\u03a5\3\2\2\2\u03a3\u03a1\3\2"+
-		"\2\2\u03a3\u03a4\3\2\2\2\u03a4\u03a7\3\2\2\2\u03a5\u03a3\3\2\2\2\u03a6"+
-		"\u039f\3\2\2\2\u03a6\u03a7\3\2\2\2\u03a7\u03a9\3\2\2\2\u03a8\u03aa\t\2"+
-		"\2\2\u03a9\u03a8\3\2\2\2\u03a9\u03aa\3\2\2\2\u03aa\u00d5\3\2\2\2\u03ab"+
-		"\u03ac\7V\2\2\u03ac\u03b0\t\2\2\2\u03ad\u03af\7\7\2\2\u03ae\u03ad\3\2"+
-		"\2\2\u03af\u03b2\3\2\2\2\u03b0\u03ae\3\2\2\2\u03b0\u03b1\3\2\2\2\u03b1"+
-		"\u03b3\3\2\2\2\u03b2\u03b0\3\2\2\2\u03b3\u03b7\7a\2\2\u03b4\u03b6\7\7"+
-		"\2\2\u03b5\u03b4\3\2\2\2\u03b6\u03b9\3\2\2\2\u03b7\u03b5\3\2\2\2\u03b7"+
-		"\u03b8\3\2\2\2\u03b8\u03ba\3\2\2\2\u03b9\u03b7\3\2\2\2\u03ba\u03be\t\2"+
-		"\2\2\u03bb\u03bd\7\7\2\2\u03bc\u03bb\3\2\2\2\u03bd\u03c0\3\2\2\2\u03be"+
-		"\u03bc\3\2\2\2\u03be\u03bf\3\2\2\2\u03bf\u03c8\3\2\2\2\u03c0\u03be\3\2"+
-		"\2\2\u03c1\u03c5\7a\2\2\u03c2\u03c4\7\7\2\2\u03c3\u03c2\3\2\2\2\u03c4"+
-		"\u03c7\3\2\2\2\u03c5\u03c3\3\2\2\2\u03c5\u03c6\3\2\2\2\u03c6\u03c9\3\2"+
-		"\2\2\u03c7\u03c5\3\2\2\2\u03c8\u03c1\3\2\2\2\u03c8\u03c9\3\2\2\2\u03c9"+
-		"\u03cb\3\2\2\2\u03ca\u03cc\7a\2\2\u03cb\u03ca\3\2\2\2\u03cb\u03cc\3\2"+
-		"\2\2\u03cc\u00d7\3\2\2\2\u03cd\u03ce\7W\2\2\u03ce\u03d2\7a\2\2\u03cf\u03d1"+
-		"\7\7\2\2\u03d0\u03cf\3\2\2\2\u03d1\u03d4\3\2\2\2\u03d2\u03d0\3\2\2\2\u03d2"+
-		"\u03d3\3\2\2\2\u03d3\u03d5\3\2\2\2\u03d4\u03d2\3\2\2\2\u03d5\u03d9\7a"+
-		"\2\2\u03d6\u03d8\7\7\2\2\u03d7\u03d6\3\2\2\2\u03d8\u03db\3\2\2\2\u03d9"+
-		"\u03d7\3\2\2\2\u03d9\u03da\3\2\2\2\u03da\u03dc\3\2\2\2\u03db\u03d9\3\2"+
-		"\2\2\u03dc\u03e0\7a\2\2\u03dd\u03df\7\7\2\2\u03de\u03dd\3\2\2\2\u03df"+
-		"\u03e2\3\2\2\2\u03e0\u03de\3\2\2\2\u03e0\u03e1\3\2\2\2\u03e1\u03ea\3\2"+
-		"\2\2\u03e2\u03e0\3\2\2\2\u03e3\u03e7\7a\2\2\u03e4\u03e6\7\7\2\2\u03e5"+
-		"\u03e4\3\2\2\2\u03e6\u03e9\3\2\2\2\u03e7\u03e5\3\2\2\2\u03e7\u03e8\3\2"+
-		"\2\2\u03e8\u03eb\3\2\2\2\u03e9\u03e7\3\2\2\2\u03ea\u03e3\3\2\2\2\u03ea"+
-		"\u03eb\3\2\2\2\u03eb\u03ed\3\2\2\2\u03ec\u03ee\7a\2\2\u03ed\u03ec\3\2"+
-		"\2\2\u03ed\u03ee\3\2\2\2\u03ee\u00d9\3\2\2\2\u03ef\u03f0\7X\2\2\u03f0"+
-		"\u03f4\t\2\2\2\u03f1\u03f3\7\7\2\2\u03f2\u03f1\3\2\2\2\u03f3\u03f6\3\2"+
-		"\2\2\u03f4\u03f2\3\2\2\2\u03f4\u03f5\3\2\2\2\u03f5\u03f7\3\2\2\2\u03f6"+
-		"\u03f4\3\2\2\2\u03f7\u03fb\7a\2\2\u03f8\u03fa\7\7\2\2\u03f9\u03f8\3\2"+
-		"\2\2\u03fa\u03fd\3\2\2\2\u03fb\u03f9\3\2\2\2\u03fb\u03fc\3\2\2\2\u03fc"+
-		"\u03fe\3\2\2\2\u03fd\u03fb\3\2\2\2\u03fe\u0402\t\2\2\2\u03ff\u0401\7\7"+
-		"\2\2\u0400\u03ff\3\2\2\2\u0401\u0404\3\2\2\2\u0402\u0400\3\2\2\2\u0402"+
-		"\u0403\3\2\2\2\u0403\u040c\3\2\2\2\u0404\u0402\3\2\2\2\u0405\u0409\7a"+
-		"\2\2\u0406\u0408\7\7\2\2\u0407\u0406\3\2\2\2\u0408\u040b\3\2\2\2\u0409"+
-		"\u0407\3\2\2\2\u0409\u040a\3\2\2\2\u040a\u040d\3\2\2\2\u040b\u0409\3\2"+
-		"\2\2\u040c\u0405\3\2\2\2\u040c\u040d\3\2\2\2\u040d\u0415\3\2\2\2\u040e"+
-		"\u0412\7a\2\2\u040f\u0411\7\7\2\2\u0410\u040f\3\2\2\2\u0411\u0414\3\2"+
-		"\2\2\u0412\u0410\3\2\2\2\u0412\u0413\3\2\2\2\u0413\u0416\3\2\2\2\u0414"+
-		"\u0412\3\2\2\2\u0415\u040e\3\2\2\2\u0415\u0416\3\2\2\2\u0416\u041e\3\2"+
-		"\2\2\u0417\u041b\7a\2\2\u0418\u041a\7\7\2\2\u0419\u0418\3\2\2\2\u041a"+
-		"\u041d\3\2\2\2\u041b\u0419\3\2\2\2\u041b\u041c\3\2\2\2\u041c\u041f\3\2"+
-		"\2\2\u041d\u041b\3\2\2\2\u041e\u0417\3\2\2\2\u041e\u041f\3\2\2\2\u041f"+
-		"\u0427\3\2\2\2\u0420\u0424\7a\2\2\u0421\u0423\7\7\2\2\u0422\u0421\3\2"+
-		"\2\2\u0423\u0426\3\2\2\2\u0424\u0422\3\2\2\2\u0424\u0425\3\2\2\2\u0425"+
-		"\u0428\3\2\2\2\u0426\u0424\3\2\2\2\u0427\u0420\3\2\2\2\u0427\u0428\3\2"+
-		"\2\2\u0428\u0429\3\2\2\2\u0429\u042a\t\2\2\2\u042a\u00db\3\2\2\2\u042b"+
-		"\u042c\7Y\2\2\u042c\u0430\t\2\2\2\u042d\u042f\7\7\2\2\u042e\u042d\3\2"+
-		"\2\2\u042f\u0432\3\2\2\2\u0430\u042e\3\2\2\2\u0430\u0431\3\2\2\2\u0431"+
-		"\u0433\3\2\2\2\u0432\u0430\3\2\2\2\u0433\u0437\7a\2\2\u0434\u0436\7\7"+
-		"\2\2\u0435\u0434\3\2\2\2\u0436\u0439\3\2\2\2\u0437\u0435\3\2\2\2\u0437"+
-		"\u0438\3\2\2\2\u0438\u043a\3\2\2\2\u0439\u0437\3\2\2\2\u043a\u043e\t\2"+
-		"\2\2\u043b\u043d\7\7\2\2\u043c\u043b\3\2\2\2\u043d\u0440\3\2\2\2\u043e"+
-		"\u043c\3\2\2\2\u043e\u043f\3\2\2\2\u043f\u0448\3\2\2\2\u0440\u043e\3\2"+
-		"\2\2\u0441\u0445\7a\2\2\u0442\u0444\7\7\2\2\u0443\u0442\3\2\2\2\u0444"+
-		"\u0447\3\2\2\2\u0445\u0443\3\2\2\2\u0445\u0446\3\2\2\2\u0446\u0449\3\2"+
-		"\2\2\u0447\u0445\3\2\2\2\u0448\u0441\3\2\2\2\u0448\u0449\3\2\2\2\u0449"+
-		"\u044a\3\2\2\2\u044a\u044e\7a\2\2\u044b\u044d\7\7\2\2\u044c\u044b\3\2"+
-		"\2\2\u044d\u0450\3\2\2\2\u044e\u044c\3\2\2\2\u044e\u044f\3\2\2\2\u044f"+
-		"\u0458\3\2\2\2\u0450\u044e\3\2\2\2\u0451\u0455\7a\2\2\u0452\u0454\7\7"+
-		"\2\2\u0453\u0452\3\2\2\2\u0454\u0457\3\2\2\2\u0455\u0453\3\2\2\2\u0455"+
-		"\u0456\3\2\2\2\u0456\u0459\3\2\2\2\u0457\u0455\3\2\2\2\u0458\u0451\3\2"+
-		"\2\2\u0458\u0459\3\2\2\2\u0459\u0461\3\2\2\2\u045a\u045e\7a\2\2\u045b"+
-		"\u045d\7\7\2\2\u045c\u045b\3\2\2\2\u045d\u0460\3\2\2\2\u045e\u045c\3\2"+
-		"\2\2\u045e\u045f\3\2\2\2\u045f\u0462\3\2\2\2\u0460\u045e\3\2\2\2\u0461"+
-		"\u045a\3\2\2\2\u0461\u0462\3\2\2\2\u0462\u0464\3\2\2\2\u0463\u0465\t\2"+
-		"\2\2\u0464\u0463\3\2\2\2\u0464\u0465\3\2\2\2\u0465\u00dd\3\2\2\2\u0466"+
-		"\u0467\7Z\2\2\u0467\u046b\t\2\2\2\u0468\u046a\7\7\2\2\u0469\u0468\3\2"+
-		"\2\2\u046a\u046d\3\2\2\2\u046b\u0469\3\2\2\2\u046b\u046c\3\2\2\2\u046c"+
-		"\u046e\3\2\2\2\u046d\u046b\3\2\2\2\u046e\u0472\7a\2\2\u046f\u0471\7\7"+
-		"\2\2\u0470\u046f\3\2\2\2\u0471\u0474\3\2\2\2\u0472\u0470\3\2\2\2\u0472"+
-		"\u0473\3\2\2\2\u0473\u0475\3\2\2\2\u0474\u0472\3\2\2\2\u0475\u0479\7a"+
-		"\2\2\u0476\u0478\7\7\2\2\u0477\u0476\3\2\2\2\u0478\u047b\3\2\2\2\u0479"+
-		"\u0477\3\2\2\2\u0479\u047a\3\2\2\2\u047a\u047c\3\2\2\2\u047b\u0479\3\2"+
-		"\2\2\u047c\u047d\t\2\2\2\u047d\u00df\3\2\2\2\u047e\u047f\7[\2\2\u047f"+
-		"\u0480\t\2\2\2\u0480\u00e1\3\2\2\2\u0481\u0482\7\\\2\2\u0482\u0486\t\2"+
-		"\2\2\u0483\u0485\7\7\2\2\u0484\u0483\3\2\2\2\u0485\u0488\3\2\2\2\u0486"+
-		"\u0484\3\2\2\2\u0486\u0487\3\2\2\2\u0487\u0489\3\2\2\2\u0488\u0486\3\2"+
-		"\2\2\u0489\u048d\7a\2\2\u048a\u048c\7\7\2\2\u048b\u048a\3\2\2\2\u048c"+
-		"\u048f\3\2\2\2\u048d\u048b\3\2\2\2\u048d\u048e\3\2\2\2\u048e\u0490\3\2"+
-		"\2\2\u048f\u048d\3\2\2\2\u0490\u0494\7a\2\2\u0491\u0493\7\7\2\2\u0492"+
-		"\u0491\3\2\2\2\u0493\u0496\3\2\2\2\u0494\u0492\3\2\2\2\u0494\u0495\3\2"+
-		"\2\2\u0495\u0497\3\2\2\2\u0496\u0494\3\2\2\2\u0497\u0498\t\2\2\2\u0498"+
-		"\u00e3\3\2\2\2\u0499\u049a\7]\2\2\u049a\u049b\t\2\2\2\u049b\u00e5\3\2"+
-		"\2\2w\u00e9\u00ed\u00f7\u0123\u0126\u012b\u0139\u013d\u0141\u0145\u0149"+
-		"\u014e\u0152\u0156\u015a\u015e\u0162\u0167\u016b\u016f\u0179\u017d\u0181"+
-		"\u0187\u0191\u0196\u019a\u019e\u01ea\u01f4\u01fe\u0208\u0212\u022b\u0253"+
-		"\u025a\u0264\u026b\u0290\u0297\u02a1\u02a8\u02ca\u02e6\u02ed\u02f4\u02fe"+
-		"\u0305\u030c\u0316\u031d\u0324\u0328\u032f\u0336\u033d\u0341\u0348\u034f"+
-		"\u0356\u035d\u0360\u0366\u0369\u036f\u0372\u0375\u037c\u0383\u038a\u0391"+
-		"\u0394\u039a\u039d\u03a3\u03a6\u03a9\u03b0\u03b7\u03be\u03c5\u03c8\u03cb"+
-		"\u03d2\u03d9\u03e0\u03e7\u03ea\u03ed\u03f4\u03fb\u0402\u0409\u040c\u0412"+
-		"\u0415\u041b\u041e\u0424\u0427\u0430\u0437\u043e\u0445\u0448\u044e\u0455"+
-		"\u0458\u045e\u0461\u0464\u046b\u0472\u0479\u0486\u048d\u0494";
+		"\2\2\u00f7\u00f8\3\2\2\2\u00f8\7\3\2\2\2\u00f9\u0125\5\20\t\2\u00fa\u0125"+
+		"\5:\36\2\u00fb\u0125\5<\37\2\u00fc\u0125\5B\"\2\u00fd\u0125\5D#\2\u00fe"+
+		"\u0125\5$\23\2\u00ff\u0125\5L\'\2\u0100\u0125\5N(\2\u0101\u0125\5P)\2"+
+		"\u0102\u0125\5&\24\2\u0103\u0125\5\22\n\2\u0104\u0125\5^\60\2\u0105\u0125"+
+		"\5`\61\2\u0106\u0125\5b\62\2\u0107\u0125\5\36\20\2\u0108\u0125\5n8\2\u0109"+
+		"\u0125\5p9\2\u010a\u0125\5h\65\2\u010b\u0125\5j\66\2\u010c\u0125\5\24"+
+		"\13\2\u010d\u0125\5v<\2\u010e\u0125\5\26\f\2\u010f\u0125\5|?\2\u0110\u0125"+
+		"\5~@\2\u0111\u0125\5\u0080A\2\u0112\u0125\5\u0082B\2\u0113\u0125\5\u0084"+
+		"C\2\u0114\u0125\5\60\31\2\u0115\u0125\5\30\r\2\u0116\u0125\5\32\16\2\u0117"+
+		"\u0125\5\u00a6T\2\u0118\u0125\5\34\17\2\u0119\u0125\5\u00acW\2\u011a\u0125"+
+		"\5\u00aeX\2\u011b\u0125\5\u00b0Y\2\u011c\u0125\5\u00b2Z\2\u011d\u0125"+
+		"\5\u00b4[\2\u011e\u0125\5\u00b6\\\2\u011f\u0125\5\u00b8]\2\u0120\u0125"+
+		"\5\u00ba^\2\u0121\u0125\5\n\6\2\u0122\u0125\5 \21\2\u0123\u0125\5\"\22"+
+		"\2\u0124\u00f9\3\2\2\2\u0124\u00fa\3\2\2\2\u0124\u00fb\3\2\2\2\u0124\u00fc"+
+		"\3\2\2\2\u0124\u00fd\3\2\2\2\u0124\u00fe\3\2\2\2\u0124\u00ff\3\2\2\2\u0124"+
+		"\u0100\3\2\2\2\u0124\u0101\3\2\2\2\u0124\u0102\3\2\2\2\u0124\u0103\3\2"+
+		"\2\2\u0124\u0104\3\2\2\2\u0124\u0105\3\2\2\2\u0124\u0106\3\2\2\2\u0124"+
+		"\u0107\3\2\2\2\u0124\u0108\3\2\2\2\u0124\u0109\3\2\2\2\u0124\u010a\3\2"+
+		"\2\2\u0124\u010b\3\2\2\2\u0124\u010c\3\2\2\2\u0124\u010d\3\2\2\2\u0124"+
+		"\u010e\3\2\2\2\u0124\u010f\3\2\2\2\u0124\u0110\3\2\2\2\u0124\u0111\3\2"+
+		"\2\2\u0124\u0112\3\2\2\2\u0124\u0113\3\2\2\2\u0124\u0114\3\2\2\2\u0124"+
+		"\u0115\3\2\2\2\u0124\u0116\3\2\2\2\u0124\u0117\3\2\2\2\u0124\u0118\3\2"+
+		"\2\2\u0124\u0119\3\2\2\2\u0124\u011a\3\2\2\2\u0124\u011b\3\2\2\2\u0124"+
+		"\u011c\3\2\2\2\u0124\u011d\3\2\2\2\u0124\u011e\3\2\2\2\u0124\u011f\3\2"+
+		"\2\2\u0124\u0120\3\2\2\2\u0124\u0121\3\2\2\2\u0124\u0122\3\2\2\2\u0124"+
+		"\u0123\3\2\2\2\u0125\t\3\2\2\2\u0126\u0128\5\f\7\2\u0127\u0126\3\2\2\2"+
+		"\u0127\u0128\3\2\2\2\u0128\u012a\3\2\2\2\u0129\u012b\5\16\b\2\u012a\u0129"+
+		"\3\2\2\2\u012b\u012c\3\2\2\2\u012c\u012a\3\2\2\2\u012c\u012d\3\2\2\2\u012d"+
+		"\13\3\2\2\2\u012e\u012f\7\5\2\2\u012f\r\3\2\2\2\u0130\u013b\5R*\2\u0131"+
+		"\u013b\5.\30\2\u0132\u013b\5\u00bc_\2\u0133\u013b\5\u00be`\2\u0134\u013b"+
+		"\5(\25\2\u0135\u013b\5\u00c4c\2\u0136\u013b\5\u00c6d\2\u0137\u013b\5\u00c8"+
+		"e\2\u0138\u013b\5*\26\2\u0139\u013b\5,\27\2\u013a\u0130\3\2\2\2\u013a"+
+		"\u0131\3\2\2\2\u013a\u0132\3\2\2\2\u013a\u0133\3\2\2\2\u013a\u0134\3\2"+
+		"\2\2\u013a\u0135\3\2\2\2\u013a\u0136\3\2\2\2\u013a\u0137\3\2\2\2\u013a"+
+		"\u0138\3\2\2\2\u013a\u0139\3\2\2\2\u013b\17\3\2\2\2\u013c\u013f\5> \2"+
+		"\u013d\u013f\5@!\2\u013e\u013c\3\2\2\2\u013e\u013d\3\2\2\2\u013f\21\3"+
+		"\2\2\2\u0140\u0143\5Z.\2\u0141\u0143\5\\/\2\u0142\u0140\3\2\2\2\u0142"+
+		"\u0141\3\2\2\2\u0143\23\3\2\2\2\u0144\u0147\5r:\2\u0145\u0147\5t;\2\u0146"+
+		"\u0144\3\2\2\2\u0146\u0145\3\2\2\2\u0147\25\3\2\2\2\u0148\u014b\5x=\2"+
+		"\u0149\u014b\5z>\2\u014a\u0148\3\2\2\2\u014a\u0149\3\2\2\2\u014b\27\3"+
+		"\2\2\2\u014c\u0150\5\u009cO\2\u014d\u0150\5\u009eP\2\u014e\u0150\5\u00a0"+
+		"Q\2\u014f\u014c\3\2\2\2\u014f\u014d\3\2\2\2\u014f\u014e\3\2\2\2\u0150"+
+		"\31\3\2\2\2\u0151\u0154\5\u00a2R\2\u0152\u0154\5\u00a4S\2\u0153\u0151"+
+		"\3\2\2\2\u0153\u0152\3\2\2\2\u0154\33\3\2\2\2\u0155\u0158\5\u00a8U\2\u0156"+
+		"\u0158\5\u00aaV\2\u0157\u0155\3\2\2\2\u0157\u0156\3\2\2\2\u0158\35\3\2"+
+		"\2\2\u0159\u015c\5d\63\2\u015a\u015c\5f\64\2\u015b\u0159\3\2\2\2\u015b"+
+		"\u015a\3\2\2\2\u015c\37\3\2\2\2\u015d\u0160\5\u00caf\2\u015e\u0160\5\u00cc"+
+		"g\2\u015f\u015d\3\2\2\2\u015f\u015e\3\2\2\2\u0160!\3\2\2\2\u0161\u0164"+
+		"\5\u00e2r\2\u0162\u0164\5\u00e4s\2\u0163\u0161\3\2\2\2\u0163\u0162\3\2"+
+		"\2\2\u0164#\3\2\2\2\u0165\u0169\5F$\2\u0166\u0169\5H%\2\u0167\u0169\5"+
+		"J&\2\u0168\u0165\3\2\2\2\u0168\u0166\3\2\2\2\u0168\u0167\3\2\2\2\u0169"+
+		"%\3\2\2\2\u016a\u016d\5T+\2\u016b\u016d\5V,\2\u016c\u016a\3\2\2\2\u016c"+
+		"\u016b\3\2\2\2\u016d\'\3\2\2\2\u016e\u0171\5\u00c0a\2\u016f\u0171\5\u00c2"+
+		"b\2\u0170\u016e\3\2\2\2\u0170\u016f\3\2\2\2\u0171)\3\2\2\2\u0172\u017b"+
+		"\5\u00ceh\2\u0173\u017b\5\u00d0i\2\u0174\u017b\5\u00d2j\2\u0175\u017b"+
+		"\5\u00d4k\2\u0176\u017b\5\u00d6l\2\u0177\u017b\5\u00d8m\2\u0178\u017b"+
+		"\5\u00dan\2\u0179\u017b\5\u00dco\2\u017a\u0172\3\2\2\2\u017a\u0173\3\2"+
+		"\2\2\u017a\u0174\3\2\2\2\u017a\u0175\3\2\2\2\u017a\u0176\3\2\2\2\u017a"+
+		"\u0177\3\2\2\2\u017a\u0178\3\2\2\2\u017a\u0179\3\2\2\2\u017b+\3\2\2\2"+
+		"\u017c\u017f\5\u00dep\2\u017d\u017f\5\u00e0q\2\u017e\u017c\3\2\2\2\u017e"+
+		"\u017d\3\2\2\2\u017f-\3\2\2\2\u0180\u0183\5T+\2\u0181\u0183\5X-\2\u0182"+
+		"\u0180\3\2\2\2\u0182\u0181\3\2\2\2\u0183/\3\2\2\2\u0184\u0188\7\6\2\2"+
+		"\u0185\u0187\5\62\32\2\u0186\u0185\3\2\2\2\u0187\u018a\3\2\2\2\u0188\u0186"+
+		"\3\2\2\2\u0188\u0189\3\2\2\2\u0189\61\3\2\2\2\u018a\u0188\3\2\2\2\u018b"+
+		"\u0193\5\64\33\2\u018c\u0193\5\66\34\2\u018d\u0193\5\u0090I\2\u018e\u0193"+
+		"\58\35\2\u018f\u0193\5\u0096L\2\u0190\u0193\5\u0098M\2\u0191\u0193\5\u009a"+
+		"N\2\u0192\u018b\3\2\2\2\u0192\u018c\3\2\2\2\u0192\u018d\3\2\2\2\u0192"+
+		"\u018e\3\2\2\2\u0192\u018f\3\2\2\2\u0192\u0190\3\2\2\2\u0192\u0191\3\2"+
+		"\2\2\u0193\63\3\2\2\2\u0194\u0198\5\u0086D\2\u0195\u0198\5\u0088E\2\u0196"+
+		"\u0198\5\u008aF\2\u0197\u0194\3\2\2\2\u0197\u0195\3\2\2\2\u0197\u0196"+
+		"\3\2\2\2\u0198\65\3\2\2\2\u0199\u019c\5\u008cG\2\u019a\u019c\5\u008eH"+
+		"\2\u019b\u0199\3\2\2\2\u019b\u019a\3\2\2\2\u019c\67\3\2\2\2\u019d\u01a0"+
+		"\5\u0092J\2\u019e\u01a0\5\u0094K\2\u019f\u019d\3\2\2\2\u019f\u019e\3\2"+
+		"\2\2\u01a09\3\2\2\2\u01a1\u01a2\7\b\2\2\u01a2\u01a3\t\2\2\2\u01a3;\3\2"+
+		"\2\2\u01a4\u01a5\7\t\2\2\u01a5\u01a6\t\2\2\2\u01a6=\3\2\2\2\u01a7\u01a8"+
+		"\7\n\2\2\u01a8\u01a9\t\2\2\2\u01a9?\3\2\2\2\u01aa\u01ab\7\13\2\2\u01ab"+
+		"\u01ac\7a\2\2\u01acA\3\2\2\2\u01ad\u01ae\7\f\2\2\u01ae\u01af\t\2\2\2\u01af"+
+		"C\3\2\2\2\u01b0\u01b1\7\r\2\2\u01b1\u01b2\t\2\2\2\u01b2E\3\2\2\2\u01b3"+
+		"\u01b4\7\16\2\2\u01b4\u01b5\t\2\2\2\u01b5G\3\2\2\2\u01b6\u01b7\7\17\2"+
+		"\2\u01b7\u01b8\t\2\2\2\u01b8I\3\2\2\2\u01b9\u01ba\7\20\2\2\u01ba\u01bb"+
+		"\7a\2\2\u01bbK\3\2\2\2\u01bc\u01bd\7\21\2\2\u01bd\u01be\t\2\2\2\u01be"+
+		"M\3\2\2\2\u01bf\u01c0\7\22\2\2\u01c0\u01c1\t\2\2\2\u01c1O\3\2\2\2\u01c2"+
+		"\u01c3\7\23\2\2\u01c3\u01c4\t\2\2\2\u01c4Q\3\2\2\2\u01c5\u01c6\7\24\2"+
+		"\2\u01c6\u01c7\7a\2\2\u01c7S\3\2\2\2\u01c8\u01c9\7\25\2\2\u01c9\u01ca"+
+		"\t\2\2\2\u01caU\3\2\2\2\u01cb\u01cc\7\26\2\2\u01cc\u01cd\t\2\2\2\u01cd"+
+		"W\3\2\2\2\u01ce\u01cf\7\27\2\2\u01cf\u01d0\t\2\2\2\u01d0Y\3\2\2\2\u01d1"+
+		"\u01d2\7\30\2\2\u01d2\u01d3\t\2\2\2\u01d3[\3\2\2\2\u01d4\u01d5\7\31\2"+
+		"\2\u01d5\u01d6\t\2\2\2\u01d6]\3\2\2\2\u01d7\u01d8\7\32\2\2\u01d8\u01d9"+
+		"\t\2\2\2\u01d9_\3\2\2\2\u01da\u01db\7\33\2\2\u01db\u01dc\t\2\2\2\u01dc"+
+		"a\3\2\2\2\u01dd\u01de\7\34\2\2\u01de\u01df\t\2\2\2\u01dfc\3\2\2\2\u01e0"+
+		"\u01e1\7\35\2\2\u01e1\u01e2\t\2\2\2\u01e2e\3\2\2\2\u01e3\u01e4\7\36\2"+
+		"\2\u01e4\u01e5\7a\2\2\u01e5g\3\2\2\2\u01e6\u01e7\7\37\2\2\u01e7\u01eb"+
+		"\7a\2\2\u01e8\u01ea\7\7\2\2\u01e9\u01e8\3\2\2\2\u01ea\u01ed\3\2\2\2\u01eb"+
+		"\u01e9\3\2\2\2\u01eb\u01ec\3\2\2\2\u01ec\u01ee\3\2\2\2\u01ed\u01eb\3\2"+
+		"\2\2\u01ee\u01ef\7a\2\2\u01efi\3\2\2\2\u01f0\u01f1\7 \2\2\u01f1\u01f5"+
+		"\7a\2\2\u01f2\u01f4\7\7\2\2\u01f3\u01f2\3\2\2\2\u01f4\u01f7\3\2\2\2\u01f5"+
+		"\u01f3\3\2\2\2\u01f5\u01f6\3\2\2\2\u01f6\u01f8\3\2\2\2\u01f7\u01f5\3\2"+
+		"\2\2\u01f8\u01f9\7a\2\2\u01f9k\3\2\2\2\u01fa\u01fb\7!\2\2\u01fb\u01ff"+
+		"\7a\2\2\u01fc\u01fe\7\7\2\2\u01fd\u01fc\3\2\2\2\u01fe\u0201\3\2\2\2\u01ff"+
+		"\u01fd\3\2\2\2\u01ff\u0200\3\2\2\2\u0200\u0202\3\2\2\2\u0201\u01ff\3\2"+
+		"\2\2\u0202\u0203\7a\2\2\u0203m\3\2\2\2\u0204\u0205\7\"\2\2\u0205\u0209"+
+		"\7a\2\2\u0206\u0208\7\7\2\2\u0207\u0206\3\2\2\2\u0208\u020b\3\2\2\2\u0209"+
+		"\u0207\3\2\2\2\u0209\u020a\3\2\2\2\u020a\u020c\3\2\2\2\u020b\u0209\3\2"+
+		"\2\2\u020c\u020d\7a\2\2\u020do\3\2\2\2\u020e\u020f\7#\2\2\u020f\u0213"+
+		"\7a\2\2\u0210\u0212\7\7\2\2\u0211\u0210\3\2\2\2\u0212\u0215\3\2\2\2\u0213"+
+		"\u0211\3\2\2\2\u0213\u0214\3\2\2\2\u0214\u0216\3\2\2\2\u0215\u0213\3\2"+
+		"\2\2\u0216\u0217\7a\2\2\u0217q\3\2\2\2\u0218\u0219\7$\2\2\u0219\u021a"+
+		"\t\2\2\2\u021as\3\2\2\2\u021b\u021c\7%\2\2\u021c\u021d\t\2\2\2\u021du"+
+		"\3\2\2\2\u021e\u021f\7&\2\2\u021f\u0220\t\2\2\2\u0220w\3\2\2\2\u0221\u0222"+
+		"\7\'\2\2\u0222\u0223\t\2\2\2\u0223y\3\2\2\2\u0224\u0225\7(\2\2\u0225\u0226"+
+		"\t\2\2\2\u0226{\3\2\2\2\u0227\u0228\7)\2\2\u0228\u022c\7a\2\2\u0229\u022b"+
+		"\7\7\2\2\u022a\u0229\3\2\2\2\u022b\u022e\3\2\2\2\u022c\u022a\3\2\2\2\u022c"+
+		"\u022d\3\2\2\2\u022d\u022f\3\2\2\2\u022e\u022c\3\2\2\2\u022f\u0230\7a"+
+		"\2\2\u0230}\3\2\2\2\u0231\u0232\7*\2\2\u0232\u0233\7a\2\2\u0233\177\3"+
+		"\2\2\2\u0234\u0235\7+\2\2\u0235\u0236\t\2\2\2\u0236\u0081\3\2\2\2\u0237"+
+		"\u0238\7,\2\2\u0238\u0239\t\2\2\2\u0239\u0083\3\2\2\2\u023a\u023b\7-\2"+
+		"\2\u023b\u023c\7a\2\2\u023c\u0085\3\2\2\2\u023d\u023e\7.\2\2\u023e\u023f"+
+		"\t\2\2\2\u023f\u0087\3\2\2\2\u0240\u0241\7/\2\2\u0241\u0242\t\2\2\2\u0242"+
+		"\u0089\3\2\2\2\u0243\u0244\7\60\2\2\u0244\u0245\7a\2\2\u0245\u008b\3\2"+
+		"\2\2\u0246\u0247\7\61\2\2\u0247\u0248\7a\2\2\u0248\u008d\3\2\2\2\u0249"+
+		"\u024a\7\62\2\2\u024a\u024b\t\2\2\2\u024b\u008f\3\2\2\2\u024c\u024d\7"+
+		"\63\2\2\u024d\u024e\7a\2\2\u024e\u0091\3\2\2\2\u024f\u0250\7\64\2\2\u0250"+
+		"\u0254\t\2\2\2\u0251\u0253\7\7\2\2\u0252\u0251\3\2\2\2\u0253\u0256\3\2"+
+		"\2\2\u0254\u0252\3\2\2\2\u0254\u0255\3\2\2\2\u0255\u0257\3\2\2\2\u0256"+
+		"\u0254\3\2\2\2\u0257\u025b\t\2\2\2\u0258\u025a\7\7\2\2\u0259\u0258\3\2"+
+		"\2\2\u025a\u025d\3\2\2\2\u025b\u0259\3\2\2\2\u025b\u025c\3\2\2\2\u025c"+
+		"\u025e\3\2\2\2\u025d\u025b\3\2\2\2\u025e\u025f\t\2\2\2\u025f\u0093\3\2"+
+		"\2\2\u0260\u0261\7\65\2\2\u0261\u0265\7a\2\2\u0262\u0264\7\7\2\2\u0263"+
+		"\u0262\3\2\2\2\u0264\u0267\3\2\2\2\u0265\u0263\3\2\2\2\u0265\u0266\3\2"+
+		"\2\2\u0266\u0268\3\2\2\2\u0267\u0265\3\2\2\2\u0268\u026c\t\2\2\2\u0269"+
+		"\u026b\7\7\2\2\u026a\u0269\3\2\2\2\u026b\u026e\3\2\2\2\u026c\u026a\3\2"+
+		"\2\2\u026c\u026d\3\2\2\2\u026d\u026f\3\2\2\2\u026e\u026c\3\2\2\2\u026f"+
+		"\u0270\t\2\2\2\u0270\u0095\3\2\2\2\u0271\u0272\7\66\2\2\u0272\u0273\t"+
+		"\2\2\2\u0273\u0097\3\2\2\2\u0274\u0275\7\67\2\2\u0275\u0276\t\2\2\2\u0276"+
+		"\u0099\3\2\2\2\u0277\u0278\78\2\2\u0278\u0279\t\2\2\2\u0279\u009b\3\2"+
+		"\2\2\u027a\u027b\79\2\2\u027b\u027c\t\2\2\2\u027c\u009d\3\2\2\2\u027d"+
+		"\u027e\7:\2\2\u027e\u027f\t\2\2\2\u027f\u009f\3\2\2\2\u0280\u0281\7;\2"+
+		"\2\u0281\u0282\7a\2\2\u0282\u00a1\3\2\2\2\u0283\u0284\7<\2\2\u0284\u0285"+
+		"\7a\2\2\u0285\u00a3\3\2\2\2\u0286\u0287\7=\2\2\u0287\u0288\t\2\2\2\u0288"+
+		"\u00a5\3\2\2\2\u0289\u028a\7>\2\2\u028a\u028b\7a\2\2\u028b\u00a7\3\2\2"+
+		"\2\u028c\u028d\7?\2\2\u028d\u0291\t\2\2\2\u028e\u0290\7\7\2\2\u028f\u028e"+
+		"\3\2\2\2\u0290\u0293\3\2\2\2\u0291\u028f\3\2\2\2\u0291\u0292\3\2\2\2\u0292"+
+		"\u0294\3\2\2\2\u0293\u0291\3\2\2\2\u0294\u0298\t\2\2\2\u0295\u0297\7\7"+
+		"\2\2\u0296\u0295\3\2\2\2\u0297\u029a\3\2\2\2\u0298\u0296\3\2\2\2\u0298"+
+		"\u0299\3\2\2\2\u0299\u029b\3\2\2\2\u029a\u0298\3\2\2\2\u029b\u029c\t\2"+
+		"\2\2\u029c\u00a9\3\2\2\2\u029d\u029e\7@\2\2\u029e\u02a2\7a\2\2\u029f\u02a1"+
+		"\7\7\2\2\u02a0\u029f\3\2\2\2\u02a1\u02a4\3\2\2\2\u02a2\u02a0\3\2\2\2\u02a2"+
+		"\u02a3\3\2\2\2\u02a3\u02a5\3\2\2\2\u02a4\u02a2\3\2\2\2\u02a5\u02a9\t\2"+
+		"\2\2\u02a6\u02a8\7\7\2\2\u02a7\u02a6\3\2\2\2\u02a8\u02ab\3\2\2\2\u02a9"+
+		"\u02a7\3\2\2\2\u02a9\u02aa\3\2\2\2\u02aa\u02ac\3\2\2\2\u02ab\u02a9\3\2"+
+		"\2\2\u02ac\u02ad\t\2\2\2\u02ad\u00ab\3\2\2\2\u02ae\u02af\7A\2\2\u02af"+
+		"\u02b0\t\2\2\2\u02b0\u00ad\3\2\2\2\u02b1\u02b2\7B\2\2\u02b2\u02b3\t\2"+
+		"\2\2\u02b3\u00af\3\2\2\2\u02b4\u02b5\7C\2\2\u02b5\u02b6\t\2\2\2\u02b6"+
+		"\u00b1\3\2\2\2\u02b7\u02b8\7D\2\2\u02b8\u02b9\t\2\2\2\u02b9\u00b3\3\2"+
+		"\2\2\u02ba\u02bb\7E\2\2\u02bb\u02bc\t\2\2\2\u02bc\u00b5\3\2\2\2\u02bd"+
+		"\u02be\7F\2\2\u02be\u02bf\7a\2\2\u02bf\u00b7\3\2\2\2\u02c0\u02c1\7G\2"+
+		"\2\u02c1\u02c2\7a\2\2\u02c2\u00b9\3\2\2\2\u02c3\u02c4\7H\2\2\u02c4\u02c5"+
+		"\t\2\2\2\u02c5\u00bb\3\2\2\2\u02c6\u02c7\7I\2\2\u02c7\u02cb\7a\2\2\u02c8"+
+		"\u02ca\7\7\2\2\u02c9\u02c8\3\2\2\2\u02ca\u02cd\3\2\2\2\u02cb\u02c9\3\2"+
+		"\2\2\u02cb\u02cc\3\2\2\2\u02cc\u02ce\3\2\2\2\u02cd\u02cb\3\2\2\2\u02ce"+
+		"\u02cf\7a\2\2\u02cf\u00bd\3\2\2\2\u02d0\u02d1\7J\2\2\u02d1\u02d2\7a\2"+
+		"\2\u02d2\u00bf\3\2\2\2\u02d3\u02d4\7K\2\2\u02d4\u02d5\t\2\2\2\u02d5\u00c1"+
+		"\3\2\2\2\u02d6\u02d7\7L\2\2\u02d7\u02d8\t\2\2\2\u02d8\u00c3\3\2\2\2\u02d9"+
+		"\u02da\7M\2\2\u02da\u02db\t\2\2\2\u02db\u00c5\3\2\2\2\u02dc\u02dd\7N\2"+
+		"\2\u02dd\u02de\7a\2\2\u02de\u00c7\3\2\2\2\u02df\u02e0\7O\2\2\u02e0\u02e1"+
+		"\7a\2\2\u02e1\u00c9\3\2\2\2\u02e2\u02e3\7P\2\2\u02e3\u02e7\t\2\2\2\u02e4"+
+		"\u02e6\7\7\2\2\u02e5\u02e4\3\2\2\2\u02e6\u02e9\3\2\2\2\u02e7\u02e5\3\2"+
+		"\2\2\u02e7\u02e8\3\2\2\2\u02e8\u02ea\3\2\2\2\u02e9\u02e7\3\2\2\2\u02ea"+
+		"\u02ee\7a\2\2\u02eb\u02ed\7\7\2\2\u02ec\u02eb\3\2\2\2\u02ed\u02f0\3\2"+
+		"\2\2\u02ee\u02ec\3\2\2\2\u02ee\u02ef\3\2\2\2\u02ef\u02f1\3\2\2\2\u02f0"+
+		"\u02ee\3\2\2\2\u02f1\u02f5\t\2\2\2\u02f2\u02f4\7\7\2\2\u02f3\u02f2\3\2"+
+		"\2\2\u02f4\u02f7\3\2\2\2\u02f5\u02f3\3\2\2\2\u02f5\u02f6\3\2\2\2\u02f6"+
+		"\u02f8\3\2\2\2\u02f7\u02f5\3\2\2\2\u02f8\u02f9\7a\2\2\u02f9\u00cb\3\2"+
+		"\2\2\u02fa\u02fb\7Q\2\2\u02fb\u02ff\t\2\2\2\u02fc\u02fe\7\7\2\2\u02fd"+
+		"\u02fc\3\2\2\2\u02fe\u0301\3\2\2\2\u02ff\u02fd\3\2\2\2\u02ff\u0300\3\2"+
+		"\2\2\u0300\u0302\3\2\2\2\u0301\u02ff\3\2\2\2\u0302\u0306\7a\2\2\u0303"+
+		"\u0305\7\7\2\2\u0304\u0303\3\2\2\2\u0305\u0308\3\2\2\2\u0306\u0304\3\2"+
+		"\2\2\u0306\u0307\3\2\2\2\u0307\u0309\3\2\2\2\u0308\u0306\3\2\2\2\u0309"+
+		"\u030d\7a\2\2\u030a\u030c\7\7\2\2\u030b\u030a\3\2\2\2\u030c\u030f\3\2"+
+		"\2\2\u030d\u030b\3\2\2\2\u030d\u030e\3\2\2\2\u030e\u0310\3\2\2\2\u030f"+
+		"\u030d\3\2\2\2\u0310\u0311\7a\2\2\u0311\u00cd\3\2\2\2\u0312\u0313\7R\2"+
+		"\2\u0313\u0317\t\2\2\2\u0314\u0316\7\7\2\2\u0315\u0314\3\2\2\2\u0316\u0319"+
+		"\3\2\2\2\u0317\u0315\3\2\2\2\u0317\u0318\3\2\2\2\u0318\u031a\3\2\2\2\u0319"+
+		"\u0317\3\2\2\2\u031a\u031e\7a\2\2\u031b\u031d\7\7\2\2\u031c\u031b\3\2"+
+		"\2\2\u031d\u0320\3\2\2\2\u031e\u031c\3\2\2\2\u031e\u031f\3\2\2\2\u031f"+
+		"\u0321\3\2\2\2\u0320\u031e\3\2\2\2\u0321\u0325\t\2\2\2\u0322\u0324\7\7"+
+		"\2\2\u0323\u0322\3\2\2\2\u0324\u0327\3\2\2\2\u0325\u0323\3\2\2\2\u0325"+
+		"\u0326\3\2\2\2\u0326\u0329\3\2\2\2\u0327\u0325\3\2\2\2\u0328\u032a\7a"+
+		"\2\2\u0329\u0328\3\2\2\2\u0329\u032a\3\2\2\2\u032a\u00cf\3\2\2\2\u032b"+
+		"\u032c\7S\2\2\u032c\u0330\7a\2\2\u032d\u032f\7\7\2\2\u032e\u032d\3\2\2"+
+		"\2\u032f\u0332\3\2\2\2\u0330\u032e\3\2\2\2\u0330\u0331\3\2\2\2\u0331\u0333"+
+		"\3\2\2\2\u0332\u0330\3\2\2\2\u0333\u0337\7a\2\2\u0334\u0336\7\7\2\2\u0335"+
+		"\u0334\3\2\2\2\u0336\u0339\3\2\2\2\u0337\u0335\3\2\2\2\u0337\u0338\3\2"+
+		"\2\2\u0338\u033a\3\2\2\2\u0339\u0337\3\2\2\2\u033a\u033e\7a\2\2\u033b"+
+		"\u033d\7\7\2\2\u033c\u033b\3\2\2\2\u033d\u0340\3\2\2\2\u033e\u033c\3\2"+
+		"\2\2\u033e\u033f\3\2\2\2\u033f\u0342\3\2\2\2\u0340\u033e\3\2\2\2\u0341"+
+		"\u0343\7a\2\2\u0342\u0341\3\2\2\2\u0342\u0343\3\2\2\2\u0343\u00d1\3\2"+
+		"\2\2\u0344\u0345\7T\2\2\u0345\u0349\t\2\2\2\u0346\u0348\7\7\2\2\u0347"+
+		"\u0346\3\2\2\2\u0348\u034b\3\2\2\2\u0349\u0347\3\2\2\2\u0349\u034a\3\2"+
+		"\2\2\u034a\u034c\3\2\2\2\u034b\u0349\3\2\2\2\u034c\u0350\7a\2\2\u034d"+
+		"\u034f\7\7\2\2\u034e\u034d\3\2\2\2\u034f\u0352\3\2\2\2\u0350\u034e\3\2"+
+		"\2\2\u0350\u0351\3\2\2\2\u0351\u0353\3\2\2\2\u0352\u0350\3\2\2\2\u0353"+
+		"\u0357\t\2\2\2\u0354\u0356\7\7\2\2\u0355\u0354\3\2\2\2\u0356\u0359\3\2"+
+		"\2\2\u0357\u0355\3\2\2\2\u0357\u0358\3\2\2\2\u0358\u0361\3\2\2\2\u0359"+
+		"\u0357\3\2\2\2\u035a\u035e\7a\2\2\u035b\u035d\7\7\2\2\u035c\u035b\3\2"+
+		"\2\2\u035d\u0360\3\2\2\2\u035e\u035c\3\2\2\2\u035e\u035f\3\2\2\2\u035f"+
+		"\u0362\3\2\2\2\u0360\u035e\3\2\2\2\u0361\u035a\3\2\2\2\u0361\u0362\3\2"+
+		"\2\2\u0362\u036a\3\2\2\2\u0363\u0367\7a\2\2\u0364\u0366\7\7\2\2\u0365"+
+		"\u0364\3\2\2\2\u0366\u0369\3\2\2\2\u0367\u0365\3\2\2\2\u0367\u0368\3\2"+
+		"\2\2\u0368\u036b\3\2\2\2\u0369\u0367\3\2\2\2\u036a\u0363\3\2\2\2\u036a"+
+		"\u036b\3\2\2\2\u036b\u0373\3\2\2\2\u036c\u0370\7a\2\2\u036d\u036f\7\7"+
+		"\2\2\u036e\u036d\3\2\2\2\u036f\u0372\3\2\2\2\u0370\u036e\3\2\2\2\u0370"+
+		"\u0371\3\2\2\2\u0371\u0374\3\2\2\2\u0372\u0370\3\2\2\2\u0373\u036c\3\2"+
+		"\2\2\u0373\u0374\3\2\2\2\u0374\u0376\3\2\2\2\u0375\u0377\t\2\2\2\u0376"+
+		"\u0375\3\2\2\2\u0376\u0377\3\2\2\2\u0377\u00d3\3\2\2\2\u0378\u0379\7U"+
+		"\2\2\u0379\u037d\t\2\2\2\u037a\u037c\7\7\2\2\u037b\u037a\3\2\2\2\u037c"+
+		"\u037f\3\2\2\2\u037d\u037b\3\2\2\2\u037d\u037e\3\2\2\2\u037e\u0380\3\2"+
+		"\2\2\u037f\u037d\3\2\2\2\u0380\u0384\7a\2\2\u0381\u0383\7\7\2\2\u0382"+
+		"\u0381\3\2\2\2\u0383\u0386\3\2\2\2\u0384\u0382\3\2\2\2\u0384\u0385\3\2"+
+		"\2\2\u0385\u0387\3\2\2\2\u0386\u0384\3\2\2\2\u0387\u038b\t\2\2\2\u0388"+
+		"\u038a\7\7\2\2\u0389\u0388\3\2\2\2\u038a\u038d\3\2\2\2\u038b\u0389\3\2"+
+		"\2\2\u038b\u038c\3\2\2\2\u038c\u0395\3\2\2\2\u038d\u038b\3\2\2\2\u038e"+
+		"\u0392\7a\2\2\u038f\u0391\7\7\2\2\u0390\u038f\3\2\2\2\u0391\u0394\3\2"+
+		"\2\2\u0392\u0390\3\2\2\2\u0392\u0393\3\2\2\2\u0393\u0396\3\2\2\2\u0394"+
+		"\u0392\3\2\2\2\u0395\u038e\3\2\2\2\u0395\u0396\3\2\2\2\u0396\u039e\3\2"+
+		"\2\2\u0397\u039b\7a\2\2\u0398\u039a\7\7\2\2\u0399\u0398\3\2\2\2\u039a"+
+		"\u039d\3\2\2\2\u039b\u0399\3\2\2\2\u039b\u039c\3\2\2\2\u039c\u039f\3\2"+
+		"\2\2\u039d\u039b\3\2\2\2\u039e\u0397\3\2\2\2\u039e\u039f\3\2\2\2\u039f"+
+		"\u03a7\3\2\2\2\u03a0\u03a4\7a\2\2\u03a1\u03a3\7\7\2\2\u03a2\u03a1\3\2"+
+		"\2\2\u03a3\u03a6\3\2\2\2\u03a4\u03a2\3\2\2\2\u03a4\u03a5\3\2\2\2\u03a5"+
+		"\u03a8\3\2\2\2\u03a6\u03a4\3\2\2\2\u03a7\u03a0\3\2\2\2\u03a7\u03a8\3\2"+
+		"\2\2\u03a8\u03aa\3\2\2\2\u03a9\u03ab\t\2\2\2\u03aa\u03a9\3\2\2\2\u03aa"+
+		"\u03ab\3\2\2\2\u03ab\u00d5\3\2\2\2\u03ac\u03ad\7V\2\2\u03ad\u03b1\t\2"+
+		"\2\2\u03ae\u03b0\7\7\2\2\u03af\u03ae\3\2\2\2\u03b0\u03b3\3\2\2\2\u03b1"+
+		"\u03af\3\2\2\2\u03b1\u03b2\3\2\2\2\u03b2\u03b4\3\2\2\2\u03b3\u03b1\3\2"+
+		"\2\2\u03b4\u03b8\7a\2\2\u03b5\u03b7\7\7\2\2\u03b6\u03b5\3\2\2\2\u03b7"+
+		"\u03ba\3\2\2\2\u03b8\u03b6\3\2\2\2\u03b8\u03b9\3\2\2\2\u03b9\u03bb\3\2"+
+		"\2\2\u03ba\u03b8\3\2\2\2\u03bb\u03bf\t\2\2\2\u03bc\u03be\7\7\2\2\u03bd"+
+		"\u03bc\3\2\2\2\u03be\u03c1\3\2\2\2\u03bf\u03bd\3\2\2\2\u03bf\u03c0\3\2"+
+		"\2\2\u03c0\u03c9\3\2\2\2\u03c1\u03bf\3\2\2\2\u03c2\u03c6\7a\2\2\u03c3"+
+		"\u03c5\7\7\2\2\u03c4\u03c3\3\2\2\2\u03c5\u03c8\3\2\2\2\u03c6\u03c4\3\2"+
+		"\2\2\u03c6\u03c7\3\2\2\2\u03c7\u03ca\3\2\2\2\u03c8\u03c6\3\2\2\2\u03c9"+
+		"\u03c2\3\2\2\2\u03c9\u03ca\3\2\2\2\u03ca\u03cc\3\2\2\2\u03cb\u03cd\7a"+
+		"\2\2\u03cc\u03cb\3\2\2\2\u03cc\u03cd\3\2\2\2\u03cd\u00d7\3\2\2\2\u03ce"+
+		"\u03cf\7W\2\2\u03cf\u03d3\7a\2\2\u03d0\u03d2\7\7\2\2\u03d1\u03d0\3\2\2"+
+		"\2\u03d2\u03d5\3\2\2\2\u03d3\u03d1\3\2\2\2\u03d3\u03d4\3\2\2\2\u03d4\u03d6"+
+		"\3\2\2\2\u03d5\u03d3\3\2\2\2\u03d6\u03da\7a\2\2\u03d7\u03d9\7\7\2\2\u03d8"+
+		"\u03d7\3\2\2\2\u03d9\u03dc\3\2\2\2\u03da\u03d8\3\2\2\2\u03da\u03db\3\2"+
+		"\2\2\u03db\u03dd\3\2\2\2\u03dc\u03da\3\2\2\2\u03dd\u03e1\7a\2\2\u03de"+
+		"\u03e0\7\7\2\2\u03df\u03de\3\2\2\2\u03e0\u03e3\3\2\2\2\u03e1\u03df\3\2"+
+		"\2\2\u03e1\u03e2\3\2\2\2\u03e2\u03eb\3\2\2\2\u03e3\u03e1\3\2\2\2\u03e4"+
+		"\u03e8\7a\2\2\u03e5\u03e7\7\7\2\2\u03e6\u03e5\3\2\2\2\u03e7\u03ea\3\2"+
+		"\2\2\u03e8\u03e6\3\2\2\2\u03e8\u03e9\3\2\2\2\u03e9\u03ec\3\2\2\2\u03ea"+
+		"\u03e8\3\2\2\2\u03eb\u03e4\3\2\2\2\u03eb\u03ec\3\2\2\2\u03ec\u03ee\3\2"+
+		"\2\2\u03ed\u03ef\7a\2\2\u03ee\u03ed\3\2\2\2\u03ee\u03ef\3\2\2\2\u03ef"+
+		"\u00d9\3\2\2\2\u03f0\u03f1\7X\2\2\u03f1\u03f5\t\2\2\2\u03f2\u03f4\7\7"+
+		"\2\2\u03f3\u03f2\3\2\2\2\u03f4\u03f7\3\2\2\2\u03f5\u03f3\3\2\2\2\u03f5"+
+		"\u03f6\3\2\2\2\u03f6\u03f8\3\2\2\2\u03f7\u03f5\3\2\2\2\u03f8\u03fc\7a"+
+		"\2\2\u03f9\u03fb\7\7\2\2\u03fa\u03f9\3\2\2\2\u03fb\u03fe\3\2\2\2\u03fc"+
+		"\u03fa\3\2\2\2\u03fc\u03fd\3\2\2\2\u03fd\u03ff\3\2\2\2\u03fe\u03fc\3\2"+
+		"\2\2\u03ff\u0403\t\2\2\2\u0400\u0402\7\7\2\2\u0401\u0400\3\2\2\2\u0402"+
+		"\u0405\3\2\2\2\u0403\u0401\3\2\2\2\u0403\u0404\3\2\2\2\u0404\u040d\3\2"+
+		"\2\2\u0405\u0403\3\2\2\2\u0406\u040a\7a\2\2\u0407\u0409\7\7\2\2\u0408"+
+		"\u0407\3\2\2\2\u0409\u040c\3\2\2\2\u040a\u0408\3\2\2\2\u040a\u040b\3\2"+
+		"\2\2\u040b\u040e\3\2\2\2\u040c\u040a\3\2\2\2\u040d\u0406\3\2\2\2\u040d"+
+		"\u040e\3\2\2\2\u040e\u0416\3\2\2\2\u040f\u0413\7a\2\2\u0410\u0412\7\7"+
+		"\2\2\u0411\u0410\3\2\2\2\u0412\u0415\3\2\2\2\u0413\u0411\3\2\2\2\u0413"+
+		"\u0414\3\2\2\2\u0414\u0417\3\2\2\2\u0415\u0413\3\2\2\2\u0416\u040f\3\2"+
+		"\2\2\u0416\u0417\3\2\2\2\u0417\u041f\3\2\2\2\u0418\u041c\7a\2\2\u0419"+
+		"\u041b\7\7\2\2\u041a\u0419\3\2\2\2\u041b\u041e\3\2\2\2\u041c\u041a\3\2"+
+		"\2\2\u041c\u041d\3\2\2\2\u041d\u0420\3\2\2\2\u041e\u041c\3\2\2\2\u041f"+
+		"\u0418\3\2\2\2\u041f\u0420\3\2\2\2\u0420\u0428\3\2\2\2\u0421\u0425\7a"+
+		"\2\2\u0422\u0424\7\7\2\2\u0423\u0422\3\2\2\2\u0424\u0427\3\2\2\2\u0425"+
+		"\u0423\3\2\2\2\u0425\u0426\3\2\2\2\u0426\u0429\3\2\2\2\u0427\u0425\3\2"+
+		"\2\2\u0428\u0421\3\2\2\2\u0428\u0429\3\2\2\2\u0429\u042a\3\2\2\2\u042a"+
+		"\u042b\t\2\2\2\u042b\u00db\3\2\2\2\u042c\u042d\7Y\2\2\u042d\u0431\t\2"+
+		"\2\2\u042e\u0430\7\7\2\2\u042f\u042e\3\2\2\2\u0430\u0433\3\2\2\2\u0431"+
+		"\u042f\3\2\2\2\u0431\u0432\3\2\2\2\u0432\u0434\3\2\2\2\u0433\u0431\3\2"+
+		"\2\2\u0434\u0438\7a\2\2\u0435\u0437\7\7\2\2\u0436\u0435\3\2\2\2\u0437"+
+		"\u043a\3\2\2\2\u0438\u0436\3\2\2\2\u0438\u0439\3\2\2\2\u0439\u043b\3\2"+
+		"\2\2\u043a\u0438\3\2\2\2\u043b\u043f\t\2\2\2\u043c\u043e\7\7\2\2\u043d"+
+		"\u043c\3\2\2\2\u043e\u0441\3\2\2\2\u043f\u043d\3\2\2\2\u043f\u0440\3\2"+
+		"\2\2\u0440\u0449\3\2\2\2\u0441\u043f\3\2\2\2\u0442\u0446\7a\2\2\u0443"+
+		"\u0445\7\7\2\2\u0444\u0443\3\2\2\2\u0445\u0448\3\2\2\2\u0446\u0444\3\2"+
+		"\2\2\u0446\u0447\3\2\2\2\u0447\u044a\3\2\2\2\u0448\u0446\3\2\2\2\u0449"+
+		"\u0442\3\2\2\2\u0449\u044a\3\2\2\2\u044a\u044b\3\2\2\2\u044b\u044f\7a"+
+		"\2\2\u044c\u044e\7\7\2\2\u044d\u044c\3\2\2\2\u044e\u0451\3\2\2\2\u044f"+
+		"\u044d\3\2\2\2\u044f\u0450\3\2\2\2\u0450\u0459\3\2\2\2\u0451\u044f\3\2"+
+		"\2\2\u0452\u0456\7a\2\2\u0453\u0455\7\7\2\2\u0454\u0453\3\2\2\2\u0455"+
+		"\u0458\3\2\2\2\u0456\u0454\3\2\2\2\u0456\u0457\3\2\2\2\u0457\u045a\3\2"+
+		"\2\2\u0458\u0456\3\2\2\2\u0459\u0452\3\2\2\2\u0459\u045a\3\2\2\2\u045a"+
+		"\u0462\3\2\2\2\u045b\u045f\7a\2\2\u045c\u045e\7\7\2\2\u045d\u045c\3\2"+
+		"\2\2\u045e\u0461\3\2\2\2\u045f\u045d\3\2\2\2\u045f\u0460\3\2\2\2\u0460"+
+		"\u0463\3\2\2\2\u0461\u045f\3\2\2\2\u0462\u045b\3\2\2\2\u0462\u0463\3\2"+
+		"\2\2\u0463\u0465\3\2\2\2\u0464\u0466\t\2\2\2\u0465\u0464\3\2\2\2\u0465"+
+		"\u0466\3\2\2\2\u0466\u00dd\3\2\2\2\u0467\u0468\7Z\2\2\u0468\u046c\t\2"+
+		"\2\2\u0469\u046b\7\7\2\2\u046a\u0469\3\2\2\2\u046b\u046e\3\2\2\2\u046c"+
+		"\u046a\3\2\2\2\u046c\u046d\3\2\2\2\u046d\u046f\3\2\2\2\u046e\u046c\3\2"+
+		"\2\2\u046f\u0473\7a\2\2\u0470\u0472\7\7\2\2\u0471\u0470\3\2\2\2\u0472"+
+		"\u0475\3\2\2\2\u0473\u0471\3\2\2\2\u0473\u0474\3\2\2\2\u0474\u0476\3\2"+
+		"\2\2\u0475\u0473\3\2\2\2\u0476\u047a\7a\2\2\u0477\u0479\7\7\2\2\u0478"+
+		"\u0477\3\2\2\2\u0479\u047c\3\2\2\2\u047a\u0478\3\2\2\2\u047a\u047b\3\2"+
+		"\2\2\u047b\u047d\3\2\2\2\u047c\u047a\3\2\2\2\u047d\u047e\t\2\2\2\u047e"+
+		"\u00df\3\2\2\2\u047f\u0480\7[\2\2\u0480\u0481\t\2\2\2\u0481\u00e1\3\2"+
+		"\2\2\u0482\u0483\7\\\2\2\u0483\u0487\t\2\2\2\u0484\u0486\7\7\2\2\u0485"+
+		"\u0484\3\2\2\2\u0486\u0489\3\2\2\2\u0487\u0485\3\2\2\2\u0487\u0488\3\2"+
+		"\2\2\u0488\u048a\3\2\2\2\u0489\u0487\3\2\2\2\u048a\u048e\7a\2\2\u048b"+
+		"\u048d\7\7\2\2\u048c\u048b\3\2\2\2\u048d\u0490\3\2\2\2\u048e\u048c\3\2"+
+		"\2\2\u048e\u048f\3\2\2\2\u048f\u0491\3\2\2\2\u0490\u048e\3\2\2\2\u0491"+
+		"\u0495\7a\2\2\u0492\u0494\7\7\2\2\u0493\u0492\3\2\2\2\u0494\u0497\3\2"+
+		"\2\2\u0495\u0493\3\2\2\2\u0495\u0496\3\2\2\2\u0496\u0498\3\2\2\2\u0497"+
+		"\u0495\3\2\2\2\u0498\u0499\t\2\2\2\u0499\u00e3\3\2\2\2\u049a\u049b\7]"+
+		"\2\2\u049b\u049c\t\2\2\2\u049c\u00e5\3\2\2\2w\u00e9\u00ed\u00f7\u0124"+
+		"\u0127\u012c\u013a\u013e\u0142\u0146\u014a\u014f\u0153\u0157\u015b\u015f"+
+		"\u0163\u0168\u016c\u0170\u017a\u017e\u0182\u0188\u0192\u0197\u019b\u019f"+
+		"\u01eb\u01f5\u01ff\u0209\u0213\u022c\u0254\u025b\u0265\u026c\u0291\u0298"+
+		"\u02a2\u02a9\u02cb\u02e7\u02ee\u02f5\u02ff\u0306\u030d\u0317\u031e\u0325"+
+		"\u0329\u0330\u0337\u033e\u0342\u0349\u0350\u0357\u035e\u0361\u0367\u036a"+
+		"\u0370\u0373\u0376\u037d\u0384\u038b\u0392\u0395\u039b\u039e\u03a4\u03a7"+
+		"\u03aa\u03b1\u03b8\u03bf\u03c6\u03c9\u03cc\u03d3\u03da\u03e1\u03e8\u03eb"+
+		"\u03ee\u03f5\u03fc\u0403\u040a\u040d\u0413\u0416\u041c\u041f\u0425\u0428"+
+		"\u0431\u0438\u043f\u0446\u0449\u044f\u0456\u0459\u045f\u0462\u0465\u046c"+
+		"\u0473\u047a\u0487\u048e\u0495";
 	public static final ATN _ATN =
 		new ATNDeserializer().deserialize(_serializedATN.toCharArray());
 	static {
--- a/src/main/java/de/intevation/lada/importer/laf/LafRawData.java	Mon Oct 24 11:47:55 2016 +0200
+++ b/src/main/java/de/intevation/lada/importer/laf/LafRawData.java	Mon Oct 24 11:52:17 2016 +0200
@@ -99,6 +99,10 @@
         public void addKommentar(Map<String, String> kommentar) {
             this.kommentar.add(kommentar);
         }
+
+        public List<Map<String, String>> getKommentare() {
+            return this.kommentar;
+        }
     }
 
     public void addProbe(LafRawData.Probe probe) {
--- a/src/main/java/de/intevation/lada/rest/importer/LafImportService.java	Mon Oct 24 11:47:55 2016 +0200
+++ b/src/main/java/de/intevation/lada/rest/importer/LafImportService.java	Mon Oct 24 11:52:17 2016 +0200
@@ -8,7 +8,9 @@
 package de.intevation.lada.rest.importer;
 
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
+import java.util.Map.Entry;
 
 import javax.enterprise.context.RequestScoped;
 import javax.inject.Inject;
@@ -20,9 +22,12 @@
 import javax.ws.rs.core.Context;
 import javax.ws.rs.core.MediaType;
 
+import org.apache.log4j.Logger;
+
 import de.intevation.lada.importer.ImportConfig;
 import de.intevation.lada.importer.ImportFormat;
 import de.intevation.lada.importer.Importer;
+import de.intevation.lada.importer.ReportItem;
 import de.intevation.lada.util.annotation.AuthorizationConfig;
 import de.intevation.lada.util.auth.Authorization;
 import de.intevation.lada.util.auth.AuthorizationType;
@@ -38,6 +43,9 @@
 @RequestScoped
 public class LafImportService {
 
+    @Inject
+    private Logger logger;
+
     /**
      * The importer
      */
@@ -71,11 +79,22 @@
 
         importer.doImport(content, userInfo);
         Map<String, Object> respData = new HashMap<String,Object>();
-        respData.put("errors", importer.getErrors());
-        respData.put("warnings", importer.getWarnings());
+        if (!importer.getErrors().isEmpty()) {
+            logger.debug("errs: " + importer.getErrors().size());
+            for (Entry<String, List<ReportItem>> entry : importer.getErrors().entrySet()) {
+                logger.debug(entry.getKey());
+                for (ReportItem item : entry.getValue()) {
+                    logger.debug(item.getKey() + " - " + item.getValue() + ": " + item.getCode());
+                }
+            }
+            respData.put("errors", importer.getErrors());
+        }
+        if (!importer.getWarnings().isEmpty()) {
+            logger.debug("warns: " + importer.getWarnings().size());
+            respData.put("warnings", importer.getWarnings());
+        }
         int code = 200;
         Response response = new Response(importer.getErrors().isEmpty(), code, respData);
-        importer.reset();
         return response;
     }
 }
--- a/src/main/java/de/intevation/lada/util/data/DataTransaction.java	Mon Oct 24 11:47:55 2016 +0200
+++ b/src/main/java/de/intevation/lada/util/data/DataTransaction.java	Mon Oct 24 11:52:17 2016 +0200
@@ -91,6 +91,7 @@
         em.remove(
             em.contains(object) ?
                 object : em.merge(object));
+        em.flush();
     }
 
     public Query queryFromString(String sql, String dataSource) {
--- a/src/test/java/de/intevation/lada/ImporterTest.java	Mon Oct 24 11:47:55 2016 +0200
+++ b/src/test/java/de/intevation/lada/ImporterTest.java	Mon Oct 24 11:52:17 2016 +0200
@@ -532,7 +532,7 @@
         kommentare.add(komm1);
         kommentare.add(komm2);
 
-        merger.mergeKommentare(messung, kommentare);
+        merger.mergeMessungKommentare(messung, kommentare);
         Assert.assertEquals(2, kommentare.size());
 
         protocol.setPassed(true);
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)