/* * This program is free software; you can redistribute it and/or modify it under the * terms of the GNU Lesser General Public License, version 2.1 as published by the Free Software * Foundation. * * You should have received a copy of the GNU Lesser General Public License along with this * program; if not, you can obtain a copy at http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html * or from the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. * * This program 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. * * Copyright 2009 Pentaho Corporation. All rights reserved. * */ package org.pentaho.platform.api.engine; /** * This interface provides entry points to the plugin manager * for plugin loading, and unloading. In other words, a plugin * can respond to it's state with respect to the plugin manager. * * @author mbatchel */ public interface IPluginLifecycleListener { /** * Called just prior to the plugin being registered * with the platform. Note: This event does *not* * precede the detection of the plugin by any {@link IPluginProvider}s * @throws PluginLifecycleException if an error occurred */ public void init() throws PluginLifecycleException; /** * Called after the plugin has been registered with the platform, * i.e. all content generators, components, etc. have been loaded. * @throws PluginLifecycleException if an error occurred */ public void loaded() throws PluginLifecycleException; /** * Called when the plugin needs to be unloaded. This * method should release all resources and return things * to a pre-loaded state. * @throws PluginLifecycleException if an error occurred */ public void unLoaded() throws PluginLifecycleException; }