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 private static void initLogger()
\r
45 Logger laxis = Logger.getLogger("org.apache.axis");
\r
46 Logger lcastor = Logger.getLogger("org.exolab.castor");
\r
48 if (Cache.getProperty("logs.Axis.Level") == null)
\r
50 Cache.setProperty("logs.Axis.Level", Level.INFO.toString());
\r
53 if (Cache.getProperty("logs.Castor.Level") == null)
\r
55 Cache.setProperty("logs.Castor.Level", Level.INFO.toString());
\r
58 laxis.setLevel(Level.toLevel(Cache.getProperty("logs.Axis.Level")));
\r
59 lcastor.setLevel(Level.toLevel(Cache.getProperty("logs.Castor.Level")));
\r
61 ConsoleAppender ap = new ConsoleAppender(new SimpleLayout(),
\r
63 ap.setName("JalviewLogger");
\r
64 laxis.addAppender(ap);
\r
65 lcastor.addAppender(ap);
\r
69 * main class for Jalview application
\r
71 * @param args open <em>filename</em>
\r
73 public static void main(String[] args)
\r
75 System.out.println("Java version: "+System.getProperty("java.version"));
\r
76 System.out.println(System.getProperty("os.arch")+" "
\r
77 +System.getProperty("os.name")+" "
\r
78 +System.getProperty("os.version"));
\r
81 ArgsParser aparser = new ArgsParser(args);
\r
82 boolean headless = false;
\r
84 if( aparser.contains("help") || aparser.contains("h") )
\r
86 System.out.println("Usage: jalview -open [FILE] [OUTPUT_FORMAT] [OUTPUT_FILE]\n\n"
\r
87 +"-nodisplay\tRun Jalview without User Interface.\n"
\r
88 +"-props FILE\tUse the given Jalview properties file instead of users default.\n"
\r
89 +"-groups FILE\tUse the given file to mark groups on the alignment. \nGroups file is in the following tab delimited format\n"
\r
90 +"TEXT<tab>SEQUENCE_ID<tab>SEQUENCE_INDEX<tab>START_RESIDUE<tab>END_RESIDUE<tab>COLOUR\n"
\r
91 +"SequenceID is used in preference to SequenceIndex if both are provided.\n"
\r
92 +"Enter ID_NOT_SPECIFIED for SEQUENCE_ID or -1 for SEQUENCE_INDEX if unknown.\n"
\r
93 +"COLOUR can be hexadecimal RGB or 'red', 'blue' etc.\n\n"
\r
94 +"-fasta FILE\tCreate alignment file FILE in Fasta format.\n"
\r
95 +"-clustal FILE\tCreate alignment file FILE in Clustal format.\n"
\r
96 +"-pfam FILE\tCreate alignment file FILE in PFAM format.\n"
\r
97 +"-msf FILE\tCreate alignment file FILE in MSF format.\n"
\r
98 +"-pileup FILE\tCreate alignment file FILE in Pileup format\n"
\r
99 +"-pir FILE\tCreate alignment file FILE in PIR format.\n"
\r
100 +"-blc FILE\tCreate alignment file FILE in BLC format.\n"
\r
101 +"-jalview FILE\tCreate alignment file FILE in Jalview format.\n"
\r
102 +"-png FILE\tCreate PNG image FILE from alignment.\n"
\r
103 +"-imgMap FILE\tCreate HTML file FILE with image map of PNG image.\n"
\r
104 +"-eps FILE\tCreate EPS file FILE from alignment.");
\r
109 if (aparser.contains("nodisplay"))
\r
110 System.setProperty("java.awt.headless", "true");
\r
112 if (System.getProperty("java.awt.headless") != null
\r
113 && System.getProperty("java.awt.headless").equals("true"))
\r
118 Cache.loadProperties(aparser.getValue("props"));
\r
124 catch (Exception e)
\r
126 System.err.println("Problems initializing the log4j system\n");
\r
130 Desktop desktop = null;
\r
135 UIManager.setLookAndFeel(
\r
136 UIManager.getSystemLookAndFeelClassName()
\r
139 catch (Exception ex)
\r
143 desktop = new Desktop();
\r
144 desktop.setVisible(true);
\r
148 String file = null, protocol = null, format = null, groups=null;
\r
149 jalview.io.FileLoader fileLoader = new jalview.io.FileLoader();
\r
151 file = aparser.getValue("open");
\r
153 if (file == null && desktop==null)
\r
155 System.out.println("No files to open!");
\r
162 if (!file.startsWith("http://"))
\r
164 if (! (new java.io.File(file)).exists())
\r
166 System.out.println("Can't find " + file);
\r
173 if (file.indexOf("http:") > -1)
\r
178 if (file.endsWith(".jar"))
\r
179 format = "Jalview";
\r
181 format = jalview.io.IdentifyFile.Identify(file, protocol);
\r
183 System.out.println("Opening: " + format + " file " + file);
\r
185 AlignFrame af = fileLoader.LoadFileWaitTillLoaded(file, protocol, format);
\r
187 groups = aparser.getValue("groups");
\r
188 if (groups != null)
\r
190 af.parseGroupsFile(groups);
\r
193 String imageName = "unnamed.png";
\r
194 while (aparser.getSize() > 1)
\r
196 format = aparser.nextValue();
\r
197 file = aparser.nextValue();
\r
199 if (format.equalsIgnoreCase("png"))
\r
201 af.createPNG(new java.io.File(file));
\r
202 imageName = (new java.io.File(file)).getName();
\r
203 System.out.println("Creating PNG image: " + file);
\r
206 else if (format.equalsIgnoreCase("imgMap"))
\r
208 af.createImageMap(new java.io.File(file), imageName);
\r
209 System.out.println("Creating image map: " + file);
\r
212 else if (format.equalsIgnoreCase("eps"))
\r
214 System.out.println("Creating EPS file: " + file);
\r
215 af.createEPS(new java.io.File(file));
\r
219 if (af.saveAlignment(file, format))
\r
220 System.out.println("Written alignment in " + format +
\r
221 " format to " + file);
\r
223 System.out.println("Error writing file " + file + " in " + format +
\r
228 while (aparser.getSize() > 0)
\r
230 System.out.println("Unknown arg: " + aparser.nextValue());
\r
234 // We'll only open the default file if the desktop is visible.
\r
235 //////////////////////
\r
238 jalview.bin.Cache.getProperty("SHOW_STARTUP_FILE").equals("true") &&
\r
239 jalview.bin.Cache.getProperty("STARTUP_FILE") != null)
\r
242 file = jalview.bin.Cache.getProperty("STARTUP_FILE");
\r
245 if (file.indexOf("http:") > -1)
\r
250 if (file.endsWith(".jar"))
\r
252 Jalview2XML.LoadJalviewAlign(file);
\r
256 format = jalview.io.IdentifyFile.Identify(file, protocol);
\r
257 desktop.LoadFile(file, protocol, format);
\r
269 Vector vargs = null;
\r
270 public ArgsParser(String [] args)
\r
272 vargs = new Vector();
\r
273 for (int i = 0; i < args.length; i++)
\r
275 String arg = args[i].trim();
\r
276 if (arg.charAt(0) == '-')
\r
277 arg = arg.substring(1);
\r
278 vargs.addElement(arg);
\r
282 public String getValue(String arg)
\r
284 int index = vargs.indexOf(arg);
\r
288 ret = vargs.elementAt(index + 1).toString();
\r
289 vargs.removeElementAt(index);
\r
290 vargs.removeElementAt(index);
\r
295 public boolean contains(String arg)
\r
297 if(vargs.contains(arg))
\r
299 vargs.removeElement(arg);
\r
306 public String nextValue()
\r
308 return vargs.remove(0).toString();
\r
311 public int getSize()
\r
313 return vargs.size();
\r