X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=forester%2Fjava%2Fsrc%2Forg%2Fforester%2Fsequence%2FBasicSequence.java;h=6d339cae25790d8538deed1f8efbd04527729d75;hb=c0439ed8b088887ffea2faf11bc7897333287cb3;hp=42861fb227aba9cec109b26cb3828708878d1352;hpb=10297bd8b8a4b4ab198a17a42fc6ff24ae2ed49b;p=jalview.git diff --git a/forester/java/src/org/forester/sequence/BasicSequence.java b/forester/java/src/org/forester/sequence/BasicSequence.java index 42861fb..6d339ca 100644 --- a/forester/java/src/org/forester/sequence/BasicSequence.java +++ b/forester/java/src/org/forester/sequence/BasicSequence.java @@ -39,15 +39,19 @@ public class BasicSequence implements MolecularSequence { * */ public BasicSequence( final String identifier, final String mol_sequence, final TYPE type ) { + check( identifier, mol_sequence ); + _mol_sequence = mol_sequence.toCharArray(); + _identifier = identifier; + _type = type; + } + + private static final void check( final String identifier, final String mol_sequence ) { if ( ForesterUtil.isEmpty( identifier ) ) { throw new IllegalArgumentException( "identifier of sequence cannot be empty" ); } if ( ForesterUtil.isEmpty( mol_sequence ) ) { throw new IllegalArgumentException( "molecular sequence cannot be empty" ); } - _mol_sequence = mol_sequence.toCharArray(); - _identifier = identifier; - _type = type; } /** @@ -144,16 +148,19 @@ public class BasicSequence implements MolecularSequence { } public static MolecularSequence createAaSequence( final String identifier, final String mol_sequence ) { + check( identifier, mol_sequence ); return new BasicSequence( identifier, mol_sequence.toUpperCase().replaceAll( "\\.", GAP_STR ) .replaceAll( AA_REGEXP, Character.toString( UNSPECIFIED_AA ) ), TYPE.AA ); } public static MolecularSequence createDnaSequence( final String identifier, final String mol_sequence ) { + check( identifier, mol_sequence ); return new BasicSequence( identifier, mol_sequence.toUpperCase().replaceAll( "\\.", GAP_STR ) .replaceAll( DNA_REGEXP, Character.toString( UNSPECIFIED_NUC ) ), TYPE.DNA ); } public static MolecularSequence createRnaSequence( final String identifier, final String mol_sequence ) { + check( identifier, mol_sequence ); return new BasicSequence( identifier, mol_sequence.toUpperCase().replaceAll( "\\.", GAP_STR ) .replaceAll( RNA_REGEXP, Character.toString( UNSPECIFIED_NUC ) ), TYPE.RNA ); }