+ public void run()
+ {
+ final long sttime = System.currentTimeMillis();
+ ths.setProgressBar("Searching for sequences from "+fsrc, sttime);
+ try {
+ Alignment ds = ths.getViewport().alignment.getDataset(); // update our local dataset reference
+ Alignment prods = CrossRef.findXrefSequences(fsel, fdna, fsrc, ds);
+ if (prods!=null)
+ {
+ SequenceI[] sprods = new SequenceI[prods.getHeight()];
+ for (int s=0; s<sprods.length;s++)
+ {
+ sprods[s] = (prods.getSequenceAt(s)).deriveSequence();
+ if (ds.getSequences()==null || !ds.getSequences().contains(sprods[s].getDatasetSequence()))
+ ds.addSequence(sprods[s].getDatasetSequence());
+ sprods[s].updatePDBIds();
+ }
+ Alignment al = new Alignment(sprods);
+ AlignedCodonFrame[] cf = prods.getCodonFrames();
+ for (int s=0; cf!=null && s<cf.length; s++)
+ {
+ al.addCodonFrame(cf[s]);
+ cf[s] = null;
+ }
+ al.setDataset(ds);
+ AlignFrame naf = new AlignFrame(al, DEFAULT_WIDTH, DEFAULT_HEIGHT);
+ String newtitle =""+((fdna) ? "Proteins " : "Nucleotides ") + " for "+((fisRegSel) ? "selected region of " : "")
+ + getTitle();
+ Desktop.addInternalFrame(naf, newtitle, DEFAULT_WIDTH,
+ DEFAULT_HEIGHT);
+ } else {
+ System.err.println("No Sequences generated for xRef type "+fsrc);
+ }
+ }
+ catch (Exception e)
+ {
+ jalview.bin.Cache.log.error("Exception when finding crossreferences",e);
+ }
+ catch (Error e)
+ {
+ jalview.bin.Cache.log.error("Error when finding crossreferences",e);
+ }
+ ths.setProgressBar("Finished searching for sequences from "+fsrc, sttime);
+ }
+
+ };
+ Thread frunner = new Thread(foo);
+ frunner.start();
+ }
+
+
+public boolean canShowTranslationProducts(SequenceI[] selection, AlignmentI alignment)
+{
+ // old way
+ try {
+ return (jalview.analysis.Dna.canTranslate(selection, viewport.getViewAsVisibleContigs(true)));
+ } catch (Exception e)
+ {
+ jalview.bin.Cache.log.warn("canTranslate threw an exception - please report to help@jalview.org",e);
+ return false;
+ }
+}
+
+public void showProducts_actionPerformed(ActionEvent e)
+{
+ ///////////////////////////////
+ // Collect Data to be translated/transferred
+
+ SequenceI [] selection = viewport.getSequenceSelection();
+ AlignmentI al = null;
+ try {
+ al = jalview.analysis.Dna.CdnaTranslate(selection, viewport.getViewAsVisibleContigs(true),
+ viewport.getGapCharacter(), viewport.getAlignment().getDataset());
+ } catch (Exception ex) {
+ al = null;
+ jalview.bin.Cache.log.debug("Exception during translation.",ex);
+ }
+ if (al==null)
+ {
+ JOptionPane.showMessageDialog(Desktop.desktop,
+ "Please select at least three bases in at least one sequence in order to perform a cDNA translation.",
+ "Translation Failed",
+ JOptionPane.WARNING_MESSAGE);
+ } else {
+ AlignFrame af = new AlignFrame(al, DEFAULT_WIDTH, DEFAULT_HEIGHT);
+ Desktop.addInternalFrame(af, "Translation of "+this.getTitle(),
+ DEFAULT_WIDTH,
+ DEFAULT_HEIGHT);
+ }
+ }