[PATCH] Cleanup and more fail safe
Wald Commits
scm-commit at wald.intevation.org
Fri Jul 6 13:12:09 CEST 2018
# HG changeset patch
# User gernotbelger
# Date 1530875524 -7200
# Node ID 2d4750874c57e30212562b8c58b8e6f2ec74b177
# Parent 03427b89ba62a812af8867410674c17b454f3755
Cleanup and more fail safe
diff -r 03427b89ba62 -r 2d4750874c57 artifacts/src/main/java/org/dive4elements/river/artifacts/datacage/templating/FixAnalysisYearXPathFunction.java
--- a/artifacts/src/main/java/org/dive4elements/river/artifacts/datacage/templating/FixAnalysisYearXPathFunction.java Fri Jul 06 13:10:31 2018 +0200
+++ b/artifacts/src/main/java/org/dive4elements/river/artifacts/datacage/templating/FixAnalysisYearXPathFunction.java Fri Jul 06 13:12:04 2018 +0200
@@ -15,8 +15,8 @@
import javax.xml.xpath.XPathFunction;
import javax.xml.xpath.XPathFunctionException;
-import org.apache.log4j.Logger;
import org.dive4elements.artifacts.CallContext;
+import org.dive4elements.river.artifacts.D4EArtifact;
import org.dive4elements.river.artifacts.FixationArtifact;
import org.dive4elements.river.artifacts.access.FixRealizingAccess;
import org.dive4elements.river.artifacts.model.fixings.FixRealizingCalculationExtended;
@@ -34,8 +34,6 @@
public static final int ARITY = 1;
- private static Logger log = Logger.getLogger(FixAnalysisYearXPathFunction.class);
-
private final CallContext context;
public FixAnalysisYearXPathFunction(final CallContext context) {
@@ -45,19 +43,18 @@
@Override
public Object evaluate(final List args) throws XPathFunctionException {
- // FIXME: get artifact id
final UUID uuid = (UUID) args.get(0);
+ if (uuid == null)
+ return null;
- final FixationArtifact fixation = (FixationArtifact) RiverUtils.getArtifact(uuid.toString(), this.context);
+ final D4EArtifact artifact = RiverUtils.getArtifact(uuid.toString(), this.context);
+ if (!(artifact instanceof FixationArtifact))
+ return null;
- // FIXME: fetch year
- // final CalculationResult r = (CalculationResult) fixation.compute(this.context, ComputeType.ADVANCE, false);
- // final FixRealizingResult frR = (FixRealizingResult) r.getData();
+ final FixationArtifact fixation = (FixationArtifact) artifact;
// Get W/Q input per gauge for this case.
final FixRealizingAccess fixAccess = new FixRealizingAccess(fixation);
- // final List<Segment> segments = fixAccess.getSegments();
- // final boolean isFixRealize = (segments != null && !segments.isEmpty());
/* ugly but necessary to keep this logic at least a bit inside the FixRealizing stuff */
final FixRealizingCalculationExtended calculation = new FixRealizingCalculationExtended(fixAccess);
More information about the Dive4Elements-commits
mailing list