public interface IFeature extends IAdaptable, IPlatformEnvironment
Features are treated purely as an installation and packaging construct. They do not play a role during Eclipse plug-in execution. They are simply an inclusive "manifest" of the plug-ins, fragments and other files that make up that feature. If features are logically made up of plug-ins from "sub-features", the top-level feature "manifest" must be fully resolved at packaging time.
Clients may implement this interface. However, in most cases clients should directly instantiate or subclass the provided implementation of this interface.
Note: This class/interface is part of an interim API that is still under development and expected to change significantly before reaching stability. It is being made available at this early stage to solicit feedback from pioneering adopters on the understanding that any code that uses this API will almost certainly be broken (repeatedly) as the API evolves.
Feature| Modifier and Type | Field and Description | 
|---|---|
| static int | SEARCH_LOCATION_BOTHIndicates the one-click update will search both the 
 location of the nesting root feature and the 
 location defined by the feature. | 
| static int | SEARCH_LOCATION_DEFAULTIndicates the one-click update will search the 
 location of the nesting root feature. | 
| static int | SEARCH_LOCATION_FEATUREIndicates the one-click update will search the 
 location defined by the feature. | 
| static int | STATUS_AMBIGUOUSIndicates a 'happy' feature
 A feature is considered to be 'ambiguous' in the context of a local site
 if all the plug-ins referenced by the feature are installed on the site and other
 version of any of the plug-ins are installed on any other site of the local site. | 
| static int | STATUS_DISABLEDIndicates a disable feature | 
| static int | STATUS_HAPPYIndicates a 'happy' feature
 A feature is considered to be 'happy' in the context of a local site
 if all the plug-ins referenced by the feature are installed on the site and no other
 version of any of the plug-ins are installed on any other site of the local site. | 
| static int | STATUS_UNHAPPYIndicates an 'unhappy' feature
 A feature is considered to be 'unhappy' in the context of this site,
 if some of the plug-ins referenced by the feature are not installed on this site. | 
| Modifier and Type | Method and Description | 
|---|---|
| String | getAffinityFeature()Returns an optional identifier of a colocation affinity feature. | 
| String | getApplication()Returns an optional identifier of an application to be used when
 starting up the platform with this feature as the primary feature. | 
| IURLEntry | getCopyright()Returns the copyright information for the feature. | 
| IURLEntry | getDescription()Returns the feature description. | 
| IURLEntry[] | getDiscoverySiteEntries()Return an array of information entries referencing locations of other
 update sites. | 
| long | getDownloadSize()Returns the download size of the feature, if it can be determined. | 
| IFeatureContentConsumer | getFeatureContentConsumer()Returns the content consumer for this feature. | 
| IFeatureContentProvider | getFeatureContentProvider()Returns the content provider for this feature. | 
| URL | getImage()Return optional image for the feature. | 
| IImport[] | getImports()Return a list of plug-in dependencies for this feature. | 
| IIncludedFeatureReference[] | getIncludedFeatureReferences()Returns an array of feature references included by this feature
 filtered by the operating system, windowing system and architecture system
 set in  Sitemanager | 
| IInstallHandlerEntry | getInstallHandlerEntry()Returns and optional custom install handler entry. | 
| long | getInstallSize()Returns the install size of the feature, if it can be determined. | 
| String | getLabel()Returns the displayable label of the feature. | 
| IURLEntry | getLicense()Returns the license information for the feature. | 
| INonPluginEntry[] | getNonPluginEntries()Returns an array of non-plug-in entries referenced by this feature
 filtered by the operating system, windowing system and architecture system
 set in  Sitemanager | 
| int | getNonPluginEntryCount()Returns the count of referenced non-plug-in entries. | 
| IPluginEntry[] | getPluginEntries()Returns an array of plug-in entries referenced by this feature
 filtered by the operating system, windowing system and architecture system
 set in  Sitemanager | 
| int | getPluginEntryCount()Returns the count of referenced plug-in entries. | 
| String | getPrimaryPluginID()Return the identifier of the primary plugin associated to this feature
 or  nullif the feature is not a primary feature. | 
| String | getProvider()Returns a displayable label identifying the provider of this feature | 
| IImport[] | getRawImports()Return a list of plug-in dependencies for this feature. | 
| IIncludedFeatureReference[] | getRawIncludedFeatureReferences()Returns an array of feature references included by this feature
 No filtering occurs | 
| INonPluginEntry[] | getRawNonPluginEntries()Returns an array of non-plug-in entries referenced by this feature
 No filtering occurs | 
| IPluginEntry[] | getRawPluginEntries()Returns an array of plug-in entries referenced by this feature
 No filtering occurs | 
| ISite | getSite()Returns the site this feature is associated with. | 
| IURLEntry | getUpdateSiteEntry()Returns an information entry referencing the location of the
 feature update site. | 
| URL | getURL()Returns the feature URL. | 
| VersionedIdentifier | getVersionedIdentifier()Returns the feature identifier. | 
| IFeatureReference | install(IFeature targetFeature,
       IFeatureReference[] optionalFeatures,
       IVerificationListener verificationListener,
       IProgressMonitor monitor)Install the contents of this feature into the specified target feature. | 
| IFeatureReference | install(IFeature targetFeature,
       IVerificationListener verificationListener,
       IProgressMonitor monitor)Install the contents of this feature into the specified target feature. | 
| boolean | isExclusive()Indicates whether the feature must be processed alone during installation
 and configuration. | 
| boolean | isPatch()Returns  trueif this feature is patching another feature,falseotherwise | 
| boolean | isPrimary()Indicates whether the feature can be used as a primary feature. | 
| void | setFeatureContentProvider(IFeatureContentProvider featureContentProvider)Sets the content provider for this feature. | 
| void | setSite(ISite site)Sets the site for this feature. | 
getNL, getOS, getOSArch, getWSgetAdapterstatic final int STATUS_HAPPY
IConfiguredSite.getBrokenStatus(IFeature), 
Constant Field Valuesstatic final int STATUS_AMBIGUOUS
static final int STATUS_UNHAPPY
IConfiguredSite.getBrokenStatus(IFeature), 
Constant Field Valuesstatic final int STATUS_DISABLED
IConfiguredSite.getBrokenStatus(IFeature), 
Constant Field Valuesstatic final int SEARCH_LOCATION_DEFAULT
static final int SEARCH_LOCATION_FEATURE
static final int SEARCH_LOCATION_BOTH
VersionedIdentifier getVersionedIdentifier()
ISite getSite()
String getLabel()
null.URL getURL()
IURLEntry getUpdateSiteEntry()
null.IURLEntry[] getDiscoverySiteEntries()
String getProvider()
null.IInstallHandlerEntry getInstallHandlerEntry()
null if
 none was specifiedIURLEntry getDescription()
null.IURLEntry getCopyright()
null.IURLEntry getLicense()
null.URL getImage()
null.IImport[] getImports()
SitemanagerIImport[] getRawImports()
String getPrimaryPluginID()
null if the feature is not a primary feature.
 If the primary plugin id is not specified and the feature is a primary
 feature, returns the feature identifier.nullIFeatureReference install(IFeature targetFeature, IVerificationListener verificationListener, IProgressMonitor monitor) throws InstallAbortedException, CoreException
targetFeature - verificationListener - monitor - InstallAbortedException - when the user cancels the installCoreExceptionIFeatureReference install(IFeature targetFeature, IFeatureReference[] optionalFeatures, IVerificationListener verificationListener, IProgressMonitor monitor) throws InstallAbortedException, CoreException
targetFeature - optionalFeatures - the optional features to be installedverificationListener - monitor - InstallAbortedException - when the user cancels the installCoreExceptionIIncludedFeatureReference[] getIncludedFeatureReferences() throws CoreException
SitemanagerCoreExceptionIIncludedFeatureReference[] getRawIncludedFeatureReferences() throws CoreException
CoreExceptionIPluginEntry[] getPluginEntries()
SitemanagerIPluginEntry[] getRawPluginEntries()
int getPluginEntryCount()
INonPluginEntry[] getNonPluginEntries()
SitemanagerINonPluginEntry[] getRawNonPluginEntries()
int getNonPluginEntryCount()
long getDownloadSize()
ContentEntryModel.UNKNOWN_SIZElong getInstallSize()
ContentEntryModel.UNKNOWN_SIZEboolean isPrimary()
true if this is a primary feature, 
 otherwise falseboolean isExclusive()
true if feature requires exclusive processing,
 false otherwise.String getApplication()
org.eclipse.core.runtime.applications extension point.nullString getAffinityFeature()
null.IFeatureContentProvider getFeatureContentProvider() throws CoreException
CoreExceptionIFeatureContentConsumer getFeatureContentConsumer() throws CoreException
CoreExceptionUnsupportedOperationExceptionvoid setSite(ISite site) throws CoreException
site - the siteCoreException - site for this feature is already setvoid setFeatureContentProvider(IFeatureContentProvider featureContentProvider)
featureContentProvider - content providerboolean isPatch()
true if this feature is patching another feature,
 false otherwiseGuidelines for using Eclipse APIs. Copyright (c) IBM Corp. and others 2000, 2006. All rights reserved.