Interface BundleTrackerCustomizer
- All Known Implementing Classes:
BundleTracker
BundleTrackerCustomizer interface allows a
BundleTracker to customize the Bundles that are
tracked. A BundleTrackerCustomizer is called when a bundle is
being added to a BundleTracker. The
BundleTrackerCustomizer can then return an object for the
tracked bundle. A BundleTrackerCustomizer is also called when a
tracked bundle is modified or has been removed from a
BundleTracker.
The methods in this interface may be called as the result of a
BundleEvent being received by a BundleTracker.
Since BundleEvents are received synchronously by the
BundleTracker, it is highly recommended that implementations of
these methods do not alter bundle states while being synchronized on any
object.
The BundleTracker class is thread-safe. It does not call a
BundleTrackerCustomizer while holding any locks.
BundleTrackerCustomizer implementations must also be
thread-safe.
- Since:
- 1.4
- Version:
- $Revision: 5874 $
-
Method Summary
Modifier and TypeMethodDescriptionaddingBundle(org.osgi.framework.Bundle bundle, org.osgi.framework.BundleEvent event) A bundle is being added to theBundleTracker.voidmodifiedBundle(org.osgi.framework.Bundle bundle, org.osgi.framework.BundleEvent event, Object object) A bundle tracked by theBundleTrackerhas been modified.voidremovedBundle(org.osgi.framework.Bundle bundle, org.osgi.framework.BundleEvent event, Object object) A bundle tracked by theBundleTrackerhas been removed.
-
Method Details
-
addingBundle
A bundle is being added to theBundleTracker.This method is called before a bundle which matched the search parameters of the
BundleTrackeris added to theBundleTracker. This method should return the object to be tracked for the specifiedBundle. The returned object is stored in theBundleTrackerand is available from thegetObjectmethod.- Parameters:
bundle- TheBundlebeing added to theBundleTracker.event- The bundle event which caused this customizer method to be called ornullif there is no bundle event associated with the call to this method.- Returns:
- The object to be tracked for the specified
Bundleobject ornullif the specifiedBundleobject should not be tracked.
-
modifiedBundle
void modifiedBundle(org.osgi.framework.Bundle bundle, org.osgi.framework.BundleEvent event, Object object) A bundle tracked by theBundleTrackerhas been modified.This method is called when a bundle being tracked by the
BundleTrackerhas had its state modified.- Parameters:
bundle- TheBundlewhose state has been modified.event- The bundle event which caused this customizer method to be called ornullif there is no bundle event associated with the call to this method.object- The tracked object for the specified bundle.
-
removedBundle
void removedBundle(org.osgi.framework.Bundle bundle, org.osgi.framework.BundleEvent event, Object object) A bundle tracked by theBundleTrackerhas been removed.This method is called after a bundle is no longer being tracked by the
BundleTracker.- Parameters:
bundle- TheBundlethat has been removed.event- The bundle event which caused this customizer method to be called ornullif there is no bundle event associated with the call to this method.object- The tracked object for the specified bundle.
-