2 * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$)
3 * Copyright (C) $$Year-Rel$$ The Jalview Authors
5 * This file is part of Jalview.
7 * Jalview is free software: you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation, either version 3
10 * of the License, or (at your option) any later version.
12 * Jalview is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty
14 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 * PURPOSE. See the GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with Jalview. If not, see <http://www.gnu.org/licenses/>.
19 * The Jalview Authors are detailed in the 'AUTHORS' file.
21 package jalview.datamodel;
23 public interface AnnotatedCollectionI extends SequenceCollectionI
27 * TODO: decide if null is a valid response if there is no annotation on the
32 AlignmentAnnotation[] getAlignmentAnnotation();
35 * Returns a list of annotations matching the given calc id, or an empty list
41 Iterable<AlignmentAnnotation> findAnnotation(String calcId);
44 * Returns an iterable collection of any annotations that match on given
45 * sequence ref, calcId and label (ignoring null values).
48 * null or reference sequence to select annotation for
50 * null or the calcId to select annotation for
52 * null or the label to select annotation for
54 Iterable<AlignmentAnnotation> findAnnotations(SequenceI seq,
55 String calcId, String label);
58 * context for this annotated collection
60 * @return null or the collection upon which this collection is defined (e.g.
61 * alignment, parent group).
63 AnnotatedCollectionI getContext();