X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FSequenceFetcher.java;h=34f0e798783cbca017a71b2405808cdc60761a41;hb=d423f22792e47dbc800ae220a58677f988971d06;hp=16753047b8745d83c58b81b399e9aee4671d1a1a;hpb=30cd830fcc83edf6fdad4887e9e209d0e20e9246;p=jalview.git diff --git a/src/jalview/gui/SequenceFetcher.java b/src/jalview/gui/SequenceFetcher.java index 1675304..34f0e79 100755 --- a/src/jalview/gui/SequenceFetcher.java +++ b/src/jalview/gui/SequenceFetcher.java @@ -1,20 +1,19 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer - * Copyright (C) 2007 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 + * Jalview - A Sequence Alignment Editor and Viewer (Version 2.5) + * Copyright (C) 2010 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle + * + * This file is part of Jalview. + * + * Jalview 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 3 of the License, or (at your option) any later version. + * + * Jalview 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 Jalview. If not, see . */ package jalview.gui; @@ -23,6 +22,7 @@ import java.util.*; import java.awt.*; import java.awt.event.*; + import javax.swing.*; import MCview.*; @@ -33,38 +33,127 @@ import jalview.io.*; import jalview.ws.DBRefFetcher; import jalview.ws.ebi.EBIFetchClient; import jalview.ws.seqfetcher.ASequenceFetcher; +import jalview.ws.seqfetcher.DbSourceProxy; import java.awt.Rectangle; import java.awt.BorderLayout; import java.awt.Dimension; -public class SequenceFetcher -extends JPanel implements Runnable +public class SequenceFetcher extends JPanel implements Runnable { - ASequenceFetcher sfetch; + // ASequenceFetcher sfetch; JInternalFrame frame; + + IProgressIndicator guiWindow; + AlignFrame alignFrame; + StringBuffer result; + final String noDbSelected = "-- Select Database --"; + Hashtable sources = new Hashtable(); - public SequenceFetcher(AlignFrame af) + + private static jalview.ws.SequenceFetcher sfetch = null; + + private static String dasRegistry = null; + + /** + * Blocking method that initialises and returns the shared instance of the + * SequenceFetcher client + * + * @param guiWindow + * - where the initialisation delay message should be shown + * @return the singleton instance of the sequence fetcher client + */ + public static jalview.ws.SequenceFetcher getSequenceFetcherSingleton( + final IProgressIndicator guiWindow) + { + if (sfetch == null + || dasRegistry != DasSourceBrowser.getDasRegistryURL()) + { + /** + * give a visual indication that sequence fetcher construction is occuring + */ + if (guiWindow != null) + { + guiWindow.setProgressBar("Initialising Sequence Database Fetchers", + Thread.currentThread().hashCode()); + } + dasRegistry = DasSourceBrowser.getDasRegistryURL(); + jalview.ws.SequenceFetcher sf = new jalview.ws.SequenceFetcher(); + if (guiWindow != null) + { + guiWindow.setProgressBar("Initialising Sequence Database Fetchers", + Thread.currentThread().hashCode()); + } + sfetch = sf; + + } + return sfetch; + } + + public SequenceFetcher(IProgressIndicator guiIndic) + { + final IProgressIndicator guiWindow = guiIndic; + final SequenceFetcher us = this; + // launch initialiser thread + Thread sf = new Thread(new Runnable() + { + + public void run() + { + if (getSequenceFetcherSingleton(guiWindow) != null) + { + us.initGui(guiWindow); + } + else + { + javax.swing.SwingUtilities.invokeLater(new Runnable() + { + public void run() + { + JOptionPane + .showInternalMessageDialog( + Desktop.desktop, + "Could not create the sequence fetcher client. Check error logs for details.", + "Couldn't create SequenceFetcher", + JOptionPane.ERROR_MESSAGE); + } + }); + + // raise warning dialog + } + } + }); + sf.start(); + } + + /** + * called by thread spawned by constructor + * + * @param guiWindow + */ + private void initGui(IProgressIndicator guiWindow) { - alignFrame = af; - sfetch = new jalview.ws.SequenceFetcher(); + this.guiWindow = guiWindow; + if (guiWindow instanceof AlignFrame) + { + alignFrame = (AlignFrame) guiWindow; + } + database.addItem(noDbSelected); /* - * Dynamically generated database list - * will need a translation function from - * internal source to externally distinct names. - * UNIPROT and UP_NAME are identical DB sources, - * and should be collapsed. + * Dynamically generated database list will need a translation function from + * internal source to externally distinct names. UNIPROT and UP_NAME are + * identical DB sources, and should be collapsed. */ - - String dbs[] = sfetch.getSupportedDb(); - for (int i=0; i0) { - if (parseResult(new Alignment(seqs), null, null)!=null) - { - result.append("# Successfully parsed the "+database.getSelectedItem()+" Queries into an Alignment"); - } - } - } - else if (database.getSelectedItem().equals("PDB")) + AlignmentI aresult = null; + Object source = database.getSelectedItem(); + Enumeration en = new StringTokenizer(textArea.getText(), ";"); + try { - StringTokenizer qset = new StringTokenizer(textArea.getText(), ";"); - String query; - SequenceI[] seqs = null; - while (qset.hasMoreTokens() && ((query = qset.nextToken())!=null)) + guiWindow.setProgressBar("Fetching Sequences from " + + database.getSelectedItem(), Thread.currentThread() + .hashCode()); + DbSourceProxy proxy = sfetch.getSourceProxy((String) sources + .get(source)); + if (proxy.getAccessionSeparator() == null) { - SequenceI[] seqparts = getPDBFile(query.toUpperCase()); - if (seqparts != null) + while (en.hasMoreElements()) { - if (seqs == null) - { - seqs = seqparts; - } - else + String item = (String) en.nextElement(); + try { - SequenceI[] newseqs = new SequenceI[seqs.length+seqparts.length]; - int i=0; - for (; i < seqs.length; i++) + if (aresult != null) { - newseqs[i] = seqs[i]; - seqs[i] = null; + try + { + // give the server a chance to breathe + Thread.sleep(5); + } catch (Exception e) + { + // + } + } - for (int j=0;j 0) - { - if (parseResult(new Alignment(seqs), null, null)!=null) - { - result.append( - "# Successfully parsed the PDB File Queries into an Alignment"); - } - } - } - else if( database.getSelectedItem().equals("PFAM")) - { - try - { - result.append(new FastaFile( - "http://www.sanger.ac.uk/cgi-bin/Pfam/getalignment.pl?format=fal&acc=" - + textArea.getText().toUpperCase(), "URL").print() - ); - - if(result.length()>0) - { - parseResult( result.toString(), textArea.getText().toUpperCase() ); - } - - } - catch (java.io.IOException ex) - { - result = null; - } - } - - if (result == null || result.length() == 0) - { - showErrorMessage("Error retrieving " + textArea.getText() - + " from " + database.getSelectedItem()); - } - - resetDialog(); - return; - } - - void getUniprotFile(String id) - { - EBIFetchClient ebi = new EBIFetchClient(); - File file = ebi.fetchDataAsFile("uniprot:" + id, "xml", null); - - DBRefFetcher dbref = new DBRefFetcher(); - Vector entries = dbref.getUniprotEntries(file); - - if (entries != null) - { - //First, make the new sequences - Enumeration en = entries.elements(); - while (en.hasMoreElements()) - { - UniprotEntry entry = (UniprotEntry) en.nextElement(); - - StringBuffer name = new StringBuffer(">UniProt/Swiss-Prot"); - Enumeration en2 = entry.getAccession().elements(); - while (en2.hasMoreElements()) - { - name.append("|"); - name.append(en2.nextElement()); } - en2 = entry.getName().elements(); - while (en2.hasMoreElements()) - { - name.append("|"); - name.append(en2.nextElement()); - } - - if (entry.getProtein() != null) - { - name.append(" " + entry.getProtein().getName().elementAt(0)); - } - - result.append(name + "\n" + entry.getUniprotSequence().getContent() + - "\n"); - } - - //Then read in the features and apply them to the dataset - Alignment al = parseResult(result.toString(), null); - for (int i = 0; i < entries.size(); i++) + else { - UniprotEntry entry = (UniprotEntry) entries.elementAt(i); - Enumeration e = entry.getDbReference().elements(); - Vector onlyPdbEntries = new Vector(); - while (e.hasMoreElements()) + StringBuffer multiacc = new StringBuffer(); + while (en.hasMoreElements()) { - PDBEntry pdb = (PDBEntry) e.nextElement(); - if (!pdb.getType().equals("PDB")) + multiacc.append(en.nextElement()); + if (en.hasMoreElements()) { - continue; - } - - onlyPdbEntries.addElement(pdb); - } - - Enumeration en2 = entry.getAccession().elements(); - while (en2.hasMoreElements()) - { - al.getSequenceAt(i).getDatasetSequence().addDBRef(new DBRefEntry( - DBRefSource.UNIPROT, - "0", - en2.nextElement().toString())); - } - - - - - al.getSequenceAt(i).getDatasetSequence().setPDBId(onlyPdbEntries); - if (entry.getFeature() != null) - { - e = entry.getFeature().elements(); - while (e.hasMoreElements()) - { - SequenceFeature sf = (SequenceFeature) e.nextElement(); - sf.setFeatureGroup("Uniprot"); - al.getSequenceAt(i).getDatasetSequence().addSequenceFeature( sf ); + multiacc.append(proxy.getAccessionSeparator()); } } + aresult = proxy.getSequenceRecords(multiacc.toString()); } - } - } - SequenceI[] getPDBFile(String id) - { - Vector result = new Vector(); - String chain = null; - if (id.indexOf(":") > -1) + } catch (Exception e) { - chain = id.substring(id.indexOf(":") + 1); - id = id.substring(0, id.indexOf(":")); - } - - EBIFetchClient ebi = new EBIFetchClient(); - String file = ebi.fetchDataAsFile("pdb:" + id, "pdb", "raw"). - getAbsolutePath(); - if (file == null) + showErrorMessage("Error retrieving " + textArea.getText() + " from " + + database.getSelectedItem()); + // error +="Couldn't retrieve sequences from "+database.getSelectedItem(); + System.err.println("Retrieval failed for source ='" + + database.getSelectedItem() + "' and query\n'" + + textArea.getText() + "'\n"); + e.printStackTrace(); + } catch (OutOfMemoryError e) { - return null; - } - try + // resets dialog box - so we don't use OOMwarning here. + showErrorMessage("Out of Memory when retrieving " + + textArea.getText() + + " from " + + database.getSelectedItem() + + "\nPlease see the Jalview FAQ for instructions for increasing the memory available to Jalview.\n"); + e.printStackTrace(); + } catch (Error e) { - PDBfile pdbfile = new PDBfile(file, jalview.io.AppletFormatAdapter.FILE); - for (int i = 0; i < pdbfile.chains.size(); i++) - { - if (chain == null || - ( (PDBChain) pdbfile.chains.elementAt(i)).id. - toUpperCase().equals(chain)) - { - PDBChain pdbchain = (PDBChain) pdbfile.chains.elementAt(i); - // Get the Chain's Sequence - who's dataset includes any special features added from the PDB file - SequenceI sq = pdbchain.sequence; - // Specially formatted name for the PDB chain sequences retrieved from the PDB - sq.setName("PDB|"+id+"|"+sq.getName()); - // Might need to add more metadata to the PDBEntry object - // like below - /* - * PDBEntry entry = new PDBEntry(); - // Construct the PDBEntry - entry.setId(id); - if (entry.getProperty() == null) - entry.setProperty(new Hashtable()); - entry.getProperty().put("chains", - pdbchain.id - + "=" + sq.getStart() - + "-" + sq.getEnd()); - sq.getDatasetSequence().addPDBId(entry); - * - // Add PDB DB Refs - // We make a DBRefEtntry because we have obtained the PDB file from a verifiable source - // JBPNote - PDB DBRefEntry should also carry the chain and mapping information - DBRefEntry dbentry = new DBRefEntry(jalview.datamodel.DBRefSource.PDB, - "0", id + pdbchain.id); - sq.addDBRef(dbentry); - // and add seuqence to the retrieved set - result.addElement(sq.deriveSequence()); - } - } - - if (result.size() < 1) - { - throw new Exception("WsDBFetch for PDB id resulted in zero result size"); - } + showErrorMessage("Serious Error retrieving " + textArea.getText() + + " from " + database.getSelectedItem()); + e.printStackTrace(); } - catch (Exception ex) // Problem parsing PDB file + if (aresult != null) { - jalview.bin.Cache.log.warn("Exception when retrieving " + - textArea.getText() + " from " + - database.getSelectedItem(), ex); - return null; + parseResult(aresult, null, null); } + // only remove visual delay after we finished parsing. + guiWindow.setProgressBar(null, Thread.currentThread().hashCode()); + resetDialog(); + } - - SequenceI[] results = new SequenceI[result.size()]; - for (int i = 0, j = result.size(); i < j; i++) - { - results[i] = (SequenceI) result.elementAt(i); - result.setElementAt(null,i); - } - return results; - }*/ + /* + * result = new StringBuffer(); if + * (database.getSelectedItem().equals("Uniprot")) { + * getUniprotFile(textArea.getText()); } else if + * (database.getSelectedItem().equals("EMBL") || + * database.getSelectedItem().equals("EMBLCDS")) { String DBRefSource = + * database.getSelectedItem().equals("EMBLCDS") ? + * jalview.datamodel.DBRefSource.EMBLCDS : jalview.datamodel.DBRefSource.EMBL; + * + * StringTokenizer st = new StringTokenizer(textArea.getText(), ";"); + * SequenceI[] seqs = null; while(st.hasMoreTokens()) { EBIFetchClient dbFetch + * = new EBIFetchClient(); String qry = + * database.getSelectedItem().toString().toLowerCase( ) + ":" + + * st.nextToken(); File reply = dbFetch.fetchDataAsFile( qry, "emblxml",null); + * + * jalview.datamodel.xdb.embl.EmblFile efile=null; if (reply != null && + * reply.exists()) { efile = + * jalview.datamodel.xdb.embl.EmblFile.getEmblFile(reply); } if (efile!=null) + * { for (Iterator i=efile.getEntries().iterator(); i.hasNext(); ) { EmblEntry + * entry = (EmblEntry) i.next(); SequenceI[] seqparts = + * entry.getSequences(false,true, DBRefSource); if (seqparts!=null) { + * SequenceI[] newseqs = null; int si=0; if (seqs==null) { newseqs = new + * SequenceI[seqparts.length]; } else { newseqs = new + * SequenceI[seqs.length+seqparts.length]; + * + * for (;si0) { if (parseResult(new Alignment(seqs), null, + * null)!=null) { result.append("# Successfully parsed the + * "+database.getSelectedItem()+" Queries into an Alignment"); } } } else if + * (database.getSelectedItem().equals("PDB")) { StringTokenizer qset = new + * StringTokenizer(textArea.getText(), ";"); String query; SequenceI[] seqs = + * null; while (qset.hasMoreTokens() && ((query = qset.nextToken())!=null)) { + * SequenceI[] seqparts = getPDBFile(query.toUpperCase()); if (seqparts != + * null) { if (seqs == null) { seqs = seqparts; } else { SequenceI[] newseqs = + * new SequenceI[seqs.length+seqparts.length]; int i=0; for (; i < + * seqs.length; i++) { newseqs[i] = seqs[i]; seqs[i] = null; } for (int + * j=0;j 0) { if (parseResult(new + * Alignment(seqs), null, null)!=null) { result.append( "# Successfully parsed + * the PDB File Queries into an + * Alignment"); } } } else if( database.getSelectedItem().equals("PFAM")) { + * try { result.append(new FastaFile( + * "http://www.sanger.ac.uk/cgi-bin/Pfam/getalignment.pl?format=fal&acc=" + + * textArea.getText().toUpperCase(), "URL").print() ); + * + * if(result.length()>0) { parseResult( result.toString(), + * textArea.getText().toUpperCase() ); } } catch (java.io.IOException ex) { + * result = null; } } + * + * if (result == null || result.length() == 0) { showErrorMessage("Error + * retrieving " + textArea.getText() + " from " + database.getSelectedItem()); + * } + * + * resetDialog(); return; } + * + * void getUniprotFile(String id) { EBIFetchClient ebi = new EBIFetchClient(); + * File file = ebi.fetchDataAsFile("uniprot:" + id, "xml", null); + * + * DBRefFetcher dbref = new DBRefFetcher(); Vector entries = + * dbref.getUniprotEntries(file); + * + * if (entries != null) { //First, make the new sequences Enumeration en = + * entries.elements(); while (en.hasMoreElements()) { UniprotEntry entry = + * (UniprotEntry) en.nextElement(); + * + * StringBuffer name = new StringBuffer(">UniProt/Swiss-Prot"); Enumeration + * en2 = entry.getAccession().elements(); while (en2.hasMoreElements()) { + * name.append("|"); name.append(en2.nextElement()); } en2 = + * entry.getName().elements(); while (en2.hasMoreElements()) { + * name.append("|"); name.append(en2.nextElement()); } + * + * if (entry.getProtein() != null) { name.append(" " + + * entry.getProtein().getName().elementAt(0)); } + * + * result.append(name + "\n" + entry.getUniprotSequence().getContent() + + * "\n"); } + * + * //Then read in the features and apply them to the dataset Alignment al = + * parseResult(result.toString(), null); for (int i = 0; i < entries.size(); + * i++) { UniprotEntry entry = (UniprotEntry) entries.elementAt(i); + * Enumeration e = entry.getDbReference().elements(); Vector onlyPdbEntries = + * new Vector(); while (e.hasMoreElements()) { PDBEntry pdb = (PDBEntry) + * e.nextElement(); if (!pdb.getType().equals("PDB")) { continue; } + * + * onlyPdbEntries.addElement(pdb); } + * + * Enumeration en2 = entry.getAccession().elements(); while + * (en2.hasMoreElements()) { + * al.getSequenceAt(i).getDatasetSequence().addDBRef(new DBRefEntry( + * DBRefSource.UNIPROT, "0", en2.nextElement().toString())); } + * + * + * + * + * al.getSequenceAt(i).getDatasetSequence().setPDBId(onlyPdbEntries); if + * (entry.getFeature() != null) { e = entry.getFeature().elements(); while + * (e.hasMoreElements()) { SequenceFeature sf = (SequenceFeature) + * e.nextElement(); sf.setFeatureGroup("Uniprot"); + * al.getSequenceAt(i).getDatasetSequence().addSequenceFeature( sf ); } } } } + * } + * + * SequenceI[] getPDBFile(String id) { Vector result = new Vector(); String + * chain = null; if (id.indexOf(":") > -1) { chain = + * id.substring(id.indexOf(":") + 1); id = id.substring(0, id.indexOf(":")); } + * + * EBIFetchClient ebi = new EBIFetchClient(); String file = + * ebi.fetchDataAsFile("pdb:" + id, "pdb", "raw"). getAbsolutePath(); if (file + * == null) { return null; } try { PDBfile pdbfile = new PDBfile(file, + * jalview.io.AppletFormatAdapter.FILE); for (int i = 0; i < + * pdbfile.chains.size(); i++) { if (chain == null || ( (PDBChain) + * pdbfile.chains.elementAt(i)).id. toUpperCase().equals(chain)) { PDBChain + * pdbchain = (PDBChain) pdbfile.chains.elementAt(i); // Get the Chain's + * Sequence - who's dataset includes any special features added from the PDB + * file SequenceI sq = pdbchain.sequence; // Specially formatted name for the + * PDB chain sequences retrieved from the PDB + * sq.setName("PDB|"+id+"|"+sq.getName()); // Might need to add more metadata + * to the PDBEntry object // like below /* PDBEntry entry = new PDBEntry(); // + * Construct the PDBEntry entry.setId(id); if (entry.getProperty() == null) + * entry.setProperty(new Hashtable()); entry.getProperty().put("chains", + * pdbchain.id + "=" + sq.getStart() + "-" + sq.getEnd()); + * sq.getDatasetSequence().addPDBId(entry); // Add PDB DB Refs // We make a + * DBRefEtntry because we have obtained the PDB file from a verifiable source + * // JBPNote - PDB DBRefEntry should also carry the chain and mapping + * information DBRefEntry dbentry = new + * DBRefEntry(jalview.datamodel.DBRefSource.PDB, "0", id + pdbchain.id); + * sq.addDBRef(dbentry); // and add seuqence to the retrieved set + * result.addElement(sq.deriveSequence()); } } + * + * if (result.size() < 1) { throw new Exception("WsDBFetch for PDB id resulted + * in zero result size"); } } catch (Exception ex) // Problem parsing PDB file + * { jalview.bin.Cache.log.warn("Exception when retrieving " + + * textArea.getText() + " from " + database.getSelectedItem(), ex); return + * null; } + * + * + * SequenceI[] results = new SequenceI[result.size()]; for (int i = 0, j = + * result.size(); i < j; i++) { results[i] = (SequenceI) result.elementAt(i); + * result.setElementAt(null,i); } return results; } + */ AlignmentI parseResult(String result, String title) { String format = new IdentifyFile().Identify(result, "Paste"); @@ -538,72 +634,92 @@ extends JPanel implements Runnable sequences = null; try { - sequences = new FormatAdapter().readFile(result.toString(), "Paste", - format); + sequences = new FormatAdapter().readFile(result.toString(), + "Paste", format); + } catch (Exception ex) + { } - catch (Exception ex) - {} - if (sequences!=null) + if (sequences != null) { return parseResult(sequences, title, format); } } else { - showErrorMessage("Error retrieving " + textArea.getText() - + " from " + database.getSelectedItem()); + showErrorMessage("Error retrieving " + textArea.getText() + " from " + + database.getSelectedItem()); } return null; } - AlignmentI parseResult(AlignmentI al, String title, String currentFileFormat) + AlignmentI parseResult(AlignmentI al, String title, + String currentFileFormat) { if (al != null && al.getHeight() > 0) { if (alignFrame == null) { - AlignFrame af = new AlignFrame(al, - AlignFrame.DEFAULT_WIDTH, - AlignFrame.DEFAULT_HEIGHT); - if (currentFileFormat!=null) + AlignFrame af = new AlignFrame(al, AlignFrame.DEFAULT_WIDTH, + AlignFrame.DEFAULT_HEIGHT); + if (currentFileFormat != null) { - af.currentFileFormat = currentFileFormat; // WHAT IS THE DEFAULT FORMAT FOR NON-FormatAdapter Sourced Alignments? + af.currentFileFormat = currentFileFormat; // WHAT IS THE DEFAULT + // FORMAT FOR + // NON-FormatAdapter Sourced + // Alignments? } - if(title==null) + if (title == null) { title = "Retrieved from " + database.getSelectedItem(); } + SequenceFeature[] sfs = null; + for (Enumeration sq = al.getSequences().elements(); sq + .hasMoreElements();) + { + if ((sfs = ((SequenceI) sq.nextElement()).getDatasetSequence() + .getSequenceFeatures()) != null) + { + if (sfs.length > 0) + { + af.setShowSeqFeatures(true); + break; + } + } - Desktop.addInternalFrame(af, - title, - AlignFrame.DEFAULT_WIDTH, - AlignFrame.DEFAULT_HEIGHT); + } + Desktop.addInternalFrame(af, title, AlignFrame.DEFAULT_WIDTH, + AlignFrame.DEFAULT_HEIGHT); af.statusBar.setText("Successfully pasted alignment file"); try { - af.setMaximum(jalview.bin.Cache.getDefault("SHOW_FULLSCREEN", false)); + af.setMaximum(jalview.bin.Cache.getDefault("SHOW_FULLSCREEN", + false)); + } catch (Exception ex) + { } - catch (Exception ex) - {} } else { for (int i = 0; i < al.getHeight(); i++) { - alignFrame.viewport.alignment.addSequence(al.getSequenceAt(i)); // this also creates dataset sequence entries + alignFrame.viewport.alignment.addSequence(al.getSequenceAt(i)); // this + // also + // creates + // dataset + // sequence + // entries } - alignFrame.viewport.setEndSeq(alignFrame.viewport.alignment. - getHeight()); + alignFrame.viewport.setEndSeq(alignFrame.viewport.alignment + .getHeight()); alignFrame.viewport.alignment.getWidth(); alignFrame.viewport.firePropertyChange("alignment", null, - alignFrame.viewport. - getAlignment().getSequences()); + alignFrame.viewport.getAlignment().getSequences()); } } return al; @@ -616,11 +732,9 @@ extends JPanel implements Runnable { public void run() { - JOptionPane.showInternalMessageDialog(Desktop.desktop, - error, "Error Retrieving Data", - JOptionPane.WARNING_MESSAGE); + JOptionPane.showInternalMessageDialog(Desktop.desktop, error, + "Error Retrieving Data", JOptionPane.WARNING_MESSAGE); } }); } } -