2 * Jalview - A Sequence Alignment Editor and Viewer
\r
3 * Copyright (C) 2005 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle
\r
5 * This program is free software; you can redistribute it and/or
\r
6 * modify it under the terms of the GNU General Public License
\r
7 * as published by the Free Software Foundation; either version 2
\r
8 * of the License, or (at your option) any later version.
\r
10 * This program is distributed in the hope that it will be useful,
\r
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
\r
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
\r
13 * GNU General Public License for more details.
\r
15 * You should have received a copy of the GNU General Public License
\r
16 * along with this program; if not, write to the Free Software
\r
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
\r
20 package jalview.gui;
\r
22 import jalview.jbgui.GFinder;
\r
23 import jalview.datamodel.*;
\r
24 import java.awt.event.*;
\r
25 import javax.swing.*;
\r
26 import javax.swing.event.*;
\r
30 public class Finder extends GFinder
\r
34 JInternalFrame frame;
\r
35 SuperGroup searchGroup;
\r
36 Vector searchResults;
\r
40 public Finder(AlignViewport av, AlignmentPanel ap, JInternalFrame f)
\r
46 // all a big pain, but we need to wait until the frame is visible before the textfield can
\r
47 // obtain the focus/////////////////////////
\r
48 frame.addInternalFrameListener(new InternalFrameAdapter()
\r
50 public void internalFrameOpened(InternalFrameEvent evt)
\r
52 SwingUtilities.invokeLater(new Runnable()
\r
55 { textfield.requestFocus(); }
\r
59 public void internalFrameClosing(InternalFrameEvent evt)
\r
61 cancel_actionPerformed(null);
\r
67 public void textfield_actionPerformed(ActionEvent e)
\r
72 public void findNext_actionPerformed(ActionEvent e)
\r
77 public void findAll_actionPerformed(ActionEvent e)
\r
84 public void cancel_actionPerformed(ActionEvent e)
\r
87 // if allResults is null, this effectively switches displaySearch flag in seqCanvas
\r
88 ap.highlightSearchResults( null );
\r
89 ap.idPanel.highlightSearchResults( null );
\r
90 // frame.setClosed(true);
\r
91 }catch(Exception ex){ }
\r
95 public void createNewGroup_actionPerformed(ActionEvent e)
\r
98 Color [] newColors = new Color[24];
\r
99 for(int i=0; i<24; i++)
\r
100 newColors[i] = new Color(60,160,115);
\r
102 jalview.schemes.UserColourScheme ucs = new jalview.schemes.UserColourScheme(newColors);
\r
103 String searchString = textfield.getText();
\r
105 searchGroup = new SuperGroup(searchString, ucs , true, true, false);
\r
108 for(int i=0; i<searchResults.size(); i+=3)
\r
110 // its possible edits may have occurred since search was performed
\r
111 // account for this here
\r
113 SequenceI seq = av.alignment.getSequenceAt( Integer.parseInt(searchResults.elementAt(i).toString()) );
\r
114 int startRes = seq.findIndex( Integer.parseInt(searchResults.elementAt(i+1).toString()) )-1;
\r
115 int endRes = seq.findIndex( Integer.parseInt(searchResults.elementAt(i+2).toString()) )-1;
\r
117 SequenceGroup sg = new SequenceGroup(searchString, ucs, true, true, false, startRes , endRes );
\r
118 sg.addSequence(seq);
\r
119 av.alignment.addGroup(sg);
\r
120 searchGroup.addGroup( sg );
\r
124 ap.av.alignment.addSuperGroup(searchGroup);
\r
125 ap.highlightSearchResults( null );
\r
129 void doSearch(boolean findAll)
\r
131 createNewGroup.setEnabled(false);
\r
133 String searchString = textfield.getText().toUpperCase();
\r
135 com.stevesoft.pat.Regex regex = new com.stevesoft.pat.Regex(searchString);
\r
137 searchResults = new Vector();
\r
138 int [] allResults = null;
\r
142 boolean found = false;
\r
144 ////// is the searchString a residue number?
\r
146 int res = Integer.parseInt(searchString);
\r
149 if(av.getSelectionGroup().getSize()>0)
\r
150 seq = (Sequence)(av.getSelectionGroup().getSequenceAt(0));
\r
152 seq = (Sequence)av.getAlignment().getSequenceAt(0);
\r
154 searchResults.add( Integer.toString( av.getAlignment().findIndex(seq) ) );
\r
155 searchResults.add( Integer.toString( seq.findIndex(res)-1 ) );
\r
156 searchResults.add( Integer.toString( seq.findIndex(res)-1 ) );
\r
158 }catch(NumberFormatException ex){}
\r
159 ///////////////////////////////////////////////
\r
163 Color [] newColors = new Color[24];
\r
164 for(int i=0; i<24; i++)
\r
165 newColors[i] = new Color(60,160,115);
\r
167 jalview.schemes.UserColourScheme ucs = new jalview.schemes.UserColourScheme(newColors);
\r
169 searchGroup = new SuperGroup(searchString, ucs , true, true, false);
\r
171 int end = av.alignment.getHeight();
\r
173 SequenceGroup selection = av.getSelectionGroup();
\r
174 if(selection!=null)
\r
175 if(selection.getSize()<1 || (selection.getEndRes()-selection.getStartRes()<2))
\r
178 while( !found && seqIndex<end)
\r
180 seq = (Sequence)av.alignment.getSequenceAt(seqIndex);
\r
183 if(selection!=null && !selection.sequences.contains(seq))
\r
190 item = seq.getSequence().toUpperCase();
\r
192 if(selection!=null && selection.getEndRes()<av.alignment.getWidth())
\r
193 item = item.substring(0, selection.getEndRes()+1);
\r
195 ///Shall we ignore gaps????
\r
196 StringBuffer noGaps = new StringBuffer();
\r
198 Vector spaces = new Vector();
\r
200 for (int j=0; j < item.length(); j++)
\r
203 if(!jalview.util.Comparison.isGap(item.charAt(j)))
\r
205 noGaps.append(item.charAt(j));
\r
206 spaces.add(new Integer(insertCount));
\r
214 for(int r = resIndex; r<noGaps.length(); r++)
\r
217 if( regex.searchFrom( noGaps.toString(), r ) )
\r
219 resIndex = regex.matchedFrom();
\r
220 if(selection!=null && ( resIndex+ Integer.parseInt(spaces.get(resIndex).toString()) )<selection.getStartRes())
\r
223 searchResults.add( Integer.toString( seqIndex) );
\r
225 int sres = seq.findPosition( resIndex+ Integer.parseInt(spaces.elementAt(resIndex).toString()) );
\r
226 int eres = seq.findPosition( regex.matchedTo()-1 + Integer.parseInt(spaces.elementAt(regex.matchedTo()-1).toString()) );
\r
228 searchResults.addElement( sres+"" );
\r
229 searchResults.addElement( eres+"" );
\r
233 // thats enough, break and display the result
\r
250 Vector idMatch = new Vector();
\r
251 for(int id = 0; id<av.alignment.getHeight(); id++)
\r
253 if( regex.search( av.alignment.getSequenceAt(id).getName() ) )
\r
254 idMatch.add( av.alignment.getSequenceAt(id) );
\r
257 if(searchResults.size()==0 && idMatch.size()>0)
\r
258 ap.idPanel.highlightSearchResults( idMatch );
\r
261 if(searchResults.size()>0)
\r
263 allResults = new int[searchResults.size()];
\r
264 for(int i=0; i<searchResults.size(); i++)
\r
265 allResults[i] = Integer.parseInt(searchResults.get(i).toString());
\r
267 createNewGroup.setEnabled(true);
\r
271 JOptionPane.showInternalMessageDialog(this, "Finished searching", null, JOptionPane.INFORMATION_MESSAGE);
\r
276 // if allResults is null, this effectively switches displaySearch flag in seqCanvas
\r
277 ap.highlightSearchResults( allResults );
\r
281 String message = (searchResults.size()/3) + " matches found.";
\r
282 JOptionPane.showInternalMessageDialog(this, message, null,
\r
283 JOptionPane.INFORMATION_MESSAGE);
\r