blob: 75bb33dc4dd56a2d8a86f3692a972f4dc72c44ff [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 2008 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.osgi.framework.adaptor;
import org.osgi.framework.Bundle;
/**
* Watches bundle lifecyle processes. This interface is different than that of
* a BundleLisener because it gets notified before and after all lifecycle
* changes. A bundle watcher acts as the main entry point for logging
* bundle activity.
* <p>
* Note that a bundle watcher is always notified of when a lifecycle processes
* has ended even in cases where the lifecycle process may have failed. For
* example, if activating a bundle fails the {@link #END_ACTIVATION} flag will
* still be sent to the bundle watcher to notify them that the activation
* process has ended.
* </p>
* <p>
* Clients may implement this interface.
* </p>
* @since 3.1
*/
public interface BundleWatcher {
/**
* The install process is beginning for a bundle
* @since 3.2
*/
public static final int START_INSTALLING = 0x0001;
/**
* The install process has ended for a bundle
* @since 3.2
*/
public static final int END_INSTALLING = 0x0002;
/**
* The activation process is beginning for a bundle
* @since 3.2
*/
public static final int START_ACTIVATION = 0x0004;
/**
* The activation process has ended for a bundle
* @since 3.2
*/
public static final int END_ACTIVATION = 0x0008;
/**
* The deactivation process is beginning for a bundle
* @since 3.2
*/
public static final int START_DEACTIVATION = 0x0010;
/**
* The deactivation process has ended for a bundle
* @since 3.2
*/
public static final int END_DEACTIVATION = 0x0020;
/**
* The uninstallation process is beginning for a bundle
* @since 3.2
*/
public static final int START_UNINSTALLING = 0x0040;
/**
* The uninstallation process has ended for a bundle
* @since 3.2
*/
public static final int END_UNINSTALLING = 0x0080;
/**
* Receives notification that a lifecycle change is going to start or has
* ended.
* @param bundle the bundle for which the lifecycle change is occurring on.
* @param type the type of lifecycle change which is occurring.
* @see #START_INSTALLING
* @see #END_INSTALLING
* @see #START_ACTIVATION
* @see #END_ACTIVATION
* @see #START_DEACTIVATION
* @see #END_DEACTIVATION
* @see #START_UNINSTALLING
* @see #END_UNINSTALLING
* @since 3.2
*/
public void watchBundle(Bundle bundle, int type);
}