- public SequenceI deriveSequence() {
- SequenceI seq = new Sequence(name, sequence, start, end);
- seq.setDescription(description);
- if (datasetSequence!=null) {
- seq.setDatasetSequence(datasetSequence);
- } else {
- if (isValidDatasetSequence())
- seq.setDatasetSequence(this);
+ public SequenceI deriveSequence()
+ {
+ SequenceI seq = new Sequence(this);
+ if (datasetSequence != null)
+ {
+ // duplicate current sequence with same dataset
+ seq.setDatasetSequence(datasetSequence);
+ }
+ else
+ {
+ if (isValidDatasetSequence())
+ {
+ // Use this as dataset sequence
+ seq.setDatasetSequence(this);
+ }
+ else
+ {
+ // Create a new, valid dataset sequence
+ SequenceI ds = seq;
+ ds.setSequence(AlignSeq.extractGaps(
+ jalview.util.Comparison.GapChars, new String(sequence)));
+ setDatasetSequence(ds);
+ ds.setSequenceFeatures(getSequenceFeatures());
+ seq = this; // and return this sequence as the derived sequence.
+ }
+ }
+ return seq;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see jalview.datamodel.SequenceI#createDatasetSequence()
+ */
+ public SequenceI createDatasetSequence()
+ {
+ if (datasetSequence == null)
+ {
+ datasetSequence = new Sequence(getName(), AlignSeq.extractGaps(
+ jalview.util.Comparison.GapChars, getSequenceAsString()),
+ getStart(), getEnd());
+ datasetSequence.setSequenceFeatures(getSequenceFeatures());
+ datasetSequence.setDescription(getDescription());
+ setSequenceFeatures(null);
+ // move database references onto dataset sequence
+ datasetSequence.setDBRef(getDBRef());
+ setDBRef(null);
+ datasetSequence.setPDBId(getPDBId());
+ setPDBId(null);
+ datasetSequence.updatePDBIds();
+ }
+ return datasetSequence;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see
+ * jalview.datamodel.SequenceI#setAlignmentAnnotation(AlignmmentAnnotation[]
+ * annotations)
+ */
+ public void setAlignmentAnnotation(AlignmentAnnotation[] annotations)
+ {
+ if (annotation != null)
+ {
+ annotation.removeAllElements();
+ }
+ if (annotations != null)
+ {
+ for (int i = 0; i < annotations.length; i++)
+ {
+ if (annotations[i] != null)
+ addAlignmentAnnotation(annotations[i]);