blob: d9c11d57a1a5f7cb5419d4cd3c0e098f33066d52 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2005, 2009 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:
* mkaufman@bea.com - initial API as ICompilationParticipant
* IBM - changed from interface ICompilationParticipant to abstract class CompilationParticipant
* IBM - rewrote specification
*
*******************************************************************************/
package org.eclipse.jdt.core.compiler;
import org.eclipse.jdt.core.IJavaProject;
/**
* A compilation participant is notified of events occuring during the compilation process.
* The compilation process not only involves generating .class files (i.e. building), it also involves
* cleaning the output directory, reconciling a working copy, etc.
* So the notified events are the result of a build action, a clean action, a reconcile operation
* (for a working copy), etc.
* <p>
* Code that participates in the build should in general be implemented with a separate Builder,
* rather than a CompilationParticipant. It is only necessary to use a CompilationParticipant if
* the build step needs to interact with the Java build, for instance by creating additional
* Java source files that must themselves in turn be compiled.
* <p>
* Clients wishing to participate in the compilation process must subclass this class, and implement
* {@link #isActive(IJavaProject)}, {@link #aboutToBuild(IJavaProject)},
* {@link #reconcile(ReconcileContext)}, etc.
* </p><p>
* This class is intended to be subclassed by clients.
* </p>
* @since 3.2
*/
public abstract class CompilationParticipant {
public final static int READY_FOR_BUILD = 1;
public final static int NEEDS_FULL_BUILD = 2;
/**
* Notifies this participant that a build is about to start and provides it the opportunity to
* create missing source folders for generated source files. Additional source folders
* should be marked as optional so the project can be built when the folders do not exist.
* Only sent to participants interested in the project.
* <p>
* Default is to return <code>READY_FOR_BUILD</code>.
* </p>
* @see #buildFinished(IJavaProject project)
* @param project the project about to build
* @return READY_FOR_BUILD or NEEDS_FULL_BUILD
*/
public int aboutToBuild(IJavaProject project) {
return READY_FOR_BUILD;
}
/**
* Notifies this participant that a build has finished for the project.
* This will be sent, even if buildStarting() was not sent when no source files needed to be compiled
* or the build failed.
* Only sent to participants interested in the project.
* @param project the project about to build
* @since 3.4
*/
public void buildFinished(IJavaProject project) {
// do nothing by default
}
/**
* Notifies this participant that a compile operation is about to start and provides it the opportunity to
* generate source files based on the source files about to be compiled.
* When isBatchBuild is true, then files contains all source files in the project.
* Only sent to participants interested in the current build project.
*
* @param files is an array of BuildContext
* @param isBatch identifies when the build is a batch build
*/
public void buildStarting(BuildContext[] files, boolean isBatch) {
// do nothing by default
}
/**
* Notifies this participant that a clean is about to start and provides it the opportunity to
* delete generated source files.
* Only sent to participants interested in the project.
* @param project the project about to be cleaned
*/
public void cleanStarting(IJavaProject project) {
// do nothing by default
}
/**
* Returns whether this participant is active for a given project.
* <p>
* Default is to return <code>false</code>.
* </p><p>
* For efficiency, participants that are not interested in the
* given project should return <code>false</code> for that project.
* </p>
* @param project the project to participate in
* @return whether this participant is active for a given project
*/
public boolean isActive(IJavaProject project) {
return false;
}
/**
* Returns whether this participant is interested in only Annotations.
* <p>
* Default is to return <code>false</code>.
* </p>
* @return whether this participant is interested in only Annotations.
*/
public boolean isAnnotationProcessor() {
return false;
}
/**
* Notifies this participant that a compile operation has found source files using Annotations.
* Only sent to participants interested in the current build project that answer true to isAnnotationProcessor().
* Each BuildContext was informed whether its source file currently hasAnnotations().
*
* @param files is an array of BuildContext
*/
public void processAnnotations(BuildContext[] files) {
// do nothing by default
}
/**
* Notifies this participant that a reconcile operation is happening. The participant can act on this reconcile
* operation by using the given context. Other participant can then see the result of this participation
* on this context.
* <p>
* Note that a participant should not modify the buffer of the working copy that is being reconciled.
* </p><p>
* Default is to do nothing.
* </p>
* @param context the reconcile context to act on
*/
public void reconcile(ReconcileContext context) {
// do nothing by default
}
}