Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/model/BlackboardDataFacet.java @ 4255:670e98f5a441
Fixed leak while merging facets.
The ThemeList that is used by OutputHelper to sort the
Facets for an Output now uses a list to store the ManagedFacets.
The correct order is made up by sorting the List using
Collections.sort() function of the Java JDK. Therfore, the
ManagedFacet class implements the Comparable interface. The
return value of its compareTo(other) method depends on the
value of the 'position' field.
author | Ingo Weinzierl <weinzierl.ingo@googlemail.com> |
---|---|
date | Thu, 25 Oct 2012 14:01:46 +0200 |
parents | ccc955ef8811 |
children |
line wrap: on
line source
package de.intevation.flys.artifacts.model; import java.util.ArrayList; import java.util.List; import de.intevation.artifacts.Artifact; import de.intevation.artifacts.CallContext; import de.intevation.artifactdatabase.state.Facet; import de.intevation.artifactdatabase.state.DefaultFacet; /** * Facet that writes artifact-uui and facet index on the blackboard, * delivers data if asked so. */ public class BlackboardDataFacet extends DefaultFacet { public BlackboardDataFacet() {} /** Do not instantiate a BlackboardDataFacet, subclass it instead. */ public BlackboardDataFacet(int idx, String name, String description) { super(idx, name, description); } /** Do not instantiate a BlackboardDataFacet, subclass it instead. */ public BlackboardDataFacet(String name, String description) { super(0, name, description); } /** Define key to which to respond when asked for 'blackboard' * (DataProvider)- data. */ public String areaDataKey(Artifact art) { return art.identifier() + ":" + getName() + ":" + getIndex(); } /** Hey, We can ArtifactUUID+:+FacetName+:+FacetIndex (i.e. getData)! */ @Override public List getStaticDataProviderKeys(Artifact art) { List list = new ArrayList(); list.add(areaDataKey(art)); return list; } /** * Can provide whatever getData returns. * @param key will respond on uuid+index * @param param ignored * @param context ignored * @return whatever getData delivers. */ @Override public Object provideBlackboardData(Artifact artifact, Object key, Object param, CallContext context ) { if (key.equals(areaDataKey(artifact))) { return getData(artifact, context); } else { return null; } } /** Copy deeply. */ @Override public Facet deepCopy() { BlackboardDataFacet copy = new BlackboardDataFacet(); copy.set(this); return copy; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :