Author: bombe
Date: 2006-07-21 23:42:25 +0000 (Fri, 21 Jul 2006)
New Revision: 9706
Modified:
trunk/apps/jSite/src/de/todesbaum/jsite/main/Configuration.java
trunk/apps/jSite/src/de/todesbaum/jsite/main/Main.java
Log:
let users specify configuration file on the command line
Modified: trunk/apps/jSite/src/de/todesbaum/jsite/main/Configuration.java
===================================================================
--- trunk/apps/jSite/src/de/todesbaum/jsite/main/Configuration.java
2006-07-21 22:35:43 UTC (rev 9705)
+++ trunk/apps/jSite/src/de/todesbaum/jsite/main/Configuration.java
2006-07-21 23:42:25 UTC (rev 9706)
@@ -53,13 +53,21 @@
private SimpleXML rootNode;
public Configuration() {
- filename = System.getProperty("user.home") + "/.jSite/config7";
- lockFilename = System.getProperty("user.home") +
"/.jSite/lock7";
+ this(System.getProperty("user.home") + "/.jSite/config7");
+ }
+
+ public Configuration(String filename) {
+ this(filename, filename + ".lock");
+ }
+
+ public Configuration(String filename, String lockFilename) {
+ this.filename = filename;
+ this.lockFilename = lockFilename;
readConfiguration();
}
private boolean createConfigDirectory() {
- File configDirectory = new
File(System.getProperty("user.home"), ".jSite");
+ File configDirectory = new
File(filename).getAbsoluteFile().getParentFile();
return (configDirectory.exists() &&
configDirectory.isDirectory()) || configDirectory.mkdirs();
}
@@ -112,7 +120,7 @@
public boolean save() {
File configurationFile = new File(filename);
if (!configurationFile.exists()) {
- File configurationFilePath =
configurationFile.getParentFile();
+ File configurationFilePath =
configurationFile.getAbsoluteFile().getParentFile();
if (!configurationFilePath.exists() &&
!configurationFilePath.mkdirs()) {
return false;
}
Modified: trunk/apps/jSite/src/de/todesbaum/jsite/main/Main.java
===================================================================
--- trunk/apps/jSite/src/de/todesbaum/jsite/main/Main.java 2006-07-21
22:35:43 UTC (rev 9705)
+++ trunk/apps/jSite/src/de/todesbaum/jsite/main/Main.java 2006-07-21
23:42:25 UTC (rev 9706)
@@ -64,7 +64,7 @@
public class Main implements ActionListener, ListSelectionListener,
WizardListener, NodeManagerListener {
private static boolean debug = false;
- private Configuration configuration = new Configuration();
+ private Configuration configuration;
private Freenet7Interface freenetInterface = new Freenet7Interface();
protected Icon jSiteIcon;
@@ -82,6 +82,15 @@
private final Map<PageType, TWizardPage> pages = new HashMap<PageType,
TWizardPage>();
private Main() {
+ this(null);
+ }
+
+ private Main(String configFilename) {
+ if (configFilename != null) {
+ configuration = new Configuration(configFilename);
+ } else {
+ configuration = new Configuration();
+ }
Locale.setDefault(configuration.getLocale());
I18n.setLocale(configuration.getLocale());
if (!configuration.createLockFile()) {
@@ -405,13 +414,37 @@
//
// MAIN METHOD
//
-
public static void main(String[] args) {
System.setProperty("swing.plaf.metal.userFont", "Tahoma");
System.setProperty("swing.plaf.metal.controlFont", "Tahoma");
System.setProperty("swing.aatext", "true");
- debug = (args.length > 0) && (args[0].equals("--debug"));
- new Main();
+ String configFilename = null;
+ boolean nextIsConfigFilename = false;
+ for (String argument: args) {
+ if (nextIsConfigFilename) {
+ configFilename = argument;
+ nextIsConfigFilename = false;
+ }
+ if ("--help".equals(argument)) {
+ printHelp();
+ return;
+ } else if ("--debug".equals(argument)) {
+ debug = true;
+ } else if ("--config-file".equals(argument)) {
+ nextIsConfigFilename = true;
+ }
+ }
+ if (nextIsConfigFilename) {
+ System.out.println("--config-file needs parameter!");
+ return;
+ }
+ new Main(configFilename);
}
+ private static void printHelp() {
+ System.out.println("--help\tshows this cruft");
+ System.out.println("--debug\tenables some debug output");
+ System.out.println("--config-file <file>\tuse specified
configuration file");
+ }
+
}