package jalview.datamodel.features;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.Collections;
import java.util.HashSet;
import java.util.List;
return new ArrayList<>();
}
- return getAllFeatures(featureTypes.toArray(new String[featureTypes
- .size()]));
+ return getAllFeatures(
+ featureTypes.toArray(new String[featureTypes.size()]));
}
/**
* {@inheritDoc}
*/
@Override
+ public List<Integer> getFeatureExtent(String... type)
+ {
+ Integer from = 0, to = 0;
+
+ for (FeatureStore featureSet : varargToTypes(type))
+ {
+ if (from == 0)
+ {
+ from = featureSet.getBegin();
+ to = featureSet.getEnd();
+ }
+ else
+ {
+ from = Math.min(from, featureSet.getBegin());
+ to = Math.max(to, featureSet.getEnd());
+ }
+ }
+ return Arrays.asList(from, to);
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ @Override
public List<SequenceFeature> getPositionalFeatures(String... type)
{
List<SequenceFeature> result = new ArrayList<>();
for (Entry<String, FeatureStore> featureType : featureStore.entrySet())
{
- Set<String> featureGroups = featureType.getValue().getFeatureGroups(
- positionalFeatures);
+ Set<String> featureGroups = featureType.getValue()
+ .getFeatureGroups(positionalFeatures);
for (String group : groups)
{
if (featureGroups.contains(group))
@Override
public float getMinimumScore(String type, boolean positional)
{
- return featureStore.containsKey(type) ? featureStore.get(type)
- .getMinimumScore(positional) : Float.NaN;
+ return featureStore.containsKey(type)
+ ? featureStore.get(type).getMinimumScore(positional)
+ : Float.NaN;
}
/**
@Override
public float getMaximumScore(String type, boolean positional)
{
- return featureStore.containsKey(type) ? featureStore.get(type)
- .getMaximumScore(positional) : Float.NaN;
+ return featureStore.containsKey(type)
+ ? featureStore.get(type).getMaximumScore(positional)
+ : Float.NaN;
}
/**
final boolean forwardStrand)
{
Collections.sort(features,
- forwardStrand
- ? IntervalI.COMPARE_BEGIN_ASC_END_DESC
+ forwardStrand ? IntervalI.COMPARE_BEGIN_ASC_END_DESC
: IntervalI.COMPARE_END_DESC);
}