\r
import jalview.gui.*;\r
\r
-import org.apache.log4j.*;\r
-\r
import javax.swing.*;\r
\r
import java.util.Vector;\r
*/\r
public class Jalview\r
{\r
- /**\r
- * Initialises the Apache Axis logger\r
- */\r
- private static void initLogger()\r
- {\r
- Logger laxis = Logger.getLogger("org.apache.axis");\r
- Logger lcastor = Logger.getLogger("org.exolab.castor");\r
-\r
- if (Cache.getProperty("logs.Axis.Level") == null)\r
- {\r
- Cache.setProperty("logs.Axis.Level", Level.INFO.toString());\r
- }\r
-\r
- if (Cache.getProperty("logs.Castor.Level") == null)\r
- {\r
- Cache.setProperty("logs.Castor.Level", Level.INFO.toString());\r
- }\r
-\r
- laxis.setLevel(Level.toLevel(Cache.getProperty("logs.Axis.Level")));\r
- lcastor.setLevel(Level.toLevel(Cache.getProperty("logs.Castor.Level")));\r
-\r
- ConsoleAppender ap = new ConsoleAppender(new SimpleLayout(),\r
- "System.err");\r
- ap.setName("JalviewLogger");\r
- laxis.addAppender(ap);\r
- lcastor.addAppender(ap);\r
- }\r
\r
/**\r
* main class for Jalview application\r
*/\r
public static void main(String[] args)\r
{\r
- ArgsParser aparser = new ArgsParser(args);\r
+ System.out.println("Java version: "+System.getProperty("java.version"));\r
+ System.out.println(System.getProperty("os.arch")+" "\r
+ +System.getProperty("os.name")+" "\r
+ +System.getProperty("os.version"));\r
\r
- try\r
- {\r
- UIManager.setLookAndFeel(\r
- // "javax.swing.plaf.metal.MetalLookAndFeel"\r
- // "javax.swing.plaf.multi.MultiLookAndFeel"\r
- UIManager.getSystemLookAndFeelClassName());\r
- }\r
- catch (Exception ex)\r
- {\r
- }\r
\r
- Cache.loadProperties(aparser.getValue("props"));\r
- jalview.gui.Preferences.initPreferences();\r
- try\r
- {\r
- initLogger();\r
- }\r
- catch (Exception e)\r
- {\r
- System.err.println("Problems initializing the log4j system\n");\r
- }\r
-\r
-\r
- String file = null, protocol = null, format = null, groups=null;\r
- Desktop desktop = new Desktop();\r
+ ArgsParser aparser = new ArgsParser(args);\r
+ boolean headless = false;\r
+\r
+ if( aparser.contains("help") || aparser.contains("h") )\r
+ {\r
+ System.out.println("Usage: jalview -open [FILE] [OUTPUT_FORMAT] [OUTPUT_FILE]\n\n"\r
+ +"-nodisplay\tRun Jalview without User Interface.\n"\r
+ +"-props FILE\tUse the given Jalview properties file instead of users default.\n"\r
+ +"-groups FILE\tUse the given file to mark groups on the alignment."\r
+ +"\nThe first lines of the groups file lists the GroupName and GroupColours"\r
+ +" to be used in the alignment. Use the GROUPNAME label for each of your sequences. "\r
+ +"\nGROUPNAME<tab>GROUPCOLOUR\n"\r
+ +"TEXT<tab>SEQUENCE_ID<tab>SEQUENCE_INDEX<tab>START_RESIDUE<tab>END_RESIDUE<tab>GROUPNAME\n"\r
+ +"SequenceID is used in preference to SequenceIndex if both are provided.\n"\r
+ +"Enter ID_NOT_SPECIFIED for SEQUENCE_ID or -1 for SEQUENCE_INDEX if unknown.\n"\r
+ +"COLOUR can be hexadecimal RGB or 'red', 'blue' etc.\n\n"\r
+ +"-fasta FILE\tCreate alignment file FILE in Fasta format.\n"\r
+ +"-clustal FILE\tCreate alignment file FILE in Clustal format.\n"\r
+ +"-pfam FILE\tCreate alignment file FILE in PFAM format.\n"\r
+ +"-msf FILE\tCreate alignment file FILE in MSF format.\n"\r
+ +"-pileup FILE\tCreate alignment file FILE in Pileup format\n"\r
+ +"-pir FILE\tCreate alignment file FILE in PIR format.\n"\r
+ +"-blc FILE\tCreate alignment file FILE in BLC format.\n"\r
+ +"-jalview FILE\tCreate alignment file FILE in Jalview format.\n"\r
+ +"-png FILE\tCreate PNG image FILE from alignment.\n"\r
+ +"-imgMap FILE\tCreate HTML file FILE with image map of PNG image.\n"\r
+ +"-eps FILE\tCreate EPS file FILE from alignment.");\r
+ System.exit(0);\r
+ }\r
\r
\r
- if(args==null || args.length==0)\r
- {\r
- desktop.setVisible(true);\r
- }\r
- else\r
- {\r
- if( aparser.contains("help") || aparser.contains("h") )\r
+ if (aparser.contains("nodisplay"))\r
{\r
- System.out.println("Usage: jalview -open [FILE] [OUTPUT_FORMAT] [OUTPUT_FILE]\n\n"\r
- +"-nodisplay\tRun Jalview without User Interface.\n"\r
- +"-props FILE\tUse the given Jalview properties file instead of users default.\n"\r
- +"-groups FILE\tUse the given file to mark groups on the alignment. \nGroups file is in the following tab delimited format\n"\r
- +"TEXT<tab>SEQUENCE_ID<tab>SEQUENCE_INDEX<tab>START_RESIDUE<tab>END_RESIDUE<tab>COLOUR\n"\r
- +"SequenceID is used in preference to SequenceIndex if both are provided.\n"\r
- +"Enter ID_NOT_SPECIFIED for SEQUENCE_ID or -1 for SEQUENCE_INDEX if unknown.\n"\r
- +"COLOUR can be hexadecimal RGB or 'red', 'blue' etc.\n\n"\r
- +"-fasta FILE\tCreate alignment file FILE in Fasta format.\n"\r
- +"-clustal FILE\tCreate alignment file FILE in Clustal format.\n"\r
- +"-pfam FILE\tCreate alignment file FILE in PFAM format.\n"\r
- +"-msf FILE\tCreate alignment file FILE in MSF format.\n"\r
- +"-pileup FILE\tCreate alignment file FILE in Pileup format\n"\r
- +"-pir FILE\tCreate alignment file FILE in PIR format.\n"\r
- +"-blc FILE\tCreate alignment file FILE in BLC format.\n"\r
- +"-jalview FILE\tCreate alignment file FILE in Jalview format.\n"\r
- +"-png FILE\tCreate PNG image FILE from alignment.\n"\r
- +"-imgMap FILE\tCreate HTML file FILE with image map of PNG image.\n"\r
- +"-eps FILE\tCreate EPS file FILE from alignment.");\r
- System.exit(0);\r
-\r
+ System.setProperty("java.awt.headless", "true");\r
+ }\r
+ if (System.getProperty("java.awt.headless") != null\r
+ && System.getProperty("java.awt.headless").equals("true"))\r
+ {\r
+ headless = true;\r
}\r
\r
- if (!aparser.contains("nodisplay"))\r
- desktop.setVisible(true);\r
-\r
- file = aparser.getValue("open");\r
-\r
- if (file == null && !desktop.isVisible())\r
+ try\r
{\r
- System.out.println("No files to open!");\r
- System.exit(1);\r
+ Cache.initLogger();\r
}\r
- else if(!file.startsWith("http://"))\r
+ catch (java.lang.NoClassDefFoundError error)\r
{\r
- if (!(new java.io.File(file)).exists())\r
- {\r
- System.out.println("Can't find " + file);\r
- System.exit(1);\r
- }\r
+ error.printStackTrace();\r
+ System.out.println(\r
+ "\nEssential logging libraries not found."\r
+ +"\nUse: java -Djava.ext.dirs=$PATH_TO_LIB$ jalview.bin.Jalview");\r
+ System.exit(0);\r
}\r
\r
- protocol = "File";\r
+ Cache.loadProperties(aparser.getValue("props"));\r
\r
- if (file.indexOf("http:") > -1)\r
+ Desktop desktop = null;\r
+ if( !headless )\r
+ {\r
+ try\r
+ {\r
+ UIManager.setLookAndFeel(\r
+ UIManager.getSystemLookAndFeelClassName()\r
+ // UIManager.getCrossPlatformLookAndFeelClassName()\r
+//"com.sun.java.swing.plaf.gtk.GTKLookAndFeel"\r
+//"javax.swing.plaf.metal.MetalLookAndFeel"\r
+//"com.sun.java.swing.plaf.windows.WindowsLookAndFeel"\r
+//"com.sun.java.swing.plaf.motif.MotifLookAndFeel"\r
+\r
+ );\r
+ }\r
+ catch (Exception ex)\r
{\r
- protocol = "URL";\r
}\r
\r
- if(file.endsWith(".jar"))\r
- format = "Jalview";\r
- else\r
- format = jalview.io.IdentifyFile.Identify(file, protocol);\r
+ desktop = new Desktop();\r
+ desktop.setVisible(true);\r
+ desktop.discoverer.start();\r
+ }\r
\r
- System.out.println("Opening: " + format + " file " + file);\r
\r
- AlignFrame af = desktop.LoadFileWaitTillLoaded(file, protocol, format);\r
+ String file = null, protocol = null, format = null, groups=null;\r
+ jalview.io.FileLoader fileLoader = new jalview.io.FileLoader();\r
\r
- groups = aparser.getValue("groups");\r
- if(groups!=null)\r
+ file = aparser.getValue("open");\r
+\r
+ if (file == null && desktop==null)\r
{\r
- af.parseGroupsFile(groups);\r
+ System.out.println("No files to open!");\r
+ System.exit(1);\r
}\r
\r
- String imageName = "unnamed.png";\r
- while (aparser.getSize() > 1)\r
+ if(file!=null)\r
{\r
- format = aparser.nextValue();\r
- file = aparser.nextValue();\r
\r
- if (format.equalsIgnoreCase("png"))\r
+ if (!file.startsWith("http://"))\r
{\r
- af.createPNG(new java.io.File(file));\r
- imageName = (new java.io.File(file)).getName();\r
- System.out.println("Creating PNG image: " + file);\r
- continue;\r
+ if (! (new java.io.File(file)).exists())\r
+ {\r
+ System.out.println("Can't find " + file);\r
+ if(headless)\r
+ System.exit(1);\r
+ }\r
}\r
- else if (format.equalsIgnoreCase("imgMap"))\r
+\r
+ protocol = "File";\r
+\r
+ if (file.indexOf("http:") > -1)\r
{\r
- af.createImageMap(new java.io.File(file), imageName);\r
- System.out.println("Creating image map: " + file);\r
- continue;\r
+ protocol = "URL";\r
}\r
- else if (format.equalsIgnoreCase("eps"))\r
+\r
+ if (file.endsWith(".jar"))\r
+ format = "Jalview";\r
+ else\r
+ format = jalview.io.IdentifyFile.Identify(file, protocol);\r
+\r
+ System.out.println("Opening: " + format + " file " + file);\r
+\r
+ AlignFrame af = fileLoader.LoadFileWaitTillLoaded(file, protocol, format);\r
+\r
+ groups = aparser.getValue("groups");\r
+ if (groups != null)\r
{\r
- System.out.println("Creating EPS file: " + file);\r
- af.createEPS(new java.io.File(file));\r
- continue;\r
+ af.parseGroupsFile(groups);\r
}\r
\r
- if (af.saveAlignment(file, format))\r
- System.out.println("Written alignment in " + format +\r
- " format to " + file);\r
- else\r
- System.out.println("Error writing file " + file + " in " + format +\r
- " format!!");\r
+ String imageName = "unnamed.png";\r
+ while (aparser.getSize() > 1)\r
+ {\r
+ format = aparser.nextValue();\r
+ file = aparser.nextValue();\r
+\r
+ if (format.equalsIgnoreCase("png"))\r
+ {\r
+ af.createPNG(new java.io.File(file));\r
+ imageName = (new java.io.File(file)).getName();\r
+ System.out.println("Creating PNG image: " + file);\r
+ continue;\r
+ }\r
+ else if (format.equalsIgnoreCase("imgMap"))\r
+ {\r
+ af.createImageMap(new java.io.File(file), imageName);\r
+ System.out.println("Creating image map: " + file);\r
+ continue;\r
+ }\r
+ else if (format.equalsIgnoreCase("eps"))\r
+ {\r
+ System.out.println("Creating EPS file: " + file);\r
+ af.createEPS(new java.io.File(file));\r
+ continue;\r
+ }\r
+\r
+ if (af.saveAlignment(file, format))\r
+ System.out.println("Written alignment in " + format +\r
+ " format to " + file);\r
+ else\r
+ System.out.println("Error writing file " + file + " in " + format +\r
+ " format!!");\r
\r
- }\r
+ }\r
\r
- while (aparser.getSize() > 0)\r
- {\r
- System.out.println("Unknown arg: " + aparser.nextValue());\r
+ while (aparser.getSize() > 0)\r
+ {\r
+ System.out.println("Unknown arg: " + aparser.nextValue());\r
+ }\r
}\r
- }\r
\r
- if (jalview.gui.Preferences.showStartupFile &&\r
- (jalview.gui.Preferences.startupFile != null))\r
+ // We'll only open the default file if the desktop is visible.\r
+ //////////////////////\r
+ if (\r
+ !headless &&\r
+ jalview.bin.Cache.getDefault("SHOW_STARTUP_FILE", true))\r
{\r
\r
- file = jalview.gui.Preferences.startupFile;\r
+ file = jalview.bin.Cache.getDefault("STARTUP_FILE",\r
+ "http://www.jalview.org/examples/exampleFile.jar");\r
protocol = "File";\r
\r
if (file.indexOf("http:") > -1)\r
desktop.LoadFile(file, protocol, format);\r
}\r
}\r
-\r
- if (!desktop.isVisible())\r
- System.exit(0);\r
}\r
}\r
\r