Package org.biojava.nbio.ontology.utils
Class AbstractAnnotation
java.lang.Object
org.biojava.nbio.ontology.utils.AbstractAnnotation
- All Implemented Interfaces:
Serializable
,Annotation
- Direct Known Subclasses:
SmallAnnotation
A utility class to ease the problem of implementing an Annotation to that of
providing an apropreate implementation of Map. Where possible implementations
This class is only intended as a way to implement
Annotation. If you are not trying to do that, then don't read on. If you
are reading the documentation for an Annotation implementation that extends
this, then don't read on. There is nothing to see here.
If you are still reading this, then you must be trying to
implement Annotation. To do that, extend this class and implement
getProperties()
and propertiesAllocated()
.
Where possible implementations should be backed with a
LinkedHashMap
or similar so properties are iterated in the order
they were added.- Since:
- 1.0
- Author:
- Matthew Pocock, Greg Cox
- See Also:
-
Field Summary
Fields inherited from interface org.biojava.nbio.ontology.utils.Annotation
EMPTY_ANNOTATION
-
Constructor Summary
ModifierConstructorDescriptionprotected
Protected no-args constructor intended for sub-classes.AbstractAnnotation
(Map annMap) Create a new Annotation by copying the key-value pairs from a map.protected
Copy-constructor. -
Method Summary
Modifier and TypeMethodDescriptionasMap()
Return a map that contains the same key/values as this Annotation.boolean
containsProperty
(Object key) Returns whether there the property is defined.boolean
protected abstract Map
Implement this to return the Map delegate.getProperty
(Object key) Retrieve the value of a property by key.int
hashCode()
keys()
Get a set of key objects.protected abstract boolean
A convenience method to see if we have allocated the properties Map.void
removeProperty
(Object key) Delete a property.void
setProperty
(Object key, Object value) Set the value of a property.toString()
-
Constructor Details
-
AbstractAnnotation
protected AbstractAnnotation()Protected no-args constructor intended for sub-classes. This class is abstract and can not be directly instantiated. -
AbstractAnnotation
Copy-constructor.This does a shallow copy of the annotation. The result is an annotation with the same properties and values, but which is independant of the original annotation.
- Parameters:
ann
- the Annotation to copy
-
AbstractAnnotation
Create a new Annotation by copying the key-value pairs from a map. The resulting Annotation is independant of the map.- Parameters:
annMap
- the Map to copy from.
-
-
Method Details
-
getProperties
Implement this to return the Map delegate. Modifying this return value will modify the properties associated with this annotation. From code in the 1.2 version of AbstractAnnotation This is required for the implementation of an Annotation that extends AbstractAnnotation. Where possible implementations should be backed with aLinkedHashMap
or similar so properties are iterated in the order they were added.- Returns:
- a Map containing all properties
-
propertiesAllocated
protected abstract boolean propertiesAllocated()A convenience method to see if we have allocated the properties Map. This is required for the implementation of an Annotation that extends AbstractAnnotation.- Returns:
- true if the properties have been allocated, false otherwise
-
getProperty
Description copied from interface:Annotation
Retrieve the value of a property by key.
Unlike the Map collections, it will complain if the key does not exist. It will only return null if the key is defined and has value null.
Normal raw access to the property. For cleverer access, use methods in AnnotationType.- Specified by:
getProperty
in interfaceAnnotation
- Parameters:
key
- the key of the property to retrieve- Returns:
- the object associated with that key
- Throws:
NoSuchElementException
- if there is no property with the key
-
setProperty
Description copied from interface:Annotation
Set the value of a property.
This method throws an exception if either properties can not be added to this object, or that this particular property is immutable or illegal within the implementation.
Normal raw access to the property. For cleverer access, use methods in AnnotationType.- Specified by:
setProperty
in interfaceAnnotation
- Parameters:
key
- the key objectvalue
- the new value for this key
-
removeProperty
Description copied from interface:Annotation
Delete a property. Normal raw access to the property. For cleverer access, use methods in AnnotationType.- Specified by:
removeProperty
in interfaceAnnotation
- Parameters:
key
- the key object- Throws:
NoSuchElementException
- if the property doesn't exist
-
containsProperty
Description copied from interface:Annotation
Returns whether there the property is defined. Normal raw access to the property. For cleverer access, use methods in AnnotationType.- Specified by:
containsProperty
in interfaceAnnotation
- Parameters:
key
- the key Object to search for- Returns:
- true if this Annotation knows about the key, false otherwise
-
keys
Description copied from interface:Annotation
Get a set of key objects.- Specified by:
keys
in interfaceAnnotation
- Returns:
- a Set of key objects
-
toString
-
asMap
Description copied from interface:Annotation
Return a map that contains the same key/values as this Annotation.If the annotation changes, the map may not reflect this. The Map may be unmodifiable.
- Specified by:
asMap
in interfaceAnnotation
- Returns:
- a Map
-
hashCode
public int hashCode() -
equals
-