3 import jalview.jbgui.GFinder;
\r
4 import jalview.datamodel.*;
\r
5 import java.awt.event.*;
\r
6 import javax.swing.*;
\r
7 import javax.swing.event.*;
\r
11 public class Finder extends GFinder
\r
15 JInternalFrame frame;
\r
16 String searchString;
\r
17 SuperGroup searchGroup;
\r
21 public Finder(AlignViewport av, AlignmentPanel ap, JInternalFrame f)
\r
27 // all a big pain, but we need to wait until the frame is visible before the textfield can
\r
28 // obtain the focus/////////////////////////
\r
29 frame.addInternalFrameListener(new InternalFrameAdapter()
\r
31 public void internalFrameOpened(InternalFrameEvent evt)
\r
33 SwingUtilities.invokeLater(new Runnable()
\r
36 { textfield.requestFocus(); }
\r
40 public void internalFrameClosing(InternalFrameEvent evt)
\r
42 cancel_actionPerformed(null);
\r
48 public void textfield_actionPerformed(ActionEvent e)
\r
53 public void findNext_actionPerformed(ActionEvent e)
\r
58 public void findAll_actionPerformed(ActionEvent e)
\r
65 public void cancel_actionPerformed(ActionEvent e)
\r
68 // if allResults is null, this effectively switches displaySearch flag in seqCanvas
\r
69 ap.highlightSearchResults( null );
\r
70 // frame.setClosed(true);
\r
71 }catch(Exception ex){ }
\r
75 public void createNewGroup_actionPerformed(ActionEvent e)
\r
77 for(int i=0; i<searchGroup.getSize(); i++)
\r
78 av.alignment.addGroup( searchGroup.getGroupeAt(i));
\r
80 ap.av.alignment.addSuperGroup(searchGroup);
\r
81 ap.highlightSearchResults( null );
\r
85 void doSearch(boolean findAll)
\r
87 createNewGroup.setEnabled(false);
\r
88 searchString = textfield.getText().toUpperCase();
\r
90 ArrayList searchResults = new ArrayList();
\r
91 int [] allResults = null;
\r
95 boolean found = false;
\r
97 /// is the searchString a residue number?
\r
99 int res = Integer.parseInt(searchString);
\r
102 if(av.getSelectionGroup().getSize()>0)
\r
103 seq = (Sequence)(av.getSelectionGroup().getSequenceAt(0));
\r
105 seq = (Sequence)av.getAlignment().getSequenceAt(0);
\r
107 searchResults.add( Integer.toString( av.getAlignment().findIndex(seq) ) );
\r
108 searchResults.add( Integer.toString( seq.findIndex(res)-1 ) );
\r
109 searchResults.add( Integer.toString( seq.findIndex(res)-1 ) );
\r
111 }catch(NumberFormatException ex){}
\r
113 jalview.schemes.UserColourScheme ucs = new jalview.schemes.UserColourScheme();
\r
114 Color [] newColors = new Color[24];
\r
115 for(int i=0; i<24; i++)
\r
116 newColors[i] = new Color(60,160,115);
\r
118 ucs.setColourScheme(newColors);
\r
120 searchGroup = new SuperGroup(searchString, ucs , true, true, false);
\r
122 int end = av.alignment.getHeight();
\r
125 SequenceGroup rubberband = av.getSelectionGroup();
\r
126 if(rubberband!=null)
\r
127 end = rubberband.getEndRes();
\r
131 while( !found && seqIndex<end)
\r
133 seq = (Sequence)av.getAlignment().getSequenceAt(seqIndex);
\r
135 if( av.getSelectionGroup().getSize()>0 && !av.getSelectionGroup().sequences.contains(seq)
\r
136 || (rubberband!=null && !rubberband.sequences.contains(seq)) )
\r
138 // if a selection has been made, only search within that selection
\r
144 item = seq.getSequence();
\r
146 if(rubberband!=null)
\r
147 item = item.substring(0, rubberband.getEndRes()+1);
\r
149 ///Shall we ignore gaps????
\r
150 StringBuffer noGaps = new StringBuffer();
\r
152 ArrayList spaces = new ArrayList();
\r
154 for (int j=0; j < item.length(); j++)
\r
157 if(!jalview.util.Comparison.isGap(item.charAt(j)))
\r
159 noGaps.append(item.charAt(j));
\r
160 spaces.add(new Integer(insertCount));
\r
167 com.stevesoft.pat.Regex regex = new com.stevesoft.pat.Regex(searchString);
\r
169 for(int r = resIndex; r<noGaps.length(); r++)
\r
172 if( regex.searchFrom( noGaps.toString(), r ) )
\r
174 resIndex = regex.matchedFrom();
\r
177 if(rubberband!=null && ( resIndex+ Integer.parseInt(spaces.get(resIndex).toString()) )<rubberband.getStartRes())
\r
180 searchResults.add( Integer.toString( seqIndex) );
\r
181 searchResults.add( Integer.toString( resIndex+ Integer.parseInt(spaces.get(resIndex).toString()) ) );
\r
182 searchResults.add( Integer.toString( regex.matchedTo()-1 + Integer.parseInt(spaces.get(regex.matchedTo()-1).toString()) ) );
\r
184 SequenceGroup sg = new SequenceGroup(searchString, ucs, true, true, false,
\r
185 resIndex+ Integer.parseInt(spaces.get(resIndex).toString()) ,
\r
186 regex.matchedTo()-1 + Integer.parseInt(spaces.get(regex.matchedTo()-1).toString())
\r
188 sg.addSequence((Sequence)av.getAlignment().getSequenceAt(seqIndex));
\r
189 searchGroup.addGroup( sg );
\r
193 // thats enough, break and display the result
\r
209 if(searchResults.size()>0)
\r
211 allResults = new int[searchResults.size()];
\r
212 for(int i=0; i<searchResults.size(); i++)
\r
213 allResults[i] = Integer.parseInt(searchResults.get(i).toString());
\r
215 createNewGroup.setEnabled(true);
\r
219 JOptionPane.showInternalMessageDialog(this, "Finished searching", null, JOptionPane.INFORMATION_MESSAGE);
\r
224 // if allResults is null, this effectively switches displaySearch flag in seqCanvas
\r
225 ap.highlightSearchResults( allResults );
\r
229 String message = (searchResults.size()/3) + " matches found.";
\r
230 JOptionPane.showInternalMessageDialog(this, message, null,
\r
231 JOptionPane.INFORMATION_MESSAGE);
\r