From: jprocter Date: Fri, 5 Aug 2011 15:49:55 +0000 (+0100) Subject: fetch groovy script from URL (JAL-899) and show progress bar when handling CLI comman... X-Git-Tag: Release_2_7~113 X-Git-Url: http://source.jalview.org/gitweb/?a=commitdiff_plain;h=42833ea8bc056c9d0257cf3a835b01f271f9254e;p=jalview.git fetch groovy script from URL (JAL-899) and show progress bar when handling CLI commands (JAL-898) --- diff --git a/src/jalview/bin/Jalview.java b/src/jalview/bin/Jalview.java index b83bdc0..5357e81 100755 --- a/src/jalview/bin/Jalview.java +++ b/src/jalview/bin/Jalview.java @@ -24,6 +24,8 @@ import java.io.IOException; import java.io.OutputStreamWriter; import java.io.PrintWriter; import java.lang.reflect.Constructor; +import java.net.MalformedURLException; +import java.net.URI; import java.net.URL; import java.net.URLDecoder; import java.security.AllPermission; @@ -332,6 +334,10 @@ public class Jalview } } } + if (!headless) + { + desktop.setProgressBar("Processing commandline arguments...", Jalview.class.hashCode()); + } protocol = jalview.io.AppletFormatAdapter.checkProtocol(file); @@ -556,6 +562,7 @@ public class Jalview // and finally, turn off batch mode indicator - if the desktop still exists if (desktop != null) { + desktop.setProgressBar(null, Jalview.class.hashCode()); desktop.setInBatchMode(false); } } @@ -608,15 +615,22 @@ public class Jalview System.err .println("Sorry. Groovy support is currently only available when running with the Jalview GUI enabled."); } - File sfile = null; + /** + * for scripts contained in files + */ + File tfile = null; + /** + * script's URI + */ + URL sfile = null; if (groovyscript.trim().equals("STDIN")) { // read from stdin into a tempfile and execute it try { - sfile = File.createTempFile("jalview", "groovy"); + tfile = File.createTempFile("jalview", "groovy"); PrintWriter outfile = new PrintWriter(new OutputStreamWriter( - new FileOutputStream(sfile))); + new FileOutputStream(tfile))); BufferedReader br = new BufferedReader( new java.io.InputStreamReader(System.in)); String line = null; @@ -631,30 +645,51 @@ public class Jalview } catch (Exception ex) { System.err.println("Failed to read from STDIN into tempfile " - + ((sfile == null) ? "(tempfile wasn't created)" : sfile + + ((tfile == null) ? "(tempfile wasn't created)" : tfile .toString())); ex.printStackTrace(); return; } + try { + sfile = tfile.toURI().toURL(); + } catch (Exception x) + { + System.err.println("Unexpected Malformed URL Exception for temporary file created from STDIN: "+tfile.toURI()); + x.printStackTrace(); + return; + } } else { - sfile = new File(groovyscript); - } - if (!sfile.exists()) - { - System.err.println("File '" + groovyscript + "' does not exist."); - return; - } - if (!sfile.canRead()) - { - System.err.println("File '" + groovyscript + "' cannot be read."); - return; - } - if (sfile.length() < 1) - { - System.err.println("File '" + groovyscript + "' is empty."); - return; + try + { + sfile = new URI(groovyscript).toURL(); + } catch (Exception x) + { + tfile = new File(groovyscript); + if (!tfile.exists()) + { + System.err.println("File '" + groovyscript + "' does not exist."); + return; + } + if (!tfile.canRead()) + { + System.err.println("File '" + groovyscript + "' cannot be read."); + return; + } + if (tfile.length() < 1) + { + System.err.println("File '" + groovyscript + "' is empty."); + return; + } + try { + sfile = tfile.getAbsoluteFile().toURI().toURL(); + } catch (Exception ex) + { + System.err.println("Failed to create a file URL for "+tfile.getAbsoluteFile()); + return; + } + } } boolean success = false; try @@ -672,44 +707,59 @@ public class Jalview */ Class[] bspec; Object[] binding; - int blen=((jalviewContext[0]==null) ? 0 : 1) + ((jalviewContext[1]==null) ? 0 : 1); - String cnames[] = new String[] { "Jalview", "currentAlFrame"}; - bspec=new Class[blen*2]; - binding=new Object[blen*2]; - blen=0; - ClassLoader cl=null; - for (int jc=0;jc