X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fanalysis%2FFinder.java;h=191f6e832ae0dd24176b8705d6c65dd09cec9283;hb=3d0101179759ef157b088ea135423cd909512d9f;hp=96151d743f0c4782a7d864581f0ec934de5c36df;hpb=47168f025aefdaa044802bd5f8f510ffe43a4808;p=jalview.git diff --git a/src/jalview/analysis/Finder.java b/src/jalview/analysis/Finder.java index 96151d7..191f6e8 100644 --- a/src/jalview/analysis/Finder.java +++ b/src/jalview/analysis/Finder.java @@ -1,6 +1,6 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8.2) - * Copyright (C) 2014 The Jalview Authors + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ The Jalview Authors * * This file is part of Jalview. * @@ -20,31 +20,43 @@ */ package jalview.analysis; -import java.util.*; +import jalview.datamodel.AlignmentI; +import jalview.datamodel.SearchResultMatchI; +import jalview.datamodel.SearchResults; +import jalview.datamodel.SearchResultsI; +import jalview.datamodel.SequenceGroup; +import jalview.datamodel.SequenceI; +import jalview.util.Comparison; -import jalview.datamodel.*; +import java.util.ArrayList; +import java.util.List; +import java.util.Vector; + +import com.stevesoft.pat.Regex; public class Finder { /** * Implements the search algorithms for the Find dialog box. */ - SearchResults searchResults; + SearchResultsI searchResults; AlignmentI alignment; - jalview.datamodel.SequenceGroup selection = null; + SequenceGroup selection = null; - Vector idMatch = null; + Vector idMatch = null; boolean caseSensitive = false; + private boolean includeDescription = false; + boolean findAll = false; - com.stevesoft.pat.Regex regex = null; + Regex regex = null; /** - * hold's last-searched position between calles to find(false) + * holds last-searched position between calls to find(false) */ int seqIndex = 0, resIndex = -1; @@ -78,11 +90,10 @@ public class Finder { searchString = searchString.toUpperCase(); } - regex = new com.stevesoft.pat.Regex(searchString); + regex = new Regex(searchString); regex.setIgnoreCase(!caseSensitive); searchResults = new SearchResults(); - idMatch = new Vector(); - Sequence seq; + idMatch = new Vector(); String item = null; boolean found = false; int end = alignment.getHeight(); @@ -97,10 +108,11 @@ public class Finder selection = null; } } + SearchResultMatchI lastm = null; while (!found && (seqIndex < end)) { - seq = (Sequence) alignment.getSequenceAt(seqIndex); + SequenceI seq = alignment.getSequenceAt(seqIndex); if ((selection != null && selection.getSize() > 0) && !selection.getSequences(null).contains(seq)) @@ -135,7 +147,21 @@ public class Finder { } - if (regex.search(seq.getName())) + if (regex.search(seq.getName()) && !idMatch.contains(seq)) + { + idMatch.addElement(seq); + hasResults = true; + if (!findAll) + { + // stop and return the match + found = true; + break; + } + } + + if (isIncludeDescription() && seq.getDescription() != null + && regex.search(seq.getDescription()) + && !idMatch.contains(seq)) { idMatch.addElement(seq); hasResults = true; @@ -156,16 +182,16 @@ public class Finder } // /Shall we ignore gaps???? - JBPNote: Add Flag for forcing this or not - StringBuffer noGapsSB = new StringBuffer(); + StringBuilder noGapsSB = new StringBuilder(); int insertCount = 0; - Vector spaces = new Vector(); + List spaces = new ArrayList(); for (int j = 0; j < item.length(); j++) { - if (!jalview.util.Comparison.isGap(item.charAt(j))) + if (!Comparison.isGap(item.charAt(j))) { noGapsSB.append(item.charAt(j)); - spaces.addElement(new Integer(insertCount)); + spaces.add(Integer.valueOf(insertCount)); } else { @@ -174,7 +200,6 @@ public class Finder } String noGaps = noGapsSB.toString(); - for (int r = resIndex; r < noGaps.length(); r++) { @@ -182,23 +207,22 @@ public class Finder { resIndex = regex.matchedFrom(); - if ((selection != null && selection.getSize() > 0) - && ((resIndex + Integer.parseInt(spaces.elementAt( - resIndex).toString())) < selection.getStartRes())) + if ((selection != null && selection.getSize() > 0) && (resIndex + + spaces.get(resIndex) < selection.getStartRes())) { continue; } - - int sres = seq - .findPosition(resIndex - + Integer.parseInt(spaces.elementAt(resIndex) - .toString())); - int eres = seq.findPosition(regex.matchedTo() - - 1 - + Integer.parseInt(spaces - .elementAt(regex.matchedTo() - 1).toString())); - - searchResults.addResult(seq, sres, eres); + // if invalid string used, then regex has no matched to/from + int sres = seq.findPosition(resIndex + spaces.get(resIndex)); + int eres = seq.findPosition(regex.matchedTo() - 1 + + (spaces.get(regex.matchedTo() - 1))); + // only add result if not contained in previous result + if (lastm == null || (lastm.getSequence() != seq + || (!(lastm.getStart() <= sres + && lastm.getEnd() >= eres)))) + { + lastm = searchResults.addResult(seq, sres, eres); + } hasResults = true; if (!findAll) { @@ -302,9 +326,12 @@ public class Finder } /** - * @return the idMatch + * Returns the (possibly empty) list of matching sequences (when search + * includes searching sequence names) + * + * @return */ - public Vector getIdMatch() + public Vector getIdMatch() { return idMatch; } @@ -320,7 +347,7 @@ public class Finder /** * @return the searchResults */ - public SearchResults getSearchResults() + public SearchResultsI getSearchResults() { return searchResults; } @@ -358,4 +385,14 @@ public class Finder { this.seqIndex = seqIndex; } + + public boolean isIncludeDescription() + { + return includeDescription; + } + + public void setIncludeDescription(boolean includeDescription) + { + this.includeDescription = includeDescription; + } }