Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/access/FixAnalysisAccess.java @ 5200:42bb6ff78d1b 2.9.11
Directly set the connectionInitSqls on the datasource
Somehow the factory fails to set the connectionInitSqls if
we add it to the dbcpProperties. So we now set it directly
author | Andre Heinecke <aheinecke@intevation.de> |
---|---|
date | Fri, 08 Mar 2013 11:48:33 +0100 |
parents | acfd48384835 |
children |
line wrap: on
line source
package de.intevation.flys.artifacts.access; import de.intevation.artifactdatabase.data.StateData; import de.intevation.artifacts.CallContext; import de.intevation.flys.artifacts.FLYSArtifact; import de.intevation.flys.artifacts.model.DateRange; import java.util.Arrays; import java.util.Date; import org.apache.log4j.Logger; public class FixAnalysisAccess extends FixAccess { private static Logger log = Logger.getLogger(FixAnalysisAccess.class); protected DateRange referencePeriod; protected DateRange [] analysisPeriods; protected double [] qs; public FixAnalysisAccess(FLYSArtifact artifact, CallContext context) { super(artifact, context); } public DateRange getReferencePeriod() { if (referencePeriod == null) { StateData refStart = artifact.getData("ref_start"); StateData refEnd = artifact.getData("ref_end"); if (refStart == null || refEnd == null) { log.warn("missing 'ref_start' or 'ref_start' value"); return null; } try { long rs = Long.parseLong((String)refStart.getValue()); long re = Long.parseLong((String)refEnd .getValue()); if (rs > re) { long t = rs; rs = re; re = t; } Date from = new Date(rs); Date to = new Date(re); referencePeriod = new DateRange(from, to); } catch (NumberFormatException nfe) { log.warn("ref_start or ref_end is not an integer."); } } return referencePeriod; } public DateRange [] getAnalysisPeriods() { if (analysisPeriods == null) { analysisPeriods = getDateRange("ana_data"); } return analysisPeriods; } /** * @return DateRange object ranging from eldest to youngest date * of analysis and reference periods. */ public DateRange getDateRange() { DateRange refP = getReferencePeriod(); if (refP == null) { return null; } Date from = refP.getFrom(); Date to = refP.getTo(); DateRange[] rs = getAnalysisPeriods(); for (DateRange r: rs) { if (r.getFrom().before(from)) { from = r.getFrom(); } if (r.getTo().after(to)) { to = r.getTo(); } } return new DateRange(from, to); } public double [] getQs() { if (qs == null) { qs = getDoubleArray("qs"); } if (log.isDebugEnabled() && qs != null) { log.debug("qs: " + Arrays.toString(qs)); } return qs; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :