apply version 2.7 copyright
[jalview.git] / src / jalview / appletgui / ExtJmol.java
index a854c6c..b3d1a3c 100644 (file)
@@ -1,6 +1,6 @@
 /*
- * Jalview - A Sequence Alignment Editor and Viewer (Version 2.6)
- * Copyright (C) 2010 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle
+ * Jalview - A Sequence Alignment Editor and Viewer (Version 2.7)
+ * Copyright (C) 2011 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle
  * 
  * This file is part of Jalview.
  * 
@@ -25,32 +25,36 @@ import java.util.Vector;
 import org.jmol.api.JmolAppConsoleInterface;
 import org.jmol.api.JmolViewer;
 
+import jalview.api.AlignmentViewPanel;
 import jalview.api.FeatureRenderer;
 import jalview.api.SequenceRenderer;
+import jalview.datamodel.AlignmentI;
 import jalview.datamodel.PDBEntry;
 import jalview.datamodel.SequenceI;
 import jalview.ext.jmol.JalviewJmolBinding;
 
 /**
  * bind an alignment view to an external Jmol instance.
+ * 
  * @author JimP
- *
+ * 
  */
 public class ExtJmol extends JalviewJmolBinding
 {
 
   private AlignmentPanel ap;
 
-  protected ExtJmol(jalview.appletgui.AlignFrame alframe, PDBEntry[] pdbentry, SequenceI[][] seq, String[][] chains,
+  protected ExtJmol(jalview.appletgui.AlignFrame alframe,
+          PDBEntry[] pdbentry, SequenceI[][] seq, String[][] chains,
           String protocol)
   {
-    super(pdbentry, seq, chains, protocol);
+    super(alframe.alignPanel.getStructureSelectionManager(), pdbentry, seq, chains, protocol);
   }
 
   public ExtJmol(JmolViewer viewer, AlignmentPanel alignPanel,
           SequenceI[][] seqs)
   {
-    super(viewer);
+    super(alignPanel.getStructureSelectionManager(), viewer);
     ap = alignPanel;
     this.sequence = seqs;
     notifyFileLoaded(null, null, null, null, 0);
@@ -58,7 +62,7 @@ public class ExtJmol extends JalviewJmolBinding
 
   public void updateColours(Object source)
   {
-    
+
     // TODO Auto-generated method stub
 
   }
@@ -68,8 +72,9 @@ public class ExtJmol extends JalviewJmolBinding
     showUrl(arg0, "jmol");
   }
 
-  public FeatureRenderer getFeatureRenderer()
+  public FeatureRenderer getFeatureRenderer(AlignmentViewPanel alignment)
   {
+    AlignmentPanel ap = (AlignmentPanel)alignment;
     if (ap.av.showSequenceFeatures)
     {
       return ap.getFeatureRenderer();
@@ -80,9 +85,9 @@ public class ExtJmol extends JalviewJmolBinding
     }
   }
 
-  public SequenceRenderer getSequenceRenderer()
+  public SequenceRenderer getSequenceRenderer(AlignmentViewPanel alignment)
   {
-    return ap.getSequenceRenderer();
+    return ((AlignmentPanel)alignment).getSequenceRenderer();
   }
 
   public void notifyScriptTermination(String strStatus, int msWalltime)
@@ -120,22 +125,23 @@ public class ExtJmol extends JalviewJmolBinding
     Vector pdbe = new Vector();
     Hashtable fileids = new Hashtable();
     SequenceI[] sq = ap.av.getAlignment().getSequencesArray();
-    for (int s=0;s<sq.length;s++)
+    for (int s = 0; s < sq.length; s++)
     {
       Vector pdbids = sq[s].getPDBId();
-      if (pdbids!=null)
+      if (pdbids != null)
       {
-        for (int pe=0,peSize=pdbids.size(); pe<peSize; pe++)
+        for (int pe = 0, peSize = pdbids.size(); pe < peSize; pe++)
         {
           PDBEntry pentry = (PDBEntry) pdbids.elementAt(pe);
-          if (!fileids.containsKey(pentry.getId())) {
+          if (!fileids.containsKey(pentry.getId()))
+          {
             pdbe.addElement(pentry);
           }
         }
       }
     }
     pdbentry = new PDBEntry[pdbe.size()];
-    for (int pe=0;pe<pdbe.size(); pe++)
+    for (int pe = 0; pe < pdbe.size(); pe++)
     {
       pdbentry[pe] = (PDBEntry) pdbe.elementAt(pe);
     }
@@ -144,8 +150,11 @@ public class ExtJmol extends JalviewJmolBinding
   @Override
   public void showConsole(boolean show)
   {
-    // This never gets called because we haven't overriden the associated Jmol's console
-    System.err.println("WARNING: unexpected call to ExtJmol's showConsole method. (showConsole="+show);
+    // This never gets called because we haven't overriden the associated Jmol's
+    // console
+    System.err
+            .println("WARNING: unexpected call to ExtJmol's showConsole method. (showConsole="
+                    + show);
   }
 
   @Override
@@ -155,16 +164,31 @@ public class ExtJmol extends JalviewJmolBinding
     // TODO Auto-generated method stub
     return null;
   }
+
   @Override
   protected void releaseUIResources()
   {
     ap = null;
-    if (console!=null) {
-      try {
+    if (console != null)
+    {
+      try
+      {
         console.setVisible(false);
-      } catch (Error e) {} catch (Exception x) {};
-      console=null;
+      } catch (Error e)
+      {
+      } catch (Exception x)
+      {
+      }
+      ;
+      console = null;
     }
+
+  }
+
+  @Override
+  public void releaseReferences(Object svl)
+  {
+    // TODO Auto-generated method stub
     
   }