public abstract class AbstractAlphabet extends AbstractChangeable implements FiniteAlphabet, Serializable
An abstract implementation of Alphabet.
This provides the frame-work for maintaining the SymbolParser <-> name mappings and also for the ChangeListeners.
This class is for developers to derive from, not for use directly.
Annotatable.AnnotationForwarder| Modifier and Type | Field and Description |
|---|---|
static long |
serialVersionUID |
EMPTY_ALPHABET, PARSERS, SYMBOLSANNOTATION| Modifier | Constructor and Description |
|---|---|
protected |
AbstractAlphabet() |
| Modifier and Type | Method and Description |
|---|---|
void |
addSymbol(Symbol s)
Adds a symbol to this alphabet.
|
protected abstract void |
addSymbolImpl(AtomicSymbol s) |
boolean |
contains(Symbol sym)
Returns whether or not this Alphabet contains the symbol.
|
protected abstract boolean |
containsImpl(AtomicSymbol s) |
Symbol |
getAmbiguity(Set syms)
Get a symbol that represents the set of symbols in syms.
|
protected Symbol |
getAmbiguityImpl(Set syms)
Backend for getAmbiguity, called when it is actually necessarly to create a new symbol.
|
Symbol |
getGapSymbol()
Get the 'gap' ambiguity symbol that is most appropriate for this alphabet.
|
Symbol |
getSymbol(List syms)
Get a symbol from the Alphabet which corresponds
to the specified ordered list of symbols.
|
protected abstract AtomicSymbol |
getSymbolImpl(List symList) |
SymbolTokenization |
getTokenization(String name)
Get a SymbolTokenization by name.
|
void |
putTokenization(String name,
SymbolTokenization parser)
Assigns a symbol parser to a String object.
|
protected Object |
readResolve()
To prevent duplication of a what should be a
single instance of an existing alphabet.
|
String |
toString() |
void |
validate(Symbol sym)
Throws a precanned IllegalSymbolException if the symbol is not contained
within this Alphabet.
|
addChangeListener, addChangeListener, generateChangeSupport, getChangeSupport, hasListeners, hasListeners, isUnchanging, removeChangeListener, removeChangeListenerclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waititerator, removeSymbol, sizegetAlphabets, getNamegetAnnotationaddChangeListener, addChangeListener, isUnchanging, removeChangeListener, removeChangeListenerpublic static final long serialVersionUID
protected AbstractAlphabet()
protected Object readResolve() throws ObjectStreamException
ObjectStreamExceptionpublic void putTokenization(String name, SymbolTokenization parser)
Assigns a symbol parser to a String object.
Afterwards, the parser can be retrieved using the getTokenization(Sting name) method.
public SymbolTokenization getTokenization(String name) throws NoSuchElementException, BioException
AlphabetGet a SymbolTokenization by name.
The parser returned is guaranteed to return Symbols and SymbolLists that conform to this alphabet.
Every alphabet should have a SymbolTokenzation under the name 'token' that uses the symbol token characters to translate a string into a SymbolList. Likewise, there should be a SymbolTokenization under the name 'name' that uses symbol names to identify symbols. Any other names may also be defined, but the behavior of the returned SymbolTokenization is not defined here.
A SymbolTokenization under the name 'default' should be defined for all sequences, that determines the behavior when printing out a sequence. Standard behavior is to define the 'token' SymbolTokenization as default if it exists, else to define the 'name' SymbolTokenization as the default, but others are possible.
getTokenization in interface Alphabetname - the name of the parserNoSuchElementException - if the name is unknownBioException - if for any reason the tokenization could not be builtpublic final Symbol getAmbiguity(Set syms) throws IllegalSymbolException
AlphabetGet a symbol that represents the set of symbols in syms.
Syms must be a set of Symbol instances each of which is contained within this alphabet. This method is used to retrieve ambiguity symbols.
getAmbiguity in interface Alphabetsyms - the Set of Symbols that will be found in getMatches of the
returned symbolIllegalSymbolExceptionprotected Symbol getAmbiguityImpl(Set syms) throws IllegalSymbolException
IllegalSymbolExceptionpublic final Symbol getSymbol(List syms) throws IllegalSymbolException
AlphabetGet a symbol from the Alphabet which corresponds to the specified ordered list of symbols.
The symbol at i in the list must be a member of the i'th alphabet in getAlphabets. If all of the symbols in rl are atomic, then the resulting symbol will also be atomic. If any one of them is an ambiguity symbol then the resulting symbol will be the appropriate ambiguity symbol.
getSymbol in interface Alphabetsyms - A list of Symbol instancesIllegalSymbolException - if the members of rl are
not Symbols over the alphabets returned from
getAlphabetsprotected abstract AtomicSymbol getSymbolImpl(List symList) throws IllegalSymbolException
IllegalSymbolExceptionprotected abstract void addSymbolImpl(AtomicSymbol s) throws IllegalSymbolException, ChangeVetoException
public final void addSymbol(Symbol s) throws IllegalSymbolException, ChangeVetoException
FiniteAlphabetIf the symbol matches more than one AtomicSymbol, then each symbol matching it will be added.
addSymbol in interface FiniteAlphabets - the Symbol to addIllegalSymbolException - if the symbol is null, or if for any reason
it can't be addedChangeVetoException - if either the alphabet doesn't allow symbols
to be added, or the change was vetoedpublic final boolean contains(Symbol sym)
AlphabetReturns whether or not this Alphabet contains the symbol.
An alphabet contains an ambiguity symbol iff the ambiguity symbol's getMatches() returns an alphabet that is a proper sub-set of this alphabet. That means that every one of the symbols that could match the ambiguity symbol is also a member of this alphabet.
public final Symbol getGapSymbol()
AlphabetGet the 'gap' ambiguity symbol that is most appropriate for this alphabet.
In general, this will be a BasisSymbol that represents a list of AlphabetManager.getGapSymbol() the same length as the getAlphabets list.
getGapSymbol in interface Alphabetpublic final void validate(Symbol sym) throws IllegalSymbolException
AlphabetThrows a precanned IllegalSymbolException if the symbol is not contained within this Alphabet.
This function is used all over the code to validate symbols as they enter a method. Also, the code is littered with catches for IllegalSymbolException. There is a preferred style of handling this, which should be covererd in the package documentation.
validate in interface Alphabetsym - the Symbol to validateIllegalSymbolException - if r is not contained in this alphabetprotected abstract boolean containsImpl(AtomicSymbol s)
Copyright © 2014 BioJava. All rights reserved.