Mercurial > dive4elements > river
changeset 690:3481cd37e609 facets-slt
Use enums to dispatch computeFeed() and computeAdvance().
flys-artifacts/branches/facets-slt@2130 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Thu, 16 Jun 2011 08:57:05 +0000 (2011-06-16) |
parents | f8ac04b2dbd0 |
children | 2600aa2c7319 |
files | flys-artifacts/src/main/java/de/intevation/flys/artifacts/FLYSArtifact.java flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/ComputeCallback.java flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/ComputeCallbackAdapter.java |
diffstat | 3 files changed, 31 insertions(+), 22 deletions(-) [+] |
line wrap: on
line diff
--- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/FLYSArtifact.java Thu Jun 16 08:43:58 2011 +0000 +++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/FLYSArtifact.java Thu Jun 16 08:57:05 2011 +0000 @@ -46,6 +46,7 @@ import de.intevation.flys.artifacts.cache.CacheFactory; import de.intevation.flys.artifacts.model.ComputeCallback; +import de.intevation.flys.artifacts.model.ComputeCallback.ComputeType; import de.intevation.flys.artifacts.model.DischargeTables; import de.intevation.flys.artifacts.model.RiverFactory; import de.intevation.flys.artifacts.model.Segment; @@ -196,7 +197,7 @@ try { saveData(target, XPATH_FEED_INPUT, context); - compute(context); + compute(context, ComputeType.FEED); return describe(target, context); } @@ -261,7 +262,7 @@ setCurrentStateId(targetState); - compute(context); + compute(context, ComputeType.ADVANCE); return describe(target, context); } @@ -1051,8 +1052,8 @@ * * @param context The CallContext. */ - public Object compute(CallContext context) { - return compute(context, hash()); + public Object compute(CallContext context, ComputeType type) { + return compute(context, hash(), type); } @@ -1067,7 +1068,7 @@ * * @return the computed data. */ - public Object compute(CallContext context, String hash) { + public Object compute(CallContext context, String hash, ComputeType type) { String calc = (String) getData(CalculationSelect.FIELD_MODE).getValue(); DefaultState current = (DefaultState) getCurrentState(context); @@ -1079,15 +1080,25 @@ return null; } - return compute(hash, callback); + return compute(hash, callback, type); } - public Object compute(String key, ComputeCallback callback) { + public Object compute( + String key, + ComputeCallback callback, + ComputeType type) + { Cache cache = CacheFactory.getCache(COMPUTING_CACHE); if (cache == null) { - return callback.compute(facets); + switch (type) { + case FEED: + return callback.computeFeed(facets); + + case ADVANCE: + return callback.computeAdvance(facets); + } } net.sf.ehcache.Element element = cache.get(key); @@ -1096,7 +1107,15 @@ return element.getValue(); } - Object result = callback.compute(facets); + Object result = null; + switch (type) { + case FEED: + result = callback.computeFeed(facets); + break; + + case ADVANCE: + result = callback.computeAdvance(facets); + } if (result != null) { cache.put(new net.sf.ehcache.Element(key, result));
--- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/ComputeCallback.java Thu Jun 16 08:43:58 2011 +0000 +++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/ComputeCallback.java Thu Jun 16 08:57:05 2011 +0000 @@ -7,7 +7,9 @@ public interface ComputeCallback { - Object compute(List<Facet> facets); + public enum ComputeType { + FEED, ADVANCE + } Object computeAdvance(List<Facet> facets);
--- a/flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/ComputeCallbackAdapter.java Thu Jun 16 08:43:58 2011 +0000 +++ b/flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/ComputeCallbackAdapter.java Thu Jun 16 08:57:05 2011 +0000 @@ -8,18 +8,6 @@ public class ComputeCallbackAdapter implements ComputeCallback { @Override - public Object compute(List<Facet> facets) { - Object obj = computeAdvance(facets); - - if (obj == null) { - obj = computeFeed(facets); - } - - return obj; - } - - - @Override public Object computeAdvance(List<Facet> facets) { return null; }