blob: 3f3e5b6950fb497cfb16d3ac3a502de11fcde312 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
/*******************************************************************************
* Copyright (c) 2007, 2018 Alphonse Van Assche and others.
*
* This program and the accompanying materials are made
* available under the terms of the Eclipse Public License 2.0
* which is available at https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* Alphonse Van Assche - initial API and implementation
*******************************************************************************/
package org.eclipse.linuxtools.internal.rpm.rpmlint.builder;
import java.util.List;
import java.util.Map;
import org.eclipse.core.resources.IProject;
import org.eclipse.core.resources.IResourceDelta;
import org.eclipse.core.resources.IncrementalProjectBuilder;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.OperationCanceledException;
import org.eclipse.linuxtools.internal.rpm.rpmlint.Activator;
import org.eclipse.linuxtools.internal.rpm.rpmlint.parser.RpmlintItem;
import org.eclipse.linuxtools.internal.rpm.rpmlint.parser.RpmlintParser;
/**
* Project builder responsible for invoking rpmlint and processing it's
* response.
*/
public class RpmlintBuilder extends IncrementalProjectBuilder {
/**
* Total number of chunks to divede the work in.
*/
public static final int MAX_WORKS = 100;
/**
* ID for this builder.
*/
public static final String BUILDER_ID = Activator.PLUGIN_ID + ".rpmlintBuilder"; //$NON-NLS-1$
/**
* ID for rpmlint marker problems.
*/
public static final String MARKER_ID = Activator.PLUGIN_ID + ".rpmlintProblem"; //$NON-NLS-1$
@Override
protected IProject[] build(int kind, Map<String, String> args, IProgressMonitor monitor) throws CoreException {
// TODO: handle the monitor in a more clean way.
monitor.beginTask(Messages.RpmlintBuilder_0, MAX_WORKS);
monitor.worked(20);
if (kind == FULL_BUILD) {
fullBuild(monitor);
} else {
IResourceDelta delta = getDelta(getProject());
if (delta == null) {
fullBuild(monitor);
} else {
incrementalBuild(delta, monitor);
}
}
return null;
}
private void fullBuild(IProgressMonitor monitor) throws CoreException {
RpmlintPreVisitor resourceVisitor = new RpmlintPreVisitor();
getProject().accept(resourceVisitor);
checkCancel(monitor);
monitor.worked(50);
monitor.setTaskName(Messages.RpmlintBuilder_1);
List<RpmlintItem> rpmlintItems = RpmlintParser.parseVisisted(resourceVisitor.getVisitedPaths());
visitAndMarkRpmlintItems(monitor, rpmlintItems);
}
private void incrementalBuild(IResourceDelta delta, IProgressMonitor monitor) throws CoreException {
RpmlintDeltaVisitor deltaVisitor = new RpmlintDeltaVisitor();
delta.accept(deltaVisitor);
monitor.worked(50);
monitor.setTaskName(Messages.RpmlintBuilder_1);
List<RpmlintItem> rpmlintItems = RpmlintParser.parseVisisted(deltaVisitor.getVisitedPaths());
visitAndMarkRpmlintItems(monitor, rpmlintItems);
}
private void visitAndMarkRpmlintItems(IProgressMonitor monitor, List<RpmlintItem> rpmlintItems)
throws CoreException {
if (rpmlintItems.size() > 0) {
checkCancel(monitor);
monitor.worked(70);
monitor.setTaskName(Messages.RpmlintBuilder_2);
getProject().accept(new RpmlintMarkerVisitor(rpmlintItems));
monitor.worked(MAX_WORKS);
}
}
private static void checkCancel(IProgressMonitor monitor) {
if (monitor.isCanceled()) {
throw new OperationCanceledException();
}
}
}
|