|
Eclipse Platform Release 3.0 | ||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectorg.eclipse.core.internal.events.InternalBuilder
org.eclipse.core.resources.IncrementalProjectBuilder
The abstract base class for all incremental project builders. This class provides the infrastructure for defining a builder and fulfills the contract specified by the org.eclipse.core.resources.builders standard extension point.
All builders must subclass this class according to the following guidelines:
On creation, the setInitializationData method is called with any parameter data specified in the declaring plug-in's manifest.
Field Summary | |
static int | AUTO_BUILD
Build kind constant (value 9) indicating an automatic build request. |
static int | CLEAN_BUILD
Build kind constant (value 15) indicating a build clean request |
static int | FULL_BUILD
Build kind constant (value 6) indicating a full build request. |
static int | INCREMENTAL_BUILD
Build kind constant (value 10) indicating an incremental build request. |
Constructor Summary | |
IncrementalProjectBuilder()
|
Method Summary | |
protected abstract IProject[] | build(int kind,
Map args,
IProgressMonitor monitor)
Runs this builder in the specified manner. |
protected void | clean(IProgressMonitor monitor)
Clean is an opportunity for a builder to discard any additional state that has been computed as a result of previous builds. |
void | forgetLastBuiltState()
Requests that this builder forget any state it may be retaining regarding previously built states. |
IResourceDelta | getDelta(IProject project)
Returns the resource delta recording the changes in the given project since the last time this builder was run. |
IProject | getProject()
Returns the project for which this builder is defined. |
boolean | hasBeenBuilt(IProject project)
Returns whether the given project has already been built during this build iteration. |
boolean | isInterrupted()
Returns whether an interrupt request has been made for this build. |
void | needRebuild()
Indicates that this builder made changes that affect a project that preceeds this project in the currently executing build order, and thus a rebuild will be necessary. |
void | setInitializationData(IConfigurationElement config,
String propertyName,
Object data)
Sets initialization data for this builder. |
protected void | startupOnInitialize()
Informs this builder that it is being started by the build management infrastructure. |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
public static final int INCREMENTAL_BUILD
public static final int FULL_BUILD
public static final int AUTO_BUILD
public static final int CLEAN_BUILD
Constructor Detail |
public IncrementalProjectBuilder()
Method Detail |
protected abstract IProject[] build(int kind, Map args, IProgressMonitor monitor) throws CoreException
If the build kind is INCREMENTAL_BUILD or AUTO_BUILD, the getDelta method can be used during the invocation of this method to obtain information about what changes have occurred since the last invocation of this method. Any resource delta acquired is valid only for the duration of the invocation of this method.
After completing a build, this builder may return a list of projects for which it requires a resource delta the next time it is run. This builder's project is implicitly included and need not be specified. The build mechanism will attempt to maintain and compute deltas relative to the identified projects when asked the next time this builder is run. Builders must re-specify the list of interesting projects every time they are run as this is not carried forward beyond the next build. Projects mentioned in return value but which do not exist will be ignored and no delta will be made available for them.
This method is long-running; progress and cancellation are provided by the given progress monitor. All builders should report their progress and honor cancel requests in a timely manner. Cancelation requests should be propagated to the caller by throwing OperationCanceledException.
All builders should try to be robust in the face of trouble. In situations where failing the build by throwing CoreException is the only option, a builder has a choice of how best to communicate the problem back to the caller. One option is to use the BUILD_FAILED status code along with a suitable message; another is to use a multi-status containing finer-grained problem diagnoses.
protected void clean(IProgressMonitor monitor) throws CoreException
This method is called as a result of invocations of IWorkspace.build or IProject.build where the build kind is CLEAN_BUILD.
This default implementation does nothing. Subclasses may override.
This method is long-running; progress and cancellation are provided by the given progress monitor. All builders should report their progress and honor cancel requests in a timely manner. Cancelation requests should be propagated to the caller by throwing OperationCanceledException.
public final void forgetLastBuiltState()
public final IResourceDelta getDelta(IProject project)
The system reserves the right to trim old state in an effort to conserve space. As such, callers should be prepared to receive null even if they previously requested a delta for a particular project by returning that project from a build call.
A non- null delta will only be supplied for the given project if either the result returned from the previous build included the project or the project is the one associated with this builder.
If the given project was mentioned in the previous build and subsequently deleted, a non- null delta containing the deletion will be returned. If the given project was mentioned in the previous build and was subsequently created, the returned value will be null.
A valid delta will be returned only when this method is called during a build. The delta returned will be valid only for the duration of the enclosing build execution.
public final IProject getProject()
public final boolean hasBeenBuilt(IProject project)
When the entire workspace is being built, the projects are built in linear sequence. This method can be used to determine if another project preceeds this builder's project in that build sequence. If only a single project is being built, then there is no build order and this method will always return false.
public final boolean isInterrupted()
public final void needRebuild()
This is an advanced feature that builders should use with caution. This can cause workspace builds to iterate until no more builders require rebuilds.
public void setInitializationData(IConfigurationElement config, String propertyName, Object data) throws CoreException
This method is part of the IExecutableExtension interface.
Subclasses are free to extend this method to pick up initialization parameters from the plug-in plug-in manifest (plugin.xml) file, but should be sure to invoke this method on their superclass.
For example, the following method looks for a boolean-valued parameter named "trace":
public void setInitializationData(IConfigurationElement cfig, String propertyName, Object data) throws CoreException { super.setInitializationData(cfig, propertyName, data); if (data instanceof Hashtable) { Hashtable args = (Hashtable) data; String traceValue = (String) args.get("trace"); TRACING = (traceValue != null && traceValue.equals("true")); } }
protected void startupOnInitialize()
|
Eclipse Platform Release 3.0 | ||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
Guidelines for using Eclipse APIs.
Copyright (c) IBM Corp. and others 2000, 2004. All rights reserved.