X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fbin%2FJalview.java;h=50e3559272b0c3054c979567f18a092288608304;hb=7d52ef194d39e75fed7730041da25c48e456cf8c;hp=1116fe404ec5733ba508dbdae70a5513b3b29d4f;hpb=a282e50f4076e9ec6da6a0500df2c80652a2353d;p=jalview.git
diff --git a/src/jalview/bin/Jalview.java b/src/jalview/bin/Jalview.java
index 1116fe4..28d029c 100755
--- a/src/jalview/bin/Jalview.java
+++ b/src/jalview/bin/Jalview.java
@@ -1,345 +1,2054 @@
-/*
- * Jalview - A Sequence Alignment Editor and Viewer
- * Copyright (C) 2006 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
- */
-package jalview.bin;
-
-import jalview.gui.*;
-
-import javax.swing.*;
-
-import java.util.Vector;
-
-
-/**
- * Main class for Jalview Application
- *
- *
start with java -Djava.ext.dirs=$PATH_TO_LIB$ jalview.bin.Jalview
- *
- * @author $author$
- * @version $Revision$
- */
-public class Jalview
-{
-
- /**
- * main class for Jalview application
- *
- * @param args open filename
- */
- public static void main(String[] args)
- {
- System.out.println("Java version: "+System.getProperty("java.version"));
- System.out.println(System.getProperty("os.arch")+" "
- +System.getProperty("os.name")+" "
- +System.getProperty("os.version"));
-
-
- ArgsParser aparser = new ArgsParser(args);
- boolean headless = false;
-
- if( aparser.contains("help") || aparser.contains("h") )
- {
- System.out.println("Usage: jalview -open [FILE] [OUTPUT_FORMAT] [OUTPUT_FILE]\n\n"
- +"-nodisplay\tRun Jalview without User Interface.\n"
- +"-props FILE\tUse the given Jalview properties file instead of users default.\n"
- +"-annotations FILE\tAdd precalculated annotations to the alignment.\n"
- +"-features FILE\tUse the given file to mark features on the alignment.\n"
- +"-fasta FILE\tCreate alignment file FILE in Fasta format.\n"
- +"-clustal FILE\tCreate alignment file FILE in Clustal format.\n"
- +"-pfam FILE\tCreate alignment file FILE in PFAM format.\n"
- +"-msf FILE\tCreate alignment file FILE in MSF format.\n"
- +"-pileup FILE\tCreate alignment file FILE in Pileup format\n"
- +"-pir FILE\tCreate alignment file FILE in PIR format.\n"
- +"-blc FILE\tCreate alignment file FILE in BLC format.\n"
- +"-jalview FILE\tCreate alignment file FILE in Jalview format.\n"
- +"-png FILE\tCreate PNG image FILE from alignment.\n"
- +"-imgMap FILE\tCreate HTML file FILE with image map of PNG image.\n"
- +"-eps FILE\tCreate EPS file FILE from alignment."
- +"\n\n~Read documentation in Application or visit http://www.jalview.org for description of Features and Annotations file~\n\n");
- System.exit(0);
- }
-
- Cache.loadProperties(aparser.getValue("props")); // must do this before anything else!
-
- if (aparser.contains("nodisplay"))
- {
- System.setProperty("java.awt.headless", "true");
- }
- if (System.getProperty("java.awt.headless") != null
- && System.getProperty("java.awt.headless").equals("true"))
- {
- headless = true;
- }
-
- try
- {
- Cache.initLogger();
- }
- catch (java.lang.NoClassDefFoundError error)
- {
- error.printStackTrace();
- System.out.println(
- "\nEssential logging libraries not found."
- +"\nUse: java -Djava.ext.dirs=$PATH_TO_LIB$ jalview.bin.Jalview");
- System.exit(0);
- }
-
- Desktop desktop = null;
- if( !headless )
- {
- try
- {
- UIManager.setLookAndFeel(
- UIManager.getSystemLookAndFeelClassName()
- // UIManager.getCrossPlatformLookAndFeelClassName()
-//"com.sun.java.swing.plaf.gtk.GTKLookAndFeel"
-//"javax.swing.plaf.metal.MetalLookAndFeel"
-//"com.sun.java.swing.plaf.windows.WindowsLookAndFeel"
-//"com.sun.java.swing.plaf.motif.MotifLookAndFeel"
-
- );
- }
- catch (Exception ex)
- {
- }
-
- desktop = new Desktop();
- desktop.setVisible(true);
- desktop.discoverer.start();
- }
-
-
- String file = null, protocol = null, format = null, data=null;
- jalview.io.FileLoader fileLoader = new jalview.io.FileLoader();
-
- file = aparser.getValue("open");
-
- if (file == null && desktop==null)
- {
- System.out.println("No files to open!");
- System.exit(1);
- }
-
- if(file!=null)
- {
- System.out.println("Opening file: " + file);
-
- if (!file.startsWith("http://"))
- {
- if (! (new java.io.File(file)).exists())
- {
- System.out.println("Can't find " + file);
- if(headless)
- System.exit(1);
- }
- }
-
- protocol = "File";
-
- if (file.indexOf("http:") > -1 || file.indexOf("file:") >-1)
- {
- protocol = "URL";
- }
-
-
-
- if (file.endsWith(".jar"))
- format = "Jalview";
- else
- format = new jalview.io.IdentifyFile().Identify(file, protocol);
-
-
-
- AlignFrame af = fileLoader.LoadFileWaitTillLoaded(file, protocol, format);
-
- if(af==null)
- {
- System.out.println("error");
- return;
- }
-
- data = aparser.getValue("colour");
- if(data!=null)
- {
- data.replaceAll("%20", " ");
-
- jalview.schemes.ColourSchemeI cs =
- jalview.schemes.ColourSchemeProperty.getColour(af.getViewport().
- getAlignment(), data);
-
- if(cs == null)
- {
- jalview.schemes.UserColourScheme ucs
- = new jalview.schemes.UserColourScheme("white");
- ucs.parseAppletParameter(data);
- cs = ucs;
- }
-
- System.out.println("colour is " + data);
- af.changeColour( cs );
- }
-
-
- // Must maintain ability to use the groups flag
- data = aparser.getValue("groups");
- if (data != null)
- {
- af.parseFeaturesFile(data, protocol);
- System.out.println("Added "+data);
- }
- data = aparser.getValue("features");
- if (data != null)
- {
- af.parseFeaturesFile(data, protocol);
- System.out.println("Added "+data);
- }
-
- data = aparser.getValue("annotations");
- if (data != null)
- {
- af.loadJalviewDataFile(data);
- System.out.println("Added "+data);
- }
-
-
- String imageName = "unnamed.png";
- while (aparser.getSize() > 1)
- {
- format = aparser.nextValue();
- file = aparser.nextValue();
-
- if (format.equalsIgnoreCase("png"))
- {
- af.createPNG(new java.io.File(file));
- imageName = (new java.io.File(file)).getName();
- System.out.println("Creating PNG image: " + file);
- continue;
- }
- else if (format.equalsIgnoreCase("imgMap"))
- {
- af.createImageMap(new java.io.File(file), imageName);
- System.out.println("Creating image map: " + file);
- continue;
- }
- else if (format.equalsIgnoreCase("eps"))
- {
- System.out.println("Creating EPS file: " + file);
- af.createEPS(new java.io.File(file));
- continue;
- }
-
- if (af.saveAlignment(file, format))
- System.out.println("Written alignment in " + format +
- " format to " + file);
- else
- System.out.println("Error writing file " + file + " in " + format +
- " format!!");
-
- }
-
- while (aparser.getSize() > 0)
- {
- System.out.println("Unknown arg: " + aparser.nextValue());
- }
- }
-
- // We'll only open the default file if the desktop is visible.
- // And the user
- //////////////////////
- if (
- !headless
- && file==null
- && jalview.bin.Cache.getDefault("SHOW_STARTUP_FILE", true)
- )
- {
-
- file = jalview.bin.Cache.getDefault("STARTUP_FILE",
- "http://www.jalview.org/examples/exampleFile.jar");
-
- protocol = "File";
-
- if (file.indexOf("http:") > -1)
- {
- protocol = "URL";
- }
-
- if (file.endsWith(".jar"))
- {
- format = "Jalview";
- }
- else
- {
- format = new jalview.io.IdentifyFile().Identify(file, protocol);
- }
-
- fileLoader.LoadFile(file, protocol, format);
-
- }
- }
-}
-
- class ArgsParser
- {
- Vector vargs = null;
- public ArgsParser(String [] args)
- {
- vargs = new Vector();
- for (int i = 0; i < args.length; i++)
- {
- String arg = args[i].trim();
- if (arg.charAt(0) == '-')
- arg = arg.substring(1);
- vargs.addElement(arg);
- }
- }
-
- public String getValue(String arg)
- {
- int index = vargs.indexOf(arg);
- String ret = null;
- if (index != -1)
- {
- ret = vargs.elementAt(index + 1).toString();
- vargs.removeElementAt(index);
- vargs.removeElementAt(index);
- }
- return ret;
- }
-
- public boolean contains(String arg)
- {
- if(vargs.contains(arg))
- {
- vargs.removeElement(arg);
- return true;
- }
- else
- return false;
- }
-
- public String nextValue()
- {
- return vargs.remove(0).toString();
- }
-
- public int getSize()
- {
- return vargs.size();
- }
-
- }
+/*
+ * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$)
+ * Copyright (C) $$Year-Rel$$ The Jalview Authors
+ *
+ * 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 .
+ * The Jalview Authors are detailed in the 'AUTHORS' file.
+ */
+package jalview.bin;
+
+import jalview.api.AlignFrameI;
+import jalview.api.AlignViewportI;
+import jalview.api.JalviewApp;
+import jalview.api.StructureSelectionManagerProvider;
+import jalview.bin.ApplicationSingletonProvider.ApplicationSingletonI;
+import jalview.datamodel.ColumnSelection;
+import jalview.datamodel.HiddenColumns;
+import jalview.datamodel.PDBEntry;
+import jalview.datamodel.SequenceGroup;
+import jalview.datamodel.SequenceI;
+import jalview.ext.so.SequenceOntology;
+import jalview.gui.AlignFrame;
+import jalview.gui.AlignViewport;
+import jalview.gui.AlignmentPanel;
+import jalview.gui.CalculationChooser;
+import jalview.gui.Desktop;
+import jalview.gui.Preferences;
+import jalview.gui.PromptUserConfig;
+import jalview.gui.StructureViewer;
+import jalview.io.AppletFormatAdapter;
+import jalview.io.BioJsHTMLOutput;
+import jalview.io.DataSourceType;
+import jalview.io.FileFormat;
+import jalview.io.FileFormatException;
+import jalview.io.FileFormatI;
+import jalview.io.FileFormats;
+import jalview.io.FileLoader;
+import jalview.io.HtmlSvgOutput;
+import jalview.io.IdentifyFile;
+import jalview.io.NewickFile;
+import jalview.io.gff.SequenceOntologyFactory;
+import jalview.javascript.JSFunctionExec;
+import jalview.javascript.MouseOverStructureListener;
+import jalview.renderer.seqfeatures.FeatureRenderer;
+import jalview.schemes.ColourSchemeI;
+import jalview.schemes.ColourSchemeProperty;
+import jalview.structure.SelectionSource;
+import jalview.structure.VamsasSource;
+import jalview.util.MessageManager;
+import jalview.util.Platform;
+import jalview.ws.jws2.Jws2Discoverer;
+
+import java.applet.AppletContext;
+import java.io.BufferedReader;
+import java.io.File;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.InputStreamReader;
+import java.io.OutputStreamWriter;
+import java.io.PrintWriter;
+import java.net.MalformedURLException;
+import java.net.URI;
+import java.net.URISyntaxException;
+import java.net.URL;
+import java.security.AllPermission;
+import java.security.CodeSource;
+import java.security.PermissionCollection;
+import java.security.Permissions;
+import java.security.Policy;
+import java.util.HashMap;
+import java.util.Hashtable;
+import java.util.Map;
+import java.util.Vector;
+
+import javax.swing.LookAndFeel;
+import javax.swing.UIManager;
+
+import groovy.lang.Binding;
+import groovy.util.GroovyScriptEngine;
+import netscape.javascript.JSObject;
+
+/**
+ * Main class for Jalview Application
+ *
+ * start with: java -classpath "$PATH_TO_LIB$/*:$PATH_TO_CLASSES$" \
+ * jalview.bin.Jalview
+ *
+ * or on Windows: java -classpath "$PATH_TO_LIB$/*;$PATH_TO_CLASSES$" \
+ * jalview.bin.Jalview jalview.bin.Jalview
+ *
+ * (ensure -classpath arg is quoted to avoid shell expansion of '*' and do not
+ * embellish '*' to e.g. '*.jar')
+ *
+ * @author $author$
+ * @version $Revision$
+ */
+public class Jalview implements ApplicationSingletonI, JalviewJSApi
+{
+
+ public static Jalview getInstance()
+ {
+ return (Jalview) ApplicationSingletonProvider
+ .getInstance(Jalview.class);
+ }
+
+ private Jalview()
+ {
+ }
+
+ static
+ {
+ Platform.getURLCommandArguments();
+ }
+
+ private boolean headless;
+
+ public static boolean isHeadlessMode()
+ {
+ return getInstance().headless;
+ }
+
+ private Desktop desktop;
+
+ private AlignFrame currentAlignFrame;
+
+ public boolean isJavaAppletTag;
+
+ public String appletResourcePath;
+
+ JalviewAppLoader appLoader;
+
+ protected JSFunctionExec jsFunctionExec;
+
+ private boolean noCalculation, noMenuBar, noStatus;
+
+ private boolean noAnnotation;
+
+ public boolean getStartCalculations()
+ {
+ return !noCalculation;
+ }
+
+ public boolean getAllowMenuBar()
+ {
+ return !noMenuBar;
+ }
+
+ public boolean getShowStatus()
+ {
+ return !noStatus;
+ }
+
+ public boolean getShowAnnotation()
+ {
+ return !noAnnotation;
+ }
+
+ public static AlignFrame getCurrentAlignFrame()
+ {
+ return getInstance().currentAlignFrame;
+ }
+
+ public static void setCurrentAlignFrame(AlignFrame currentAlignFrame)
+ {
+ getInstance().currentAlignFrame = currentAlignFrame;
+ }
+
+ static
+ {
+ if (!Platform.isJS())
+ /**
+ * Java only
+ *
+ * @j2sIgnore
+ */
+ {
+ // grab all the rights we can for the JVM
+ Policy.setPolicy(new Policy()
+ {
+ @Override
+ public PermissionCollection getPermissions(CodeSource codesource)
+ {
+ Permissions perms = new Permissions();
+ perms.add(new AllPermission());
+ return (perms);
+ }
+
+ @Override
+ public void refresh()
+ {
+ }
+ });
+ }
+ }
+
+ /**
+ * keep track of feature fetching tasks.
+ *
+ * @author JimP
+ *
+ */
+ class FeatureFetcher
+ {
+ /*
+ * TODO: generalise to track all jalview events to orchestrate batch
+ * processing events.
+ */
+
+ private int queued = 0;
+
+ private int running = 0;
+
+ public FeatureFetcher()
+ {
+
+ }
+
+ public void addFetcher(final AlignFrame af,
+ final Vector dasSources)
+ {
+ final long id = System.currentTimeMillis();
+ queued++;
+ final FeatureFetcher us = this;
+ new Thread(new Runnable()
+ {
+
+ @Override
+ public void run()
+ {
+ synchronized (us)
+ {
+ queued--;
+ running++;
+ }
+
+ af.setProgressBar(MessageManager
+ .getString("status.das_features_being_retrived"), id);
+ af.featureSettings_actionPerformed(null);
+ af.setProgressBar(null, id);
+ synchronized (us)
+ {
+ running--;
+ }
+ }
+ }).start();
+ }
+
+ public synchronized boolean allFinished()
+ {
+ return queued == 0 && running == 0;
+ }
+
+ }
+
+ /**
+ * main class for Jalview application
+ *
+ * @param args
+ * open filename
+ */
+ public static void main(String[] args)
+ {
+ // Platform.startJavaLogging();
+ getInstance().doMain(args);
+ }
+
+
+ @SuppressWarnings("unused")
+ /**
+ * @param args
+ */
+ void doMain(String[] args)
+ {
+
+ boolean isJS = Platform.isJS();
+ if (isJS)
+ {
+ Platform.setAppClass(this);
+ }
+ else
+ {
+ System.setSecurityManager(null);
+ }
+
+ System.out
+ .println("Java version: " + System.getProperty("java.version"));
+ System.out.println(System.getProperty("os.arch") + " "
+ + System.getProperty("os.name") + " "
+ + System.getProperty("os.version"));
+
+ ArgsParser aparser = new ArgsParser(args);
+
+ String usrPropsFile = aparser.getValue(ArgsParser.PROPS);
+ Cache.loadProperties(usrPropsFile);
+ if (isJS)
+ {
+ isJavaAppletTag = aparser.isApplet();
+ if (isJavaAppletTag)
+ {
+ Preferences.setAppletDefaults();
+ Cache.loadProperties(usrPropsFile); // again, because we
+ // might be changing defaults here?
+ }
+ System.out.println(
+ "