private String source;
/**
- * 1-based index into the featureList used by FeatureStoreJS
- */
- public int index1;
-
- /**
- * containment nesting link used by FeatureStoreJS to track starting points
- */
- public SequenceFeature containedBy;
-
- /**
* Constructs a duplicate feature. Note: Uses makes a shallow copy of the
* otherDetails map, so the new and original SequenceFeature may reference the
* same objects in the map.
@Override
public boolean equals(Object o)
{
- return equals(o, false);
+ return (o != null && (o instanceof SequenceFeature)
+ && equalsInterval((SequenceFeature) o));
}
/**
+ * Having determined that this is in fact a SequenceFeature, now check it for
+ * equivalence. Overridden in CrossRef; used by IntervalStore (possibly).
+ */
+ @Override
+ public boolean equalsInterval(IntervalI sf)
+ {
+ return sf != null && equals((SequenceFeature) sf, false);
+ }
+ /**
* Overloaded method allows the equality test to optionally ignore the
* 'Parent' attribute of a feature. This supports avoiding adding many
* superficially duplicate 'exon' or CDS features to genomic or protein
* @param ignoreParent
* @return
*/
- public boolean equals(Object o, boolean ignoreParent)
+ public boolean equals(SequenceFeature sf, boolean ignoreParent)
{
- if (o == null || !(o instanceof SequenceFeature))
- {
- return false;
- }
-
- SequenceFeature sf = (SequenceFeature) o;
- boolean sameScore = Float.isNaN(score) ? Float.isNaN(sf.score)
- : score == sf.score;
- if (begin != sf.begin || end != sf.end || !sameScore)
- {
- return false;
- }
-
- if (getStrand() != sf.getStrand())
- {
- return false;
- }
-
- if (!(type + description + featureGroup + getPhase()).equals(
- sf.type + sf.description + sf.featureGroup + sf.getPhase()))
- {
- return false;
- }
- if (!equalAttribute(getValue("ID"), sf.getValue("ID")))
- {
- return false;
- }
- if (!equalAttribute(getValue("Name"), sf.getValue("Name")))
- {
- return false;
- }
- if (!ignoreParent)
- {
- if (!equalAttribute(getValue("Parent"), sf.getValue("Parent")))
- {
- return false;
- }
- }
- return true;
+ return (begin == sf.begin && end == sf.end
+ && getStrand() == sf.getStrand()
+ && (Float.isNaN(score) ? Float.isNaN(sf.score)
+ : score == sf.score)
+ && (type + description + featureGroup + getPhase())
+ .equals(sf.type + sf.description + sf.featureGroup
+ + sf.getPhase())
+ && equalAttribute(getValue("ID"), sf.getValue("ID"))
+ && equalAttribute(getValue("Name"), sf.getValue("Name"))
+ && (ignoreParent || equalAttribute(getValue("Parent"),
+ sf.getValue("Parent"))));
}
/**
source = theSource;
}
- @Override
- public IntervalI getContainedBy()
- {
- return containedBy;
- }
-
- @Override
- public void setContainedBy(IntervalI containedBy)
- {
- this.containedBy = (SequenceFeature) containedBy;
-
- }
-
+
}
class SFSortByEnd implements Comparator<SequenceFeature>