annotate artifacts/src/main/java/org/dive4elements/river/exports/injector/PNPInjector.java @ 8724:47199406994a

(issue1801) Determine gauge at a station always with same tolerance.
author Tom Gottfried <tom@intevation.de>
date Wed, 29 Apr 2015 12:30:57 +0200
parents f5461750e5c7
children a805211690f7
rev   line source
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
1 package org.dive4elements.river.exports.injector;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
2
8326
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
3 import org.apache.log4j.Logger;
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
4 import org.dive4elements.artifacts.Artifact;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
5 import org.dive4elements.artifacts.CallContext;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
6 import org.dive4elements.artifacts.ContextInjector;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
7 import org.dive4elements.river.artifacts.D4EArtifact;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
8 import org.dive4elements.river.artifacts.access.RiverAccess;
8337
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
9 import org.dive4elements.river.model.River;
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
10 import org.dive4elements.river.model.Gauge;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
11 import org.w3c.dom.Document;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
12 import org.w3c.dom.Element;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
13
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
14 import static org.dive4elements.river.exports.injector.InjectorConstants.CURRENT_KM;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
15 import static org.dive4elements.river.exports.injector.InjectorConstants.PNP;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
16
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
17 public class PNPInjector
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
18 implements ContextInjector
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
19 {
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
20
8326
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
21 private Logger log = Logger.getLogger(PNPInjector.class);
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
22 @Override
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
23 public void setup(Element cfg) {
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
24 // TODO Auto-generated method stub
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
25
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
26 }
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
27
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
28 @Override
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
29 public void injectContext(
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
30 CallContext ctx,
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
31 Artifact artifact,
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
32 Document request
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
33 ) {
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
34 Object currentKm = ctx.getContextValue(CURRENT_KM);
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
35 if (currentKm == null) {
8326
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
36 log.debug("no current km. not injecting pnp");
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
37 return;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
38 }
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
39
8326
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
40 Double km = Double.valueOf(currentKm.toString());
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
41 if (Double.isNaN(km) || Double.isInfinite(km)) {
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
42 log.debug("current km is NAN or infinte. not injecting pnp.");
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
43 return;
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
44 }
8337
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
45
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
46 River river = new RiverAccess((D4EArtifact)artifact).getRiver();
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
47 if (river == null) {
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
48 log.error("River not accessible from artifact. Not injecting PNP");
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
49 return;
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
50 }
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
51
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
52 Gauge gauge =
8724
47199406994a (issue1801) Determine gauge at a station always with same tolerance.
Tom Gottfried <tom@intevation.de>
parents: 8337
diff changeset
53 river.determineGaugeAtStation(km);
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
54 if (gauge == null) {
8326
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
55 log.debug("no gauge found at current km. not injecting pnp");
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
56 return;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
57 }
8326
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
58 log.debug("injecting pnp: " + gauge.getDatum());
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
59 ctx.putContextValue(PNP, gauge.getDatum());
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
60 }
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
61
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
62 }

http://dive4elements.wald.intevation.org