public class SingletonAlphabet extends AbstractAlphabet implements FiniteAlphabet, Serializable
Annotatable.AnnotationForwarder
serialVersionUID
EMPTY_ALPHABET, PARSERS, SYMBOLS
ANNOTATION
Constructor and Description |
---|
SingletonAlphabet(AtomicSymbol sym) |
Modifier and Type | Method and Description |
---|---|
void |
addSymbolImpl(AtomicSymbol sym) |
protected boolean |
containsImpl(AtomicSymbol s) |
List |
getAlphabets()
Return an ordered List of the alphabets which make up a
compound alphabet.
|
Annotation |
getAnnotation()
Should return the associated annotation object.
|
String |
getName()
Get the name of the alphabet.
|
protected AtomicSymbol |
getSymbolImpl(List symList) |
SymbolTokenization |
getTokenization(String name)
Get a SymbolTokenization by name.
|
Iterator |
iterator()
Retrieve an Iterator over the AtomicSymbols in this FiniteAlphabet.
|
void |
removeSymbol(Symbol sym)
Remove a symbol from this alphabet.
|
int |
size()
The number of symbols in the alphabet.
|
addSymbol, contains, getAmbiguity, getAmbiguityImpl, getGapSymbol, getSymbol, putTokenization, readResolve, toString, validate
addChangeListener, addChangeListener, generateChangeSupport, getChangeSupport, hasListeners, hasListeners, isUnchanging, removeChangeListener, removeChangeListener
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
addSymbol
contains, getAmbiguity, getGapSymbol, getSymbol, validate
addChangeListener, addChangeListener, isUnchanging, removeChangeListener, removeChangeListener
public SingletonAlphabet(AtomicSymbol sym)
public List getAlphabets()
Alphabet
getAlphabets
in interface Alphabet
protected boolean containsImpl(AtomicSymbol s)
containsImpl
in class AbstractAlphabet
public String getName()
Alphabet
public SymbolTokenization getTokenization(String name) throws NoSuchElementException
Alphabet
Get 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 Alphabet
getTokenization
in class AbstractAlphabet
name
- the name of the parserNoSuchElementException
- if the name is unknownpublic Iterator iterator()
FiniteAlphabet
Each AtomicSymbol as for which this.contains(as) is true will be returned exactly once by this iterator in no specified order.
iterator
in interface FiniteAlphabet
public int size()
FiniteAlphabet
size
in interface FiniteAlphabet
public Annotation getAnnotation()
Annotatable
getAnnotation
in interface Annotatable
public void addSymbolImpl(AtomicSymbol sym) throws IllegalSymbolException
addSymbolImpl
in class AbstractAlphabet
IllegalSymbolException
public void removeSymbol(Symbol sym) throws IllegalSymbolException
FiniteAlphabet
If the symbol matches multiple AtomicSymbols, then each matching symbol it will be removed.
removeSymbol
in interface FiniteAlphabet
sym
- the Symbol to removeintGotIllegalSymbolException
- if the symbol is null, or if for any reason
it can't be removedprotected AtomicSymbol getSymbolImpl(List symList) throws IllegalSymbolException
getSymbolImpl
in class AbstractAlphabet
IllegalSymbolException
Copyright © 2020 BioJava. All rights reserved.