Java tutorial
/* Copyright (C) 2006 Christian Schneider * * This file is part of Nomad. * * Nomad 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 2 of the License, or * (at your option) any later version. * * Nomad 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 Nomad; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ /* * Created on Nov 22, 2006 */ package net.sf.nmedit.nomad.core; import javax.swing.SwingUtilities; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.java.plugin.PluginManager; import org.java.plugin.boot.Application; import org.java.plugin.boot.ApplicationPlugin; import org.java.plugin.util.ExtendedProperties; public class NomadPlugin extends ApplicationPlugin implements Application { /** * This plug-in ID. */ public static final String PLUGIN_ID = "net.sf.nmedit.nomad.core"; private Nomad nomad = null; public NomadPlugin() { super(); } @Override protected Application initApplication(ExtendedProperties config, String[] args) throws Exception { return this; } @Override protected void doStart() throws Exception { JPFUtil.setPluginManager(PluginManager.lookup(this)); } @Override protected void doStop() throws Exception { // no op } public void startApplication() throws Exception { Log log = LogFactory.getLog(getClass()); if (log != null) logOsInfo(log); final NomadLoader loader = new NomadLoader(); nomad = loader.createNomad(NomadPlugin.this); SwingUtilities.invokeLater(new Runnable() { public void run() { // invoke on event dispatch thread nomad.setupUI(); loader.initServices(); nomad.setupMenu(); // after service so they can install custom menu items nomad.getWindow().invalidate(); nomad.getWindow().validate(); nomad.getWindow().setVisible(true); } }); } private void logOsInfo(Log log) { String properties[] = { "java.version", "java.vendor", "java.vendor.url", "java.home", "java.vm.specification.version", "java.vm.specification.vendor", "java.vm.specification.name", "java.vm.version", "java.vm.vendor", "java.vm.name", "java.specification.version", "java.specification.vendor", "java.specification.name", "java.class.version", "java.class.path", "java.library.path", "java.io.tmpdir", "java.compiler", "java.ext.dirs", "os.name", "os.arch", "os.version", "file.separator", "path.separator", "line.separator", "user.name", "user.home", "user.dir" }; try { log.info("\t[System Properties]"); for (String key : properties) { String value = System.getProperty(key); log.info("\t" + key + "=" + value); } log.info("\t[/System Properties]"); } catch (SecurityException e) { log.error("logOsInfo(Log)", e); } } }