本文整理匯總了Java中org.eclipse.core.resources.IncrementalProjectBuilder.FULL_BUILD屬性的典型用法代碼示例。如果您正苦於以下問題:Java IncrementalProjectBuilder.FULL_BUILD屬性的具體用法?Java IncrementalProjectBuilder.FULL_BUILD怎麽用?Java IncrementalProjectBuilder.FULL_BUILD使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類org.eclipse.core.resources.IncrementalProjectBuilder
的用法示例。
在下文中一共展示了IncrementalProjectBuilder.FULL_BUILD屬性的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: getParserForBuilder
/**
* @param buildType single element array; element may be altered to indicate
* actual required build type
*/
public static PgDbParser getParserForBuilder(IProject proj, int[] buildType) {
PgDbParser pnew = new PgDbParser();
PgDbParser p = PROJ_PARSERS.putIfAbsent(proj, pnew);
if (p == null) {
p = pnew;
// prepare newly created parser
ResourcesPlugin.getWorkspace().addResourceChangeListener(p,
IResourceChangeEvent.PRE_CLOSE | IResourceChangeEvent.PRE_DELETE);
if (buildType == null) {
// not a builder call, start builder
startBuildJob(proj);
} else {
// builder call, change build type to FULL for new parsers
buildType[0] = IncrementalProjectBuilder.FULL_BUILD;
}
}
return p;
}
示例2: build
@Override
protected IProject[] build(int kind, Map<String, String> args, IProgressMonitor monitor) throws CoreException {
if (AsciidocInstance.INSTANCE.getAsciidoctor() == null) {
return new IProject[0];
}
try {
if (kind == IncrementalProjectBuilder.FULL_BUILD) {
AsciidocBuildHelper.fullBuild(getProject(), monitor);
} else {
AsciidocBuildHelper.incrementalBuild(getProject(), getDelta(getProject()), monitor);
}
} catch (Exception e) {
Activator.getDefault().getLog().log(new Status(IStatus.ERROR, Activator.PLUGIN_ID, e.getMessage(), e));
}
return new IProject[0];
}
示例3: build
@Override
protected IProject[] build(int kind, Map<String, String> args, IProgressMonitor monitor) throws CoreException {
if (kind == IncrementalProjectBuilder.FULL_BUILD) {
fullBuild(monitor);
} else {
IResourceDelta delta = getDelta(getProject());
if (delta == null) {
fullBuild(monitor);
} else {
incrementalBuild(delta, monitor);
}
}
return null;
}
示例4: build
/**
* {@inheritDoc}
*/
@Override
protected IProject[] build(final int kind, final Map<String, String> args, final IProgressMonitor monitor) throws CoreException {
try {
final Optional<? extends FeedbackJavaProject> javaProjectOptional = this.getFeedbackJavaResourceFactory().create(getProject());
if (javaProjectOptional.isPresent()) {
final FeedbackJavaProject project = javaProjectOptional.get();
Logger.print(String.format("Triggered %S.", BuildTypes.INSTANCE.get(kind)));
if (kind == IncrementalProjectBuilder.FULL_BUILD || kind == IncrementalProjectBuilder.CLEAN_BUILD) {
fullBuild(project);
}
else {
incrementalBuild(project);
}
}
}
catch (final RequestException e) {
new RequestExceptionHandler().handle(getProject(), e);
}
return null;
}
示例5: build
@Override
protected IProject[] build(int kind, Map args, IProgressMonitor monitor) throws CoreException {
if (!PlatformUI.isWorkbenchRunning()) {
return new IProject[0];
}
IProject[] projects = null;
switch (kind) {
case IncrementalProjectBuilder.CLEAN_BUILD:
clean(monitor);
break;
case IncrementalProjectBuilder.FULL_BUILD:
projects = fullBuild(args, monitor);
break;
case IncrementalProjectBuilder.AUTO_BUILD:
case IncrementalProjectBuilder.INCREMENTAL_BUILD:
projects = incrementalBuild(args, monitor);
break;
}
return projects;
}
示例6: shouldBuild
protected boolean shouldBuild(int kind, IManagedBuildInfo info) {
IConfiguration cfg = info.getDefaultConfiguration();
IBuilder builder = null;
if (cfg != null) {
builder = cfg.getEditableBuilder();
switch (kind) {
case IncrementalProjectBuilder.AUTO_BUILD :
return true;
case IncrementalProjectBuilder.INCREMENTAL_BUILD : // now treated as the same!
case IncrementalProjectBuilder.FULL_BUILD :
return builder.isFullBuildEnabled() | builder.isIncrementalBuildEnabled() ;
case IncrementalProjectBuilder.CLEAN_BUILD :
return builder.isCleanBuildEnabled();
}
}
return true;
}
示例7: build
@Override
protected IProject[] build(final int kind, @SuppressWarnings("rawtypes") final Map args, final IProgressMonitor monitor) throws CoreException {
final IProject project = getProject();
monitor.beginTask("Building Apache Karaf project: " + project.getName(), 1);
try {
if (kind == IncrementalProjectBuilder.FULL_BUILD) {
fullBuild(monitor);
} else {
final IResourceDelta delta = getDelta(getProject());
if (delta == null) {
fullBuild(monitor);
} else {
incrementalBuild(delta, monitor);
}
}
getProject().refreshLocal(IResource.DEPTH_INFINITE, monitor);
} finally {
monitor.done();
}
return null;
}
示例8: build
@SuppressWarnings({ "unchecked", "rawtypes" })
@Override
protected IProject[] build(int kind, Map args, IProgressMonitor monitor)
throws CoreException {
IProject[] retval = super.build(kind, args, monitor);
if (kind == IncrementalProjectBuilder.FULL_BUILD) {
fullBuild(monitor);
} else {
IResourceDelta delta = getDelta(project);
if (delta == null) {
fullBuild(monitor);
} else {
incrementalBuild(delta, monitor);
}
}
return retval;
}
示例9: startBuildJob
private static void startBuildJob(IProject proj) {
BuildAction build = new BuildAction(
PlatformUI.getWorkbench().getActiveWorkbenchWindow(),
IncrementalProjectBuilder.FULL_BUILD);
build.selectionChanged(new StructuredSelection(proj));
build.runInBackground(null);
}
示例10: build
@Override
protected IProject[] build(int kind, Map args, IProgressMonitor monitor) {
if (kind == IncrementalProjectBuilder.FULL_BUILD) {
fullBuild(monitor);
} else {
IResourceDelta delta = getDelta(getProject());
if (delta == null) {
fullBuild(monitor);
} else {
incrementalBuild(delta, monitor);
}
}
return null;
}
示例11: build
protected IProject[] build(int kind, Map args, IProgressMonitor monitor) {
if (kind == IncrementalProjectBuilder.FULL_BUILD) {
build(monitor);
} else {
IResourceDelta delta = getDelta(getProject());
if (delta == null) {
build(monitor);
} else {
incrementalBuild(delta, monitor);
}
}
return null;
}
示例12: build
@SuppressWarnings("rawtypes")
@Override
protected IProject[] build(int kind, Map args, IProgressMonitor monitor) throws CoreException
{
traceParticipantsEnabled = IdeLog.isTraceEnabled(BuildPathCorePlugin.getDefault(),
IDebugScopes.BUILDER_PARTICIPANTS);
boolean logTraceEnabled = traceLoggingEnabled();
IProject project = getProjectHandle();
String projectName = project.getName();
long startTime = System.nanoTime();
SubMonitor sub = SubMonitor.convert(monitor, 100);
// Keep these build participant instances and use them in the build process, rather than grabbing new ones
// in sub-methods. We do pre- and post- setups on them, so we need to retain instances.
IBuildParticipantManager manager = getBuildParticipantManager();
if (manager == null)
{
return new IProject[0];
}
List<IBuildParticipant> participants = manager.getAllBuildParticipants();
participants = filterToEnabled(participants, project);
buildStarting(participants, kind, sub.newChild(10));
if (kind == IncrementalProjectBuilder.FULL_BUILD)
{
if (logTraceEnabled)
{
logTrace(MessageFormat.format(Messages.UnifiedBuilder_PerformingFullBuld, projectName));
}
fullBuild(participants, sub.newChild(80));
}
else
{
IResourceDelta delta = getResourceDelta();
if (delta == null)
{
if (logTraceEnabled)
{
logTrace(MessageFormat.format(Messages.UnifiedBuilder_PerformingFullBuildNullDelta, projectName));
}
fullBuild(participants, sub.newChild(80));
}
else
{
if (logTraceEnabled)
{
logTrace(MessageFormat.format(Messages.UnifiedBuilder_PerformingIncrementalBuild, projectName));
}
incrementalBuild(participants, delta, sub.newChild(80));
}
}
buildEnding(participants, sub.newChild(10));
if (logTraceEnabled)
{
double endTime = ((double) System.nanoTime() - startTime) / 1000000;
logTrace(MessageFormat.format(Messages.UnifiedBuilder_FinishedBuild, projectName, endTime));
}
return null;
}
示例13: build
/**
* Run the builder.
*
* @see IncrementalProjectBuilder#build
*/
@SuppressWarnings("rawtypes")
@Override
protected IProject[] build(int kind, Map args, IProgressMonitor monitor) throws CoreException {
monitor.subTask("Running FindBugs...");
switch (kind) {
case IncrementalProjectBuilder.FULL_BUILD: {
FindBugs2Eclipse.cleanClassClache(getProject());
if (FindbugsPlugin.getUserPreferences(getProject()).isRunAtFullBuild()) {
if (DEBUG) {
System.out.println("FULL BUILD");
}
doBuild(args, monitor, kind);
} else {
// TODO probably worth to cleanup?
// MarkerUtil.removeMarkers(getProject());
}
break;
}
case IncrementalProjectBuilder.INCREMENTAL_BUILD: {
if (DEBUG) {
System.out.println("INCREMENTAL BUILD");
}
doBuild(args, monitor, kind);
break;
}
case IncrementalProjectBuilder.AUTO_BUILD: {
if (DEBUG) {
System.out.println("AUTO BUILD");
}
doBuild(args, monitor, kind);
break;
}
default: {
FindbugsPlugin.getDefault()
.logWarning("UKNOWN BUILD kind" + kind);
doBuild(args, monitor, kind);
break;
}
}
return null;
}
示例14: doBuild
/**
* Performs the build process. This method gets all files in the current
* project and has a <code>FindBugsVisitor</code> run on them.
*
* @param args
* A <code>Map</code> containing additional build parameters.
* @param monitor
* The <code>IProgressMonitor</code> displaying the build
* progress.
* @param kind
* kind the kind of build being requested, see
* IncrementalProjectBuilder
* @throws CoreException
*/
private void doBuild(final Map<?, ?> args, final IProgressMonitor monitor, int kind) throws CoreException {
boolean incremental = (kind != IncrementalProjectBuilder.FULL_BUILD);
IProject project = getProject();
IResource resource = project;
List<WorkItem> files;
if (incremental) {
IResourceDelta resourceDelta = getDelta(project);
boolean configChanged = !isConfigUnchanged(resourceDelta);
boolean fullBuildEnabled = FindbugsPlugin.getCorePreferences(getProject(), configChanged).isRunAtFullBuild();
if (configChanged && fullBuildEnabled) {
files = new ArrayList<WorkItem>();
files.add(new WorkItem(project));
} else {
files = ResourceUtils.collectIncremental(resourceDelta);
/*
* Here we expect to have only ONE file as a result of a
* post-save trigger. In this case incremental builder should
* run and analyse 1 file again. For some reason, JDT uses
* "AUTO" kind for such incremental compile. Unfortunately,
* Eclipse also triggers "AUTO" build on startup, if it detects
* that some project files are changed (I think also on team
* update operations). This causes sometimes a real startup
* slowdown for workspaces with many projects. Because we cannot
* distinguish between first and second build, and if
* "fullBuildEnabled" id OFF, we will analyse incrementally ONLY
* ONE SINGLE FILE. This is not nice, but there is no other ways
* today... May be we can use preferences to define "how many"
* is "incremental"...
*/
if (files.size() > 1) {
if (DEBUG) {
FindbugsPlugin.getDefault()
.logInfo(
"Incremental builder: too many resources to analyse for project " + project + ", files: "
+ files);
}
return;
} else if(files.size() == 1){
IResource corespondingResource = files.get(0).getCorespondingResource();
if(corespondingResource != null) {
resource = corespondingResource;
}
}
}
} else {
files = new ArrayList<WorkItem>();
files.add(new WorkItem(project));
}
work(resource, files, monitor);
}