[Lada-commits] [PATCH 2 of 5] Updated importer
Wald Commits
scm-commit at wald.intevation.org
Mon Oct 24 11:55:00 CEST 2016
# HG changeset patch
# User Raimund Renkert <raimund.renkert at intevation.de>
# Date 1477302737 -7200
# Node ID 7683c4162746c8bbc2ae99d8e3289511d0467ed1
# Parent 46df70a277671babefec31a82c6b94430db128b3
Updated importer.
* Fixed in grammar
* More reporting
* Fixed unit test
diff -r 46df70a27767 -r 7683c4162746 src/main/antlr4/de/intevation/lada/importer/laf/Laf.g4
--- 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
diff -r 46df70a27767 -r 7683c4162746 src/main/java/de/intevation/lada/importer/laf/LafImporter.java
--- 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;
}
}
diff -r 46df70a27767 -r 7683c4162746 src/main/java/de/intevation/lada/importer/laf/LafObjectListener.java
--- 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);
}
/**
diff -r 46df70a27767 -r 7683c4162746 src/main/java/de/intevation/lada/importer/laf/LafObjectMapper.java
--- 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;
+ }
}
+
+
+
diff -r 46df70a27767 -r 7683c4162746 src/main/java/de/intevation/lada/importer/laf/LafParser.java
--- 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);
+ setState(765);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(761);
+ setState(762);
match(T__4);
}
}
- setState(766);
+ setState(767);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(767);
+ setState(768);
match(STRING);
- setState(771);
+ setState(772);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(768);
+ setState(769);
match(T__4);
}
}
- setState(773);
+ setState(774);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(774);
+ setState(775);
match(STRING);
- setState(778);
+ setState(779);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(775);
+ setState(776);
match(T__4);
}
}
- setState(780);
+ setState(781);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(781);
+ 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);
+ setState(814);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(810);
+ setState(811);
match(T__4);
}
}
- setState(815);
+ setState(816);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(816);
+ setState(817);
match(STRING);
- setState(820);
+ setState(821);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(817);
+ setState(818);
match(T__4);
}
}
- setState(822);
+ setState(823);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(823);
+ setState(824);
match(STRING);
- setState(827);
+ setState(828);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(824);
+ setState(825);
match(T__4);
}
}
- setState(829);
+ setState(830);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(831);
+ 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);
+ setState(834);
match(MESSWERT_I);
- setState(834);
+ setState(835);
_la = _input.LA(1);
if ( !(_la==STRING_ESC || _la==STRING) ) {
_errHandler.recoverInline(this);
} else {
consume();
}
- setState(838);
+ setState(839);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(835);
+ setState(836);
match(T__4);
}
}
- setState(840);
+ setState(841);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(841);
+ setState(842);
match(STRING);
- setState(845);
+ setState(846);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(842);
+ setState(843);
match(T__4);
}
}
- setState(847);
+ setState(848);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(848);
+ setState(849);
_la = _input.LA(1);
if ( !(_la==STRING_ESC || _la==STRING) ) {
_errHandler.recoverInline(this);
} else {
consume();
}
- setState(852);
+ setState(853);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(849);
+ setState(850);
match(T__4);
}
}
- setState(854);
+ setState(855);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(862);
+ 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);
+ setState(886);
match(MESSWERT_G);
- setState(886);
+ setState(887);
_la = _input.LA(1);
if ( !(_la==STRING_ESC || _la==STRING) ) {
_errHandler.recoverInline(this);
} else {
consume();
}
- setState(890);
+ setState(891);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(887);
+ setState(888);
match(T__4);
}
}
- setState(892);
+ setState(893);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(893);
+ setState(894);
match(STRING);
- setState(897);
+ setState(898);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(894);
+ setState(895);
match(T__4);
}
}
- setState(899);
+ setState(900);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(900);
+ setState(901);
_la = _input.LA(1);
if ( !(_la==STRING_ESC || _la==STRING) ) {
_errHandler.recoverInline(this);
} else {
consume();
}
- setState(904);
+ setState(905);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(901);
+ setState(902);
match(T__4);
}
}
- setState(906);
+ setState(907);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(914);
+ 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);
+ setState(977);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(973);
+ setState(974);
match(T__4);
}
}
- setState(978);
+ setState(979);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(979);
+ setState(980);
match(STRING);
- setState(983);
+ setState(984);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(980);
+ setState(981);
match(T__4);
}
}
- setState(985);
+ setState(986);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(986);
+ setState(987);
match(STRING);
- setState(990);
+ setState(991);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(987);
+ setState(988);
match(T__4);
}
}
- setState(992);
+ setState(993);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(1000);
+ 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);
+ setState(1034);
_errHandler.sync(this);
_la = _input.LA(1);
}
}
break;
}
- setState(1043);
+ setState(1044);
switch ( getInterpreter().adaptivePredict(_input,95,_ctx) ) {
case 1:
{
- setState(1036);
+ setState(1037);
match(STRING);
- setState(1040);
+ setState(1041);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(1037);
+ setState(1038);
match(T__4);
}
}
- setState(1042);
+ setState(1043);
_errHandler.sync(this);
_la = _input.LA(1);
}
}
break;
}
- setState(1052);
+ setState(1053);
switch ( getInterpreter().adaptivePredict(_input,97,_ctx) ) {
case 1:
{
- setState(1045);
+ setState(1046);
match(STRING);
- setState(1049);
+ setState(1050);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(1046);
+ setState(1047);
match(T__4);
}
}
- setState(1051);
+ setState(1052);
_errHandler.sync(this);
_la = _input.LA(1);
}
}
break;
}
- setState(1061);
+ setState(1062);
switch ( getInterpreter().adaptivePredict(_input,99,_ctx) ) {
case 1:
{
- setState(1054);
+ setState(1055);
match(STRING);
- setState(1058);
+ setState(1059);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(1055);
+ setState(1056);
match(T__4);
}
}
- setState(1060);
+ setState(1061);
_errHandler.sync(this);
_la = _input.LA(1);
}
}
break;
}
- setState(1063);
+ 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);
+ setState(1130);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(1126);
+ setState(1127);
match(T__4);
}
}
- setState(1131);
+ setState(1132);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(1132);
+ setState(1133);
match(STRING);
- setState(1136);
+ setState(1137);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(1133);
+ setState(1134);
match(T__4);
}
}
- setState(1138);
+ setState(1139);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(1139);
+ setState(1140);
match(STRING);
- setState(1143);
+ setState(1144);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(1140);
+ setState(1141);
match(T__4);
}
}
- setState(1145);
+ setState(1146);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(1146);
+ 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);
+ setState(1157);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(1153);
+ setState(1154);
match(T__4);
}
}
- setState(1158);
+ setState(1159);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(1159);
+ setState(1160);
match(STRING);
- setState(1163);
+ setState(1164);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(1160);
+ setState(1161);
match(T__4);
}
}
- setState(1165);
+ setState(1166);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(1166);
+ setState(1167);
match(STRING);
- setState(1170);
+ setState(1171);
_errHandler.sync(this);
_la = _input.LA(1);
while (_la==T__4) {
{
{
- setState(1167);
+ setState(1168);
match(T__4);
}
}
- setState(1172);
+ setState(1173);
_errHandler.sync(this);
_la = _input.LA(1);
}
- setState(1173);
+ 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 {
diff -r 46df70a27767 -r 7683c4162746 src/main/java/de/intevation/lada/importer/laf/LafRawData.java
--- 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) {
diff -r 46df70a27767 -r 7683c4162746 src/main/java/de/intevation/lada/rest/importer/LafImportService.java
--- 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;
}
}
diff -r 46df70a27767 -r 7683c4162746 src/main/java/de/intevation/lada/util/data/DataTransaction.java
--- 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) {
diff -r 46df70a27767 -r 7683c4162746 src/test/java/de/intevation/lada/ImporterTest.java
--- 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);
More information about the Lada-commits
mailing list