JAL-4020 Added the +2 arg for PyMOLWin.exe allowing older versions of PyMOL
authorBen Soares <bsoares@dundee.ac.uk>
Mon, 6 Jun 2022 18:56:53 +0000 (19:56 +0100)
committerBen Soares <bsoares@dundee.ac.uk>
Mon, 6 Jun 2022 18:56:53 +0000 (19:56 +0100)
src/jalview/ext/pymol/PymolManager.java

index 358e360..1def866 100644 (file)
@@ -32,11 +32,13 @@ import java.net.URL;
 import java.nio.file.Paths;
 import java.util.ArrayList;
 import java.util.List;
+import java.util.Locale;
 
 import jalview.bin.Cache;
 import jalview.bin.Console;
 import jalview.gui.Preferences;
 import jalview.structure.StructureCommandI;
+import jalview.util.Platform;
 
 public class PymolManager
 {
@@ -110,7 +112,7 @@ public class PymolManager
       {
         for (String path : new String[] { "Schrodinger\\PyMOL2", "PyMOL" })
         {
-          for (String binary : new String[] { "PyMOLWinWithConsole.bat" })
+          for (String binary : new String [] {"PyMOLWinWithConsole.bat", "PyMOLWin.exe"})
           {
             pathList.add(String.format("%s\\%s\\%s", root, path, binary));
           }
@@ -269,8 +271,15 @@ public class PymolManager
         }
         List<String> args = new ArrayList<>();
         args.add(pymolPath);
+        
+        // Windows PyMOLWin.exe needs an extra argument
+        if (Platform.isWin() && pymolPath.toLowerCase(Locale.ROOT).endsWith("\\pymolwin.exe"))
+        {
+          args.add("+2");
+        }
         args.add("-R"); // https://pymolwiki.org/index.php/RPC
         ProcessBuilder pb = new ProcessBuilder(args);
+        Console.debug("Running PyMOL as "+String.join(" ", pb.command()));
         pymolProcess = pb.start();
         error = "";
         break;