Package org.biojavax.ontology
Class SimpleComparableOntology
- java.lang.Object
- 
- org.biojava.utils.AbstractChangeable
- 
- org.biojavax.ontology.SimpleComparableOntology
 
 
- 
- All Implemented Interfaces:
- Comparable,- Ontology,- Changeable,- ComparableOntology
 
 public class SimpleComparableOntology extends AbstractChangeable implements ComparableOntology Represents an ontology that can be compared to other ontologies.- Since:
- 1.5
- Author:
- Richard Holland, Mark Schreiber
 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface org.biojava.ontology.OntologyOntology.Impl
 
- 
 - 
Field Summary- 
Fields inherited from interface org.biojavax.ontology.ComparableOntologyDESCRIPTION, TERM, TRIPLE
 
- 
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedSimpleComparableOntology()SimpleComparableOntology(String name)Creates a new instance of SimpleComparableOntology with the given, immutable, non-nullable name.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description intcompareTo(Object o)Ontologies are compared only by name.booleancontainsTerm(String name)Determines if this ontology currently contains a term namednamebooleancontainsTriple(Term subject, Term object, Term predicate)See if a triple exists in this ontologyTermcreateTerm(String name)Create a new term in this ontology.TermcreateTerm(String name, String description)Create a new term in this ontology.TermcreateTerm(String name, String description, Object[] synonyms)Create a new term in this ontology.TriplecreateTriple(Term subject, Term object, Term predicate, String name, String description)Creates a new Triple.VariablecreateVariable(String name, String description)Create a new term in this ontology that is used as a variable.voiddeleteTerm(Term t)Remove a term from an ontology, together with all triples which refer to it.booleanequals(Object obj)Ontologies are equal if their names are equal.StringgetDescription()Return a human-readable description of this ontology.IntegergetId()Gets the Hibernate ID.StringgetName()Return the name of this ontologyOntologyOpsgetOps()Return the associated OntologyOps.ComparableTermgetOrCreateTerm(String name)Looks for a term with the given name and returns it.ComparableTriplegetOrCreateTriple(Term subject, Term object, Term predicate)Looks for a triple with the given subject object and predicate and returns it.ComparableTermgetOrImportTerm(Term term)Looks for a term with the same name as the given term and returns it.TermgetTerm(String s)Fetch the term with the specified name.SetgetTerms()Return all the terms in this ontologySetgetTermSet()Returns the set of terms in this ontology.SetgetTriples(Term subject, Term object, Term predicate)Return all triples from this ontology which match the supplied pattern.SetgetTripleSet()Returns the set of triples in this ontology.inthashCode()TermimportTerm(Term t, String localName)Create a view of a term from another ontology.voidsetDescription(String description)Sets a human-readable description of this ontology.voidsetId(Integer id)Sets the Hibernate ID.voidsetName(String name)Set the name for this ontologyvoidsetTermSet(Set terms)Clears out all the terms and populates the ontology with the contents of the set passed.voidsetTripleSet(Set triples)Clears out all the triples and populates the ontology with the contents of the set passed.StringtoString()Form: "name"- 
Methods inherited from class org.biojava.utils.AbstractChangeableaddChangeListener, addChangeListener, generateChangeSupport, getChangeSupport, hasListeners, hasListeners, isUnchanging, removeChangeListener, removeChangeListener
 - 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface org.biojava.utils.ChangeableaddChangeListener, addChangeListener, isUnchanging, removeChangeListener, removeChangeListener
 
- 
 
- 
- 
- 
Constructor Detail- 
SimpleComparableOntologypublic SimpleComparableOntology(String name) Creates a new instance of SimpleComparableOntology with the given, immutable, non-nullable name.- Parameters:
- name- the name of the ontology.
 
 - 
SimpleComparableOntologyprotected SimpleComparableOntology() 
 
- 
 - 
Method Detail- 
compareTopublic int compareTo(Object o) Ontologies are compared only by name.- Specified by:
- compareToin interface- Comparable
 
 - 
containsTermpublic boolean containsTerm(String name) Determines if this ontology currently contains a term namedname- Specified by:
- containsTermin interface- Ontology
- Returns:
- true is contained
 
 - 
getTermpublic Term getTerm(String s) throws NoSuchElementException Fetch the term with the specified name.- Specified by:
- getTermin interface- Ontology
- Parameters:
- s- the name of the term
- Returns:
- The term named name
- Throws:
- NoSuchElementException- if no term exists with that name
 
 - 
getOrCreateTermpublic ComparableTerm getOrCreateTerm(String name) Looks for a term with the given name and returns it. If it couldn't be found, then it creates it, adds it to the ontology, then returns it. If the term has to be created, it is added with the description "auto-generated by biojavax".- Specified by:
- getOrCreateTermin interface- ComparableOntology
- Parameters:
- name- the name of the term to look for.
- Returns:
- the ComparableTerm representing that name.
 
 - 
getOrCreateTriplepublic ComparableTriple getOrCreateTriple(Term subject, Term object, Term predicate) Looks for a triple with the given subject object and predicate and returns it. If it couldn't be found, then it creates it, adds it to the ontology, then returns it.- Specified by:
- getOrCreateTriplein interface- ComparableOntology
- Parameters:
- subject- the subject of the triple eg apple
- object- the object of the triple eg fruit
- predicate- the relationship of the triple eg is_a
- Returns:
- the ComparableTriple representing the object subject and predicate.
 
 - 
getOrImportTermpublic ComparableTerm getOrImportTerm(Term term) Looks for a term with the same name as the given term and returns it. If it couldn't be found, then it creates it, adds it to the ontology, then returns it.- Specified by:
- getOrImportTermin interface- ComparableOntology
- Parameters:
- term- the term to look for.
- Returns:
- the ComparableTerm representing that term in this ontology.
 
 - 
createTermpublic Term createTerm(String name, String description, Object[] synonyms) throws AlreadyExistsException, ChangeVetoException, IllegalArgumentException Create a new term in this ontology.- Specified by:
- createTermin interface- Ontology
- Parameters:
- name- The name of the term (must be unique)
- description- A human-readable description (may be empty)
- synonyms- Some synonyms for this term.
- Returns:
- The newly created term.
- Throws:
- AlreadyExistsException- if a term of this name already exists
- ChangeVetoException
- IllegalArgumentException- if either- nameor- descriptionis- null, or violates some other constraint of this implementation.
 
 - 
importTermpublic Term importTerm(Term t, String localName) throws ChangeVetoException, IllegalArgumentException Create a view of a term from another ontology. If the requested term has already been imported under that name, this method returns the existing RemoteTerm object. If the term that is being imported is itself a RemoteTerm instance then first unwrap the term back to the orriginal term it represents and then produce a RemoteTerm from that. If the term being imported orriginated from this ontology, then return that term unaltered. This particular implementation merely copies the term into this ontology, and returns a pointer to the copied term. Thus the term becomes a part of this ontology instead of a pointer to another ontology.- Specified by:
- importTermin interface- Ontology
- Parameters:
- t- the Term to import
- localName- the local name to import it under, optionally null
- Returns:
- a Term
- Throws:
- ChangeVetoException
- IllegalArgumentException
- See Also:
- ComparableTerm
 
 - 
createTriplepublic Triple createTriple(Term subject, Term object, Term predicate, String name, String description) throws AlreadyExistsException, ChangeVetoException Creates a new Triple. If you call this method with plain Terms instead of ComparableTerms, it will import them into the local ontology first. This is done BEFORE the check to see if the triple already exists, as obviously it can't check until it has the right terms to check with. So you may find the terms get imported but the triple does not. Moral of the story: use ComparableTerm objects!- Specified by:
- createTriplein interface- Ontology
- Parameters:
- subject- the subject Term
- object- the object Term
- predicate- the predicate Term
- name- the name of the triple, or null
- description- the description of the triple, or null
- Returns:
- a new Triple over these three terms
- Throws:
- AlreadyExistsException- if a triple already exists with the same subject, object and predicate, regardless of the name and description
- ChangeVetoException
- See Also:
- ComparableTerm
 
 - 
deleteTermpublic void deleteTerm(Term t) throws ChangeVetoException Remove a term from an ontology, together with all triples which refer to it. If you call this method with a plain Term instead of a ComparableTerm, it may not match any of the terms in the ontology as they are all stored as ComparableTerms. So, use ComparableTerm objects! This method also removes all triples that the term is involved in.- Specified by:
- deleteTermin interface- Ontology
- Throws:
- ChangeVetoException
- See Also:
- ComparableTerm
 
 - 
getTriplespublic Set getTriples(Term subject, Term object, Term predicate) Return all triples from this ontology which match the supplied pattern. If any of the parameters of this method arenull, they are treated as wildcards. If you call this method with plain Terms instead of ComparableTerms, it may not match any of the triples in the ontology as they are all stored as ComparableTerms. So, use ComparableTerm objects! The set returned is a set of ComparableTriple objects.- Specified by:
- getTriplesin interface- Ontology
- Parameters:
- subject- The subject to search for, or- null
- object- The object to search for, or- null
- predicate- The relationship to search for, or- null.
- Returns:
- a Set of triples
- See Also:
- ComparableTerm,- ComparableTriple
 
 - 
setTripleSetpublic void setTripleSet(Set triples) throws ChangeVetoException Clears out all the triples and populates the ontology with the contents of the set passed. Warning this method gives access to the original Collection not a copy. This is required by Hibernate. If you modify the object directly the behaviour may be unpredictable.- Specified by:
- setTripleSetin interface- ComparableOntology
- Parameters:
- triples- the set of ComparableTriple objects this ontology should have.
- Throws:
- ChangeVetoException- if any of them are unacceptable.
- See Also:
- ComparableTriple
 
 - 
getTripleSetpublic Set getTripleSet() Returns the set of triples in this ontology. Warning this method gives access to the original Collection not a copy. This is required by Hibernate. If you modify the object directly the behaviour may be unpredictable.- Specified by:
- getTripleSetin interface- ComparableOntology
- Returns:
- the set of ComparableTriple objects.
 
 - 
getTermspublic Set getTerms() Return all the terms in this ontology This will always return a set of ComparableTerm objects. It is not the original set so you are safe to modify it.- Specified by:
- getTermsin interface- Ontology
- Returns:
- a Set of all Terms of the ontology.
- See Also:
- ComparableTerm
 
 - 
setTermSetpublic void setTermSet(Set terms) throws ChangeVetoException Clears out all the terms and populates the ontology with the contents of the set passed. The terms should be ComparableTerms. Warning this method gives access to the original Collection not a copy. This is required by Hibernate. If you modify the object directly the behaviour may be unpredictable.- Specified by:
- setTermSetin interface- ComparableOntology
- Parameters:
- terms- a set of Term objects this ontology should have.
- Throws:
- ChangeVetoException- if any of them are unacceptable.
- See Also:
- ComparableTerm
 
 - 
getTermSetpublic Set getTermSet() Returns the set of terms in this ontology. Warning this method gives access to the original Collection not a copy. This is required by Hibernate. If you modify the object directly the behaviour may be unpredictable.- Specified by:
- getTermSetin interface- ComparableOntology
- Returns:
- a set of ComparableTerm objects.
- See Also:
- ComparableTerm
 
 - 
containsTriplepublic boolean containsTriple(Term subject, Term object, Term predicate) See if a triple exists in this ontology If you call this method with plain Terms instead of ComparableTerms, it may not match any of the triples in the ontology as they are all stored as ComparableTerms. So, use ComparableTerm objects! The set returned is a set of ComparableTriple objects.- Specified by:
- containsTriplein interface- Ontology
- Returns:
- true if contained
- See Also:
- ComparableTerm,- ComparableTriple
 
 - 
createTermpublic Term createTerm(String name) throws AlreadyExistsException, ChangeVetoException, IllegalArgumentException Create a new term in this ontology.- Specified by:
- createTermin interface- Ontology
- Parameters:
- name- The name of the term (must be unique))
- Returns:
- The newly created term.
- Throws:
- AlreadyExistsException- if a term of this name already exists
- ChangeVetoException
- IllegalArgumentException- if either- nameor- descriptionis- null, or violates some other constraint of this implementation.
 
 - 
createTermpublic Term createTerm(String name, String description) throws AlreadyExistsException, ChangeVetoException, IllegalArgumentException Create a new term in this ontology.- Specified by:
- createTermin interface- Ontology
- Parameters:
- name- The name of the term (must be unique)
- description- A human-readable description (may be empty)
- Returns:
- The newly created term.
- Throws:
- AlreadyExistsException- if a term of this name already exists
- ChangeVetoException
- IllegalArgumentException- if either- nameor- descriptionis- null, or violates some other constraint of this implementation.
 
 - 
createVariablepublic Variable createVariable(String name, String description) throws AlreadyExistsException, ChangeVetoException, IllegalArgumentException Create a new term in this ontology that is used as a variable. NOT IMPLEMENTED- Specified by:
- createVariablein interface- Ontology
- Parameters:
- name- The name of the term (must be unique)
- description- A human-readable description (may be empty)
- Returns:
- The newly created term.
- Throws:
- AlreadyExistsException- if a term of this name already exists
- ChangeVetoException
- IllegalArgumentException- if either- nameor- descriptionis- null, or violates some other constraint of this implementation.
 
 - 
getDescriptionpublic String getDescription() Return a human-readable description of this ontology.- Specified by:
- getDescriptionin interface- ComparableOntology
- Specified by:
- getDescriptionin interface- Ontology
- Returns:
- the description.
 
 - 
setDescriptionpublic void setDescription(String description) throws ChangeVetoException Sets a human-readable description of this ontology.- Specified by:
- setDescriptionin interface- ComparableOntology
- Specified by:
- setDescriptionin interface- Ontology
- Parameters:
- description- the description.
- Throws:
- ChangeVetoException- in case of problems.
 
 - 
setNamepublic void setName(String name) Description copied from interface:OntologySet the name for this ontology
 - 
getOpspublic OntologyOps getOps() Return the associated OntologyOps. This method should be implemented by ontology implementors to allow OntoTools to get optimized access to some usefull ontology operations. It is not intended that users will ever invoke this. A sensible dumb implementation of this would return a per-ontology instance of DefaultOps.
 - 
getIdpublic Integer getId() Gets the Hibernate ID. Should be used with caution.- Returns:
- the Hibernate ID, if using Hibernate.
 
 
- 
 
-