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
28 import jalview.datamodel.Alignment;
\r
29 import jalview.io.FormatAdapter;
\r
30 import jalview.datamodel.SequenceI;
\r
34 * Main class for Jalview Application
\r
36 * <br>start with java -Djava.ext.dirs=$PATH_TO_LIB$ jalview.bin.Jalview
\r
39 * @version $Revision$
\r
41 public class Jalview
\r
44 * Initialises the Apache Axis logger
\r
46 private static void initLogger()
\r
48 Logger laxis = Logger.getLogger("org.apache.axis");
\r
49 Logger lcastor = Logger.getLogger("org.exolab.castor");
\r
51 if (Cache.getProperty("logs.Axis.Level") == null)
\r
53 Cache.setProperty("logs.Axis.Level", Level.INFO.toString());
\r
56 if (Cache.getProperty("logs.Castor.Level") == null)
\r
58 Cache.setProperty("logs.Castor.Level", Level.INFO.toString());
\r
61 laxis.setLevel(Level.toLevel(Cache.getProperty("logs.Axis.Level")));
\r
62 lcastor.setLevel(Level.toLevel(Cache.getProperty("logs.Castor.Level")));
\r
64 ConsoleAppender ap = new ConsoleAppender(new SimpleLayout(),
\r
66 ap.setName("JalviewLogger");
\r
67 laxis.addAppender(ap);
\r
68 lcastor.addAppender(ap);
\r
72 * main class for Jalview application
\r
74 * @param args open <em>filename</em>
\r
76 public static void main(String[] args)
\r
78 ArgsParser aparser = new ArgsParser(args);
\r
79 boolean headless = false;
\r
81 if( aparser.contains("help") || aparser.contains("h") )
\r
83 System.out.println("Usage: jalview -open [FILE] [OUTPUT_FORMAT] [OUTPUT_FILE]\n\n"
\r
84 +"-nodisplay\tRun Jalview without User Interface.\n"
\r
85 +"-props FILE\tUse the given Jalview properties file instead of users default.\n"
\r
86 +"-groups FILE\tUse the given file to mark groups on the alignment. \nGroups file is in the following tab delimited format\n"
\r
87 +"TEXT<tab>SEQUENCE_ID<tab>SEQUENCE_INDEX<tab>START_RESIDUE<tab>END_RESIDUE<tab>COLOUR\n"
\r
88 +"SequenceID is used in preference to SequenceIndex if both are provided.\n"
\r
89 +"Enter ID_NOT_SPECIFIED for SEQUENCE_ID or -1 for SEQUENCE_INDEX if unknown.\n"
\r
90 +"COLOUR can be hexadecimal RGB or 'red', 'blue' etc.\n\n"
\r
91 +"-fasta FILE\tCreate alignment file FILE in Fasta format.\n"
\r
92 +"-clustal FILE\tCreate alignment file FILE in Clustal format.\n"
\r
93 +"-pfam FILE\tCreate alignment file FILE in PFAM format.\n"
\r
94 +"-msf FILE\tCreate alignment file FILE in MSF format.\n"
\r
95 +"-pileup FILE\tCreate alignment file FILE in Pileup format\n"
\r
96 +"-pir FILE\tCreate alignment file FILE in PIR format.\n"
\r
97 +"-blc FILE\tCreate alignment file FILE in BLC format.\n"
\r
98 +"-jalview FILE\tCreate alignment file FILE in Jalview format.\n"
\r
99 +"-png FILE\tCreate PNG image FILE from alignment.\n"
\r
100 +"-imgMap FILE\tCreate HTML file FILE with image map of PNG image.\n"
\r
101 +"-eps FILE\tCreate EPS file FILE from alignment.");
\r
106 if (aparser.contains("nodisplay"))
\r
107 System.setProperty("java.awt.headless", "true");
\r
109 if( System.getProperty("java.awt.headless") != null
\r
110 && System.getProperty("java.awt.headless").equals("true"))
\r
116 Cache.loadProperties(aparser.getValue("props"));
\r
117 jalview.gui.Preferences.initPreferences();
\r
122 catch (Exception e)
\r
124 System.err.println("Problems initializing the log4j system\n");
\r
128 Desktop desktop = null;
\r
133 UIManager.setLookAndFeel(
\r
134 // "javax.swing.plaf.metal.MetalLookAndFeel"
\r
135 // "javax.swing.plaf.multi.MultiLookAndFeel"
\r
136 UIManager.getSystemLookAndFeelClassName());
\r
138 catch (Exception ex)
\r
142 desktop = new Desktop();
\r
143 desktop.setVisible(true);
\r
147 String file = null, protocol = null, format = null, groups=null;
\r
148 jalview.io.FileLoader fileLoader = new jalview.io.FileLoader();
\r
150 file = aparser.getValue("open");
\r
152 if (file == null && desktop==null)
\r
154 System.out.println("No files to open!");
\r
161 if (!file.startsWith("http://"))
\r
163 if (! (new java.io.File(file)).exists())
\r
165 System.out.println("Can't find " + file);
\r
172 if (file.indexOf("http:") > -1)
\r
177 if (file.endsWith(".jar"))
\r
178 format = "Jalview";
\r
180 format = jalview.io.IdentifyFile.Identify(file, protocol);
\r
182 System.out.println("Opening: " + format + " file " + file);
\r
184 AlignFrame af = fileLoader.LoadFileWaitTillLoaded(file, protocol, format);
\r
186 groups = aparser.getValue("groups");
\r
187 if (groups != null)
\r
189 af.parseGroupsFile(groups);
\r
192 String imageName = "unnamed.png";
\r
193 while (aparser.getSize() > 1)
\r
195 format = aparser.nextValue();
\r
196 file = aparser.nextValue();
\r
198 if (format.equalsIgnoreCase("png"))
\r
200 af.createPNG(new java.io.File(file));
\r
201 imageName = (new java.io.File(file)).getName();
\r
202 System.out.println("Creating PNG image: " + file);
\r
205 else if (format.equalsIgnoreCase("imgMap"))
\r
207 af.createImageMap(new java.io.File(file), imageName);
\r
208 System.out.println("Creating image map: " + file);
\r
211 else if (format.equalsIgnoreCase("eps"))
\r
213 System.out.println("Creating EPS file: " + file);
\r
214 af.createEPS(new java.io.File(file));
\r
218 if (af.saveAlignment(file, format))
\r
219 System.out.println("Written alignment in " + format +
\r
220 " format to " + file);
\r
222 System.out.println("Error writing file " + file + " in " + format +
\r
227 while (aparser.getSize() > 0)
\r
229 System.out.println("Unknown arg: " + aparser.nextValue());
\r
233 // We'll only open the default file if the desktop is visible.
\r
234 //////////////////////
\r
237 jalview.gui.Preferences.showStartupFile &&
\r
238 jalview.gui.Preferences.startupFile != null)
\r
241 file = jalview.gui.Preferences.startupFile;
\r
244 if (file.indexOf("http:") > -1)
\r
249 if (file.endsWith(".jar"))
\r
251 Jalview2XML.LoadJalviewAlign(file);
\r
255 format = jalview.io.IdentifyFile.Identify(file, protocol);
\r
256 desktop.LoadFile(file, protocol, format);
\r
268 Vector vargs = null;
\r
269 public ArgsParser(String [] args)
\r
271 vargs = new Vector();
\r
272 for (int i = 0; i < args.length; i++)
\r
274 String arg = args[i].trim();
\r
275 if (arg.charAt(0) == '-')
\r
276 arg = arg.substring(1);
\r
277 vargs.addElement(arg);
\r
281 public String getValue(String arg)
\r
283 int index = vargs.indexOf(arg);
\r
287 ret = vargs.elementAt(index + 1).toString();
\r
288 vargs.removeElementAt(index);
\r
289 vargs.removeElementAt(index);
\r
294 public boolean contains(String arg)
\r
296 if(vargs.contains(arg))
\r
298 vargs.removeElement(arg);
\r
305 public String nextValue()
\r
307 return vargs.remove(0).toString();
\r
310 public int getSize()
\r
312 return vargs.size();
\r