X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fdatamodel%2FCigarArray.java;fp=src%2Fjalview%2Fdatamodel%2FCigarArray.java;h=9b60e566929ade7150328476a74cacf45f8557dd;hb=0f71bfca98457c30f1051f142c31b6aaa3e23ead;hp=0000000000000000000000000000000000000000;hpb=072fc418c393cbd2a40dfa1d3e46f90178b79572;p=jalview.git diff --git a/src/jalview/datamodel/CigarArray.java b/src/jalview/datamodel/CigarArray.java new file mode 100644 index 0000000..9b60e56 --- /dev/null +++ b/src/jalview/datamodel/CigarArray.java @@ -0,0 +1,206 @@ +/* + * Jalview - A Sequence Alignment Editor and Viewer + * Copyright (C) 2006 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + */ +package jalview.datamodel; + +public class CigarArray extends CigarBase +{ + /** + * Do CIGAR operations on a set of sequences from many other cigars + * BAD THINGS WILL HAPPEN IF A CIGARARRAY IS PASSED TO A CIGARARRAY + * or a CIGARCIGAR is given a CIGARARRAY to insert gaps into. + */ + /** + * array of subject cigars + */ + public CigarSimple refCigars[]=null; + private boolean seqcigararray=false; + private CigarArray() { + super(); + } + + /** + * isSeqCigarArray() + * @return boolean true if all refCigars resolve to a SeqCigar or a CigarCigar + */ + public boolean isSeqCigarArray() + { + return seqcigararray; + } + /** + * Apply CIGAR operations to several cigars in parallel + * will throw an error if any of cigar are actually CigarArrays. + * @param cigar Cigar[] + */ + public CigarArray(CigarSimple[] cigars) { + super(); + seqcigararray = true; + if (cigars != null && cigars.length > 0) + { + refCigars = new CigarSimple[cigars.length]; + for (int c = 0; c < cigars.length; c++) + { + refCigars[c] = cigars[c]; + if (! ( (cigars[c] instanceof SeqCigar) + || cigars[c] instanceof CigarCigar)) + { + seqcigararray = false; + } + } + } + } + /** + * @see Cigar.getSequenceAndDeletions + * @param GapChar char + * @return Object[][] + */ + protected Object[][] getArrayofSequenceAndDeletions(char GapChar) { + if (refCigars == null || refCigars.length == 0 || length == 0) { + return null; + } + Object[][] sqanddels = new Object[refCigars.length][]; + for (int c=0; c