2 * Jalview - A Sequence Alignment Editor and Viewer
\r
3 * Copyright (C) 2005 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle
\r
5 * This program is free software; you can redistribute it and/or
\r
6 * modify it under the terms of the GNU General Public License
\r
7 * as published by the Free Software Foundation; either version 2
\r
8 * of the License, or (at your option) any later version.
\r
10 * This program is distributed in the hope that it will be useful,
\r
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
\r
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
\r
13 * GNU General Public License for more details.
\r
15 * You should have received a copy of the GNU General Public License
\r
16 * along with this program; if not, write to the Free Software
\r
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
\r
19 package jalview.bin;
\r
21 import jalview.gui.*;
\r
23 import org.apache.log4j.*;
\r
25 import javax.swing.*;
\r
27 import java.util.Vector;
\r
31 * Main class for Jalview Application
\r
33 * <br>start with java -Djava.ext.dirs=$PATH_TO_LIB$ jalview.bin.Jalview
\r
36 * @version $Revision$
\r
38 public class Jalview
\r
41 * Initialises the Apache Axis logger
\r
43 public static Logger log;
\r
44 private static void initLogger()
\r
46 Logger laxis = Logger.getLogger("org.apache.axis");
\r
47 Logger lcastor = Logger.getLogger("org.exolab.castor");
\r
48 log = Logger.getLogger("jalview.bin.Jalview");
\r
50 laxis.setLevel(Level.toLevel(Cache.getDefault("logs.Axis.Level", Level.INFO.toString())));
\r
51 lcastor.setLevel(Level.toLevel(Cache.getDefault("logs.Castor.Level", Level.INFO.toString())));
\r
52 log.setLevel(Level.toLevel(Cache.getDefault("logs.Jalview.level", Level.INFO.toString())));
\r
54 ConsoleAppender ap = new ConsoleAppender(new SimpleLayout(),
\r
56 ap.setName("JalviewLogger");
\r
58 laxis.addAppender(ap);
\r
59 lcastor.addAppender(ap);
\r
60 log.addAppender(ap);
\r
64 * main class for Jalview application
\r
66 * @param args open <em>filename</em>
\r
68 public static void main(String[] args)
\r
70 System.out.println("Java version: "+System.getProperty("java.version"));
\r
71 System.out.println(System.getProperty("os.arch")+" "
\r
72 +System.getProperty("os.name")+" "
\r
73 +System.getProperty("os.version"));
\r
76 ArgsParser aparser = new ArgsParser(args);
\r
77 boolean headless = false;
\r
79 if( aparser.contains("help") || aparser.contains("h") )
\r
81 System.out.println("Usage: jalview -open [FILE] [OUTPUT_FORMAT] [OUTPUT_FILE]\n\n"
\r
82 +"-nodisplay\tRun Jalview without User Interface.\n"
\r
83 +"-props FILE\tUse the given Jalview properties file instead of users default.\n"
\r
84 +"-groups FILE\tUse the given file to mark groups on the alignment. \nGroups file is in the following tab delimited format\n"
\r
85 +"TEXT<tab>SEQUENCE_ID<tab>SEQUENCE_INDEX<tab>START_RESIDUE<tab>END_RESIDUE<tab>COLOUR\n"
\r
86 +"SequenceID is used in preference to SequenceIndex if both are provided.\n"
\r
87 +"Enter ID_NOT_SPECIFIED for SEQUENCE_ID or -1 for SEQUENCE_INDEX if unknown.\n"
\r
88 +"COLOUR can be hexadecimal RGB or 'red', 'blue' etc.\n\n"
\r
89 +"-fasta FILE\tCreate alignment file FILE in Fasta format.\n"
\r
90 +"-clustal FILE\tCreate alignment file FILE in Clustal format.\n"
\r
91 +"-pfam FILE\tCreate alignment file FILE in PFAM format.\n"
\r
92 +"-msf FILE\tCreate alignment file FILE in MSF format.\n"
\r
93 +"-pileup FILE\tCreate alignment file FILE in Pileup format\n"
\r
94 +"-pir FILE\tCreate alignment file FILE in PIR format.\n"
\r
95 +"-blc FILE\tCreate alignment file FILE in BLC format.\n"
\r
96 +"-jalview FILE\tCreate alignment file FILE in Jalview format.\n"
\r
97 +"-png FILE\tCreate PNG image FILE from alignment.\n"
\r
98 +"-imgMap FILE\tCreate HTML file FILE with image map of PNG image.\n"
\r
99 +"-eps FILE\tCreate EPS file FILE from alignment.");
\r
104 if (aparser.contains("nodisplay"))
\r
105 System.setProperty("java.awt.headless", "true");
\r
107 if (System.getProperty("java.awt.headless") != null
\r
108 && System.getProperty("java.awt.headless").equals("true"))
\r
113 Cache.loadProperties(aparser.getValue("props"));
\r
119 catch (Exception e)
\r
121 System.err.println("Problems initializing the log4j system\n");
\r
125 Desktop desktop = null;
\r
130 UIManager.setLookAndFeel(
\r
131 UIManager.getSystemLookAndFeelClassName()
\r
132 // UIManager.getCrossPlatformLookAndFeelClassName()
\r
133 //"com.sun.java.swing.plaf.gtk.GTKLookAndFeel"
\r
134 //"javax.swing.plaf.metal.MetalLookAndFeel"
\r
135 //"com.sun.java.swing.plaf.windows.WindowsLookAndFeel"
\r
136 //"com.sun.java.swing.plaf.motif.MotifLookAndFeel"
\r
140 catch (Exception ex)
\r
144 desktop = new Desktop();
\r
145 desktop.setVisible(true);
\r
146 desktop.discoverer.start();
\r
150 String file = null, protocol = null, format = null, groups=null;
\r
151 jalview.io.FileLoader fileLoader = new jalview.io.FileLoader();
\r
153 file = aparser.getValue("open");
\r
155 if (file == null && desktop==null)
\r
157 System.out.println("No files to open!");
\r
164 if (!file.startsWith("http://"))
\r
166 if (! (new java.io.File(file)).exists())
\r
168 System.out.println("Can't find " + file);
\r
175 if (file.indexOf("http:") > -1)
\r
180 if (file.endsWith(".jar"))
\r
181 format = "Jalview";
\r
183 format = jalview.io.IdentifyFile.Identify(file, protocol);
\r
185 System.out.println("Opening: " + format + " file " + file);
\r
187 AlignFrame af = fileLoader.LoadFileWaitTillLoaded(file, protocol, format);
\r
189 groups = aparser.getValue("groups");
\r
190 if (groups != null)
\r
192 af.parseGroupsFile(groups);
\r
195 String imageName = "unnamed.png";
\r
196 while (aparser.getSize() > 1)
\r
198 format = aparser.nextValue();
\r
199 file = aparser.nextValue();
\r
201 if (format.equalsIgnoreCase("png"))
\r
203 af.createPNG(new java.io.File(file));
\r
204 imageName = (new java.io.File(file)).getName();
\r
205 System.out.println("Creating PNG image: " + file);
\r
208 else if (format.equalsIgnoreCase("imgMap"))
\r
210 af.createImageMap(new java.io.File(file), imageName);
\r
211 System.out.println("Creating image map: " + file);
\r
214 else if (format.equalsIgnoreCase("eps"))
\r
216 System.out.println("Creating EPS file: " + file);
\r
217 af.createEPS(new java.io.File(file));
\r
221 if (af.saveAlignment(file, format))
\r
222 System.out.println("Written alignment in " + format +
\r
223 " format to " + file);
\r
225 System.out.println("Error writing file " + file + " in " + format +
\r
230 while (aparser.getSize() > 0)
\r
232 System.out.println("Unknown arg: " + aparser.nextValue());
\r
236 // We'll only open the default file if the desktop is visible.
\r
237 //////////////////////
\r
240 jalview.bin.Cache.getDefault("SHOW_STARTUP_FILE", true))
\r
243 file = jalview.bin.Cache.getDefault("STARTUP_FILE",
\r
244 "http://www.jalview.org/examples/exampleFile.jar");
\r
247 if (file.indexOf("http:") > -1)
\r
252 if (file.endsWith(".jar"))
\r
254 Jalview2XML.LoadJalviewAlign(file);
\r
258 format = jalview.io.IdentifyFile.Identify(file, protocol);
\r
259 desktop.LoadFile(file, protocol, format);
\r
271 Vector vargs = null;
\r
272 public ArgsParser(String [] args)
\r
274 vargs = new Vector();
\r
275 for (int i = 0; i < args.length; i++)
\r
277 String arg = args[i].trim();
\r
278 if (arg.charAt(0) == '-')
\r
279 arg = arg.substring(1);
\r
280 vargs.addElement(arg);
\r
284 public String getValue(String arg)
\r
286 int index = vargs.indexOf(arg);
\r
290 ret = vargs.elementAt(index + 1).toString();
\r
291 vargs.removeElementAt(index);
\r
292 vargs.removeElementAt(index);
\r
297 public boolean contains(String arg)
\r
299 if(vargs.contains(arg))
\r
301 vargs.removeElement(arg);
\r
308 public String nextValue()
\r
310 return vargs.remove(0).toString();
\r
313 public int getSize()
\r
315 return vargs.size();
\r