Package org.biojava.bio.annodb
Class LazyFilteredAnnotationDB
- java.lang.Object
 - 
- org.biojava.bio.annodb.LazyFilteredAnnotationDB
 
 
- 
- All Implemented Interfaces:
 AnnotationDB
public class LazyFilteredAnnotationDB extends Object implements AnnotationDB
An implementation of AnnotationDB that lazily applies a filter.- Since:
 - 1.3
 - Author:
 - Matthew Pocock
 
 
- 
- 
Field Summary
- 
Fields inherited from interface org.biojava.bio.annodb.AnnotationDB
EMPTY 
 - 
 
- 
Constructor Summary
Constructors Constructor Description LazyFilteredAnnotationDB(String name, AnnotationDB source, AnnotationType schema)Create a new DB by wrapping another with a schema. 
- 
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description AnnotationDBfilter(AnnotationType at)Find all Annotation instances in this DB that are of a particular type.StringgetName()The name of this AnnotationDB.AnnotationTypegetSchema()Get an AnnotationType that accepts all Annotation instances in this DB.Iteratoriterator()Loop over each Annotation in this db.AnnotationDBsearch(AnnotationType at)Find all Annotation instances in this DB and any Annotations that are child properties of these that match an AnnotationType.intsize()The number of Annotation instances in the DB. 
 - 
 
- 
- 
Constructor Detail
- 
LazyFilteredAnnotationDB
public LazyFilteredAnnotationDB(String name, AnnotationDB source, AnnotationType schema)
Create a new DB by wrapping another with a schema.- Parameters:
 name- the name for the SBsource- the underlying DBschema- the schema to apply to the underlying DB to make this one
 
 - 
 
- 
Method Detail
- 
getName
public String getName()
Description copied from interface:AnnotationDBThe name of this AnnotationDB.
- Specified by:
 getNamein interfaceAnnotationDB- Returns:
 - the name of this AnnotationDB
 
 
- 
getSchema
public AnnotationType getSchema()
Description copied from interface:AnnotationDBGet an AnnotationType that accepts all Annotation instances in this DB.
The schema should accept all Annotations in the DB. However, it may hit other Annotations. So, AnnotationType.ALL is always a valid schema. Obviously, the more retrictive it is, the more usefull it becomes for introspection.
- Specified by:
 getSchemain interfaceAnnotationDB- Returns:
 - the schema AnnotationType
 
 
- 
iterator
public Iterator iterator()
Description copied from interface:AnnotationDBLoop over each Annotation in this db.- Specified by:
 iteratorin interfaceAnnotationDB- Returns:
 - an Iterator over each item in the DB
 
 
- 
size
public int size()
Description copied from interface:AnnotationDBThe number of Annotation instances in the DB.- Specified by:
 sizein interfaceAnnotationDB- Returns:
 - the size of this DB
 
 
- 
filter
public AnnotationDB filter(AnnotationType at)
Description copied from interface:AnnotationDBFind all Annotation instances in this DB that are of a particular type.- Specified by:
 filterin interfaceAnnotationDB- Parameters:
 at- the AnnotationType to match- Returns:
 - an AnnotationDB with all matching Annotation instances
 
 
- 
search
public AnnotationDB search(AnnotationType at)
Description copied from interface:AnnotationDBFind all Annotation instances in this DB and any Annotations that are child properties of these that match an AnnotationType.- Specified by:
 searchin interfaceAnnotationDB- Parameters:
 at- the AnnotationType to search with- Returns:
 - an AnnotationDB with all matching Annotation instances, irregardless of how deep in the hieracy they are
 
 
 - 
 
 -