package jalview.gui; import jalview.jbgui.GFinder; import jalview.datamodel.*; import java.awt.event.*; import javax.swing.*; import javax.swing.event.*; import java.util.*; import java.util.regex.*; import java.awt.*; public class Finder extends GFinder { AlignViewport av; AlignmentPanel ap; JInternalFrame frame; String searchString; SuperGroup searchGroup; int seqIndex = 0; int resIndex = 0; public Finder(AlignViewport av, AlignmentPanel ap, JInternalFrame f) { this.av = av; this.ap = ap; frame = f; // all a big pain, but we need to wait until the frame is visible before the textfield can // obtain the focus///////////////////////// frame.addInternalFrameListener(new InternalFrameAdapter() { public void internalFrameOpened(InternalFrameEvent evt) { SwingUtilities.invokeLater(new Runnable() { public void run() { textfield.requestFocus(); } }); } public void internalFrameClosing(InternalFrameEvent evt) { cancel_actionPerformed(null); } }); } public void textfield_actionPerformed(ActionEvent e) { doSearch(false); } public void findNext_actionPerformed(ActionEvent e) { doSearch(false); } public void findAll_actionPerformed(ActionEvent e) { resIndex=0; seqIndex=0; doSearch(true); } public void cancel_actionPerformed(ActionEvent e) { try{ // if allResults is null, this effectively switches displaySearch flag in seqCanvas ap.highlightSearchResults( null ); // frame.setClosed(true); }catch(Exception ex){ } } public void createNewGroup_actionPerformed(ActionEvent e) { for(int i=0; i0) seq = (Sequence)(av.getSelection().sequenceAt(0)); else seq = (Sequence)av.getAlignment().getSequenceAt(0); searchResults.add( Integer.toString( av.getAlignment().findIndex(seq) ) ); searchResults.add( Integer.toString( seq.findIndex(res)-1 ) ); searchResults.add( Integer.toString( seq.findIndex(res)-1 ) ); //av.getAlignment().getSequenceAt(seq).findPosition(res) }catch(NumberFormatException ex){} jalview.schemes.UserColourScheme ucs = new jalview.schemes.UserColourScheme(); Color [] newColors = new Color[24]; for(int i=0; i<24; i++) newColors[i] = new Color(60,160,115); ucs.setColourScheme(newColors); searchGroup = new SuperGroup(searchString, ucs , true, true, false); while( !found && seqIndex0 && !av.getSelection().contains(seq)) { // if a selection has been made, only search within that selection seqIndex++; resIndex=0; continue; } item = seq.getSequence(); ///Shall we ignore gaps???? StringBuffer noGaps = new StringBuffer(); int insertCount=0; ArrayList spaces = new ArrayList(); for (int j=0; j < item.length(); j++) { if(!jalview.util.Comparison.isGap(item.charAt(j))) { noGaps.append(item.charAt(j)); spaces.add(new Integer(insertCount)); } else insertCount++; } Pattern pattern = Pattern.compile(searchString); Matcher matcher = pattern.matcher(noGaps); for(int r = resIndex; r0) { allResults = new int[searchResults.size()]; for(int i=0; i