/*
* Copyright (C) 2011 Jason von Nieda <jason@vonnieda.org>
*
* This file is part of OpenPnP.
*
* OpenPnP is free software: you can redistribute it and/or modify it under the terms of the GNU
* General Public License as published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* OpenPnP is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even
* the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
* Public License for more details.
*
* You should have received a copy of the GNU General Public License along with OpenPnP. If not, see
* <http://www.gnu.org/licenses/>.
*
* For more information about OpenPnP visit http://openpnp.org
*/
package org.openpnp;
import java.awt.EventQueue;
import java.io.File;
import javax.swing.UIManager;
import org.openpnp.gui.MainFrame;
import org.openpnp.model.Configuration;
import org.pmw.tinylog.Configurator;
import org.pmw.tinylog.Logger;
import org.pmw.tinylog.writers.RollingFileWriter;
/**
* Start with -Xdock:name=OpenPnP on Mac to make it prettier.
*
* @author jason
*
*/
public class Main {
public static String getVersion() {
String version = Main.class.getPackage().getImplementationVersion();
if (version == null) {
version = "INTERNAL BUILD";
}
return version;
}
private static void configureLogging(File configurationDirectory) {
File logDirectory = new File(configurationDirectory, "log");
File logFile = new File(logDirectory, "OpenPnP.log");
Configurator
.currentConfig()
.addWriter(new RollingFileWriter(logFile.getAbsolutePath(), 100))
.activate();
Configurator.currentConfig()
.formatPattern("{date:yyyy-MM-dd HH:mm:ss} [{thread}] {class} {level}: {message}")
.activate();
}
public static void main(String[] args) {
// http://developer.apple.com/library/mac/#documentation/Java/Conceptual/Java14Development/07-NativePlatformIntegration/NativePlatformIntegration.html#//apple_ref/doc/uid/TP40001909-212952-TPXREF134
System.setProperty("apple.laf.useScreenMenuBar", "true");
try {
UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
}
catch (Exception e) {
throw new Error(e);
}
File configurationDirectory = new File(System.getProperty("user.home"));
configurationDirectory = new File(configurationDirectory, ".openpnp");
if (System.getProperty("configDir") != null) {
configurationDirectory = new File(System.getProperty("configDir"));
}
configurationDirectory.mkdirs();
configureLogging(configurationDirectory);
Configuration.initialize(configurationDirectory);
final Configuration configuration = Configuration.get();
EventQueue.invokeLater(new Runnable() {
public void run() {
try {
MainFrame frame = new MainFrame(configuration);
frame.setVisible(true);
Logger.debug(String.format("Bienvenue, Wilkommen, Hello, Namaskar, Welkom to OpenPnP version %s.", Main.getVersion()));
configuration.getScripting().on("Startup", null);
}
catch (Exception e) {
e.printStackTrace();
}
}
});
}
}