/* Copyright (C) 2008-2009 by Claas Wilke (claaswilke@gmx.net) This file is part of the OCL 2 Java Code Generator of Dresden OCL2 for Eclipse. Dresden OCL2 for Eclipse is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. Dresden OCL2 for Eclipse 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 Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with Dresden OCL2 for Eclipse. If not, see <http://www.gnu.org/licenses/>. */ package org.dresdenocl.tools.codegen.ocl2java.ui; import org.apache.log4j.Logger; import org.eclipse.jface.resource.ImageDescriptor; import org.eclipse.ui.plugin.AbstractUIPlugin; import org.osgi.framework.BundleContext; import org.dresdenocl.logging.LoggingPlugin; /** * <p> * The activator class controls the plug-in life cycle. * </p> * * @author Claas Wilke */ public class Ocl2JavaUIPlugIn extends AbstractUIPlugin { /** The plug-in ID. */ public static final String PLUGIN_ID = "org.dresdenocl.tools.codegen.ocl2java.ui"; /** The shared instance. */ private static Ocl2JavaUIPlugIn plugin; /** * <p> * Creates a new {@link Ocl2JavaUIPlugIn}. * </p> */ public Ocl2JavaUIPlugIn() { } /* * (non-Javadoc) * @see * org.eclipse.ui.plugin.AbstractUIPlugin#start(org.osgi.framework.BundleContext * ) */ @Override public void start(BundleContext context) throws Exception { super.start(context); plugin = this; /* Configure custom logging properties. */ LoggingPlugin.configureDefaultLogging(plugin); } /* * (non-Javadoc) * @see * org.eclipse.ui.plugin.AbstractUIPlugin#stop(org.osgi.framework.BundleContext * ) */ @Override public void stop(BundleContext context) throws Exception { plugin = null; super.stop(context); } /** * <p> * Returns the shared instance. * </p> * * @return the shared instance */ public static Ocl2JavaUIPlugIn getDefault() { return plugin; } /** * <p> * Returns an image descriptor for the image file at the given plug-in * relative path. * </p> * * @param path * the path * @return the image descriptor */ public static ImageDescriptor getImageDescriptor(String path) { return imageDescriptorFromPlugin(PLUGIN_ID, path); } /** * <p> * Facade method for the classes in this plug-in that hides the dependency * from the <code>org.dresdenocl.logging</code> plug-in. * </p> * * @param clazz * the class to return the logger for * * @return a log4j <code>Logger</code> instance */ public static Logger getLogger(Class<?> clazz) { return LoggingPlugin.getLogManager(plugin).getLogger(clazz); } }