Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/transitions/ValueCompareTransition.java @ 704:eab5e5089d77
Merged revisions 2127-2133,2136-2137,2140,2143-2144,2146,2150-2151,2153-2154 via svnmerge from
svn+ssh://teichmann@thoe/home/projects/Geospatial/bsh-generischer-viewer/Material/SVN/flys-artifacts/branches/facets-slt
........
r2127 | ingo | 2011-06-16 09:50:56 +0200 (Do, 16 Jun 2011) | 1 line
Added a compute() method to WINFOArtifact which acts as a dispatcher for different computations. It triggers a calculation based on ComputeCallbacks that are generated by the current states.
........
r2128 | ingo | 2011-06-16 10:25:06 +0200 (Do, 16 Jun 2011) | 1 line
Moved Waterlevel state into the correct package.
........
r2129 | ingo | 2011-06-16 10:43:58 +0200 (Do, 16 Jun 2011) | 1 line
Added two more compute() methods to ComputeCallback to distinguish between different phases of the artifact.
........
r2130 | ingo | 2011-06-16 10:57:05 +0200 (Do, 16 Jun 2011) | 1 line
Use enums to dispatch computeFeed() and computeAdvance().
........
r2131 | ingo | 2011-06-16 11:04:59 +0200 (Do, 16 Jun 2011) | 1 line
Store facets for each state.
........
r2132 | ingo | 2011-06-16 12:05:44 +0200 (Do, 16 Jun 2011) | 1 line
Generated facets for each output aspect.
........
r2133 | ingo | 2011-06-16 15:24:00 +0200 (Do, 16 Jun 2011) | 1 line
Write computed facets into artifacts describe document.
........
r2136 | ingo | 2011-06-16 16:10:49 +0200 (Do, 16 Jun 2011) | 1 line
Add index and description of facets to collections describe document.
........
r2137 | ingo | 2011-06-16 16:31:41 +0200 (Do, 16 Jun 2011) | 1 line
OutGenerators doOut() takes a facet object now instead of just its name.
........
r2140 | ingo | 2011-06-17 11:19:43 +0200 (Fr, 17 Jun 2011) | 1 line
OutGenerators use now facets to fetch necessary data.
........
r2143 | teichmann | 2011-06-17 12:40:54 +0200 (Fr, 17 Jun 2011) | 1 line
Removed ComputeCallback because this was thought too complicated. Fixed issue with facets not be re-generated if same state is entered again.
........
r2144 | teichmann | 2011-06-17 13:08:31 +0200 (Fr, 17 Jun 2011) | 1 line
make getGauges() more robust
........
r2146 | teichmann | 2011-06-17 13:23:57 +0200 (Fr, 17 Jun 2011) | 1 line
mico opt: inter cmps are faster than str cmps.
........
r2150 | teichmann | 2011-06-17 15:10:20 +0200 (Fr, 17 Jun 2011) | 1 line
call computeAdvance() if we want to advance.
........
r2151 | teichmann | 2011-06-17 15:45:50 +0200 (Fr, 17 Jun 2011) | 1 line
Base WST/CSV exports on facets. TODO: generate the facets.
........
r2153 | teichmann | 2011-06-17 16:03:29 +0200 (Fr, 17 Jun 2011) | 1 line
Add facet to access raw computed data.
........
r2154 | teichmann | 2011-06-17 16:37:09 +0200 (Fr, 17 Jun 2011) | 1 line
Generate data facets for the computed states.
........
flys-artifacts/trunk@2156 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Sascha L. Teichmann <sascha.teichmann@intevation.de> |
---|---|
date | Fri, 17 Jun 2011 16:17:03 +0000 |
parents | 22e9574c8b1b |
children | eb5564662e19 |
line wrap: on
line source
package de.intevation.flys.artifacts.transitions; import javax.xml.xpath.XPathConstants; import org.apache.log4j.Logger; import org.w3c.dom.Node; import de.intevation.artifacts.Artifact; import de.intevation.artifactdatabase.data.StateData; import de.intevation.artifactdatabase.state.State; import de.intevation.artifacts.common.utils.XMLUtils; import de.intevation.flys.artifacts.FLYSArtifact; /** * This transition compares data objects with a <i>equal</i> or <i>notequal</i> * operator. * * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a> */ public class ValueCompareTransition extends DefaultTransition { /** The logger that is used in this transition.*/ private static Logger log = Logger.getLogger(ValueCompareTransition.class); /** XPath that points to the condition's operator.*/ public static final String XPATH_OPERATOR = "condition/@operator"; /** XPath that points to the condition's value.*/ public static final String XPATH_VALUE = "condition/@value"; /** XPath that points to the condition's dataname.*/ public static final String XPATH_DATANAME = "condition/@data"; /** The value of the 'equal' operator.*/ public static final String OPERATOR_EQUAL = "equal"; /** The value of the 'not equal' operator.*/ public static final String OPERATOR_NOTEQUAL = "notequal"; /** The operator.*/ protected String operator; /** The value used for comparison.*/ protected String value; /** The name of the data used for the comparison.*/ protected String dataname; public ValueCompareTransition() { } public ValueCompareTransition(String from, String to) { super(from, to); } @Override public void init(Node config) { log.debug("ValueCompareTransition.init"); String tmp = (String) XMLUtils.xpath( config, XPATH_OPERATOR, XPathConstants.STRING); operator = tmp.trim().toLowerCase(); value = (String) XMLUtils.xpath( config, XPATH_VALUE, XPathConstants.STRING); dataname = (String) XMLUtils.xpath( config, XPATH_DATANAME, XPathConstants.STRING); } @Override public boolean isValid(Artifact artifact, State a, State b) { log.debug("ValueCompareTransition.isValid"); FLYSArtifact flysArtifact = (FLYSArtifact) artifact; StateData dataObj = flysArtifact.getData(dataname); String dataVal = dataObj != null ? (String) dataObj.getValue() : ""; if (log.isDebugEnabled()) { log.debug("Compare settings:"); log.debug("-- dataname: " + dataname); log.debug("-- operator: " + operator); log.debug("-- compare value: " + value); log.debug("-- state value: " + dataVal); } if (operator.equals(OPERATOR_EQUAL)) { return value.equals(dataVal); } else if (operator.equals(OPERATOR_NOTEQUAL)) { return !(value.equals(dataVal)); } log.error("Wrong operator set! No comparison takes place."); return false; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :