diff options
Diffstat (limited to 'jps/jps-builders/src/org/jetbrains/jps/incremental/fs/BuildFSState.java')
-rw-r--r-- | jps/jps-builders/src/org/jetbrains/jps/incremental/fs/BuildFSState.java | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/jps/jps-builders/src/org/jetbrains/jps/incremental/fs/BuildFSState.java b/jps/jps-builders/src/org/jetbrains/jps/incremental/fs/BuildFSState.java index e92c0d59a3b0..bb28c422044b 100644 --- a/jps/jps-builders/src/org/jetbrains/jps/incremental/fs/BuildFSState.java +++ b/jps/jps-builders/src/org/jetbrains/jps/incremental/fs/BuildFSState.java @@ -145,13 +145,17 @@ public class BuildFSState extends FSState { setRoundDelta(CURRENT_ROUND_DELTA_KEY, context, new FilesDelta()); } - public <R extends BuildRootDescriptor, T extends BuildTarget<R>> boolean processFilesToRecompile(CompileContext context, final T target, final FileProcessor<R, T> processor) throws IOException { + public <R extends BuildRootDescriptor, T extends BuildTarget<R>> boolean processFilesToRecompile(CompileContext context, final @NotNull T target, final FileProcessor<R, T> processor) throws IOException { final Map<BuildRootDescriptor, Set<File>> data = getSourcesToRecompile(context, target); final CompileScope scope = context.getScope(); synchronized (data) { for (Map.Entry<BuildRootDescriptor, Set<File>> entry : data.entrySet()) { //noinspection unchecked R root = (R)entry.getKey(); + if (!target.equals(root.getTarget())) { + // the data can contain roots from other targets (e.g. when compiling module cycles) + continue; + } for (File file : entry.getValue()) { if (!scope.isAffected(target, file)) { continue; |