From 29b53a2ae34b1c37a6087734795c4bf7d3646356 Mon Sep 17 00:00:00 2001 From: Mickael Istria Date: Tue, 10 Sep 2024 09:01:51 +0200 Subject: [PATCH] Revert "Force the DOM parser to continue with errors (#808)" The commit has caused several regressions for which a fix is yet to be found. Let's revert to keep the main branch as clean as possible and work on TolerantParser in a different PR. This reverts commit cb3c54ff805b938febe42cabb52e760df1614b29. --- .../dom/JavacCompilationUnitResolver.java | 2 - .../jdt/internal/javac/JavacCompiler.java | 45 ++++++++++- .../internal/javac/TolerantJavaCompiler.java | 76 ------------------- 3 files changed, 44 insertions(+), 79 deletions(-) delete mode 100644 org.eclipse.jdt.core.javac/src/org/eclipse/jdt/internal/javac/TolerantJavaCompiler.java diff --git a/org.eclipse.jdt.core.javac/src/org/eclipse/jdt/core/dom/JavacCompilationUnitResolver.java b/org.eclipse.jdt.core.javac/src/org/eclipse/jdt/core/dom/JavacCompilationUnitResolver.java index 825f641626b..bde8c148689 100644 --- a/org.eclipse.jdt.core.javac/src/org/eclipse/jdt/core/dom/JavacCompilationUnitResolver.java +++ b/org.eclipse.jdt.core.javac/src/org/eclipse/jdt/core/dom/JavacCompilationUnitResolver.java @@ -70,7 +70,6 @@ import org.eclipse.jdt.internal.core.util.BindingKeyParser; import org.eclipse.jdt.internal.javac.JavacProblemConverter; import org.eclipse.jdt.internal.javac.JavacUtils; -import org.eclipse.jdt.internal.javac.TolerantJavaCompiler; import org.eclipse.jdt.internal.javac.UnusedProblemFactory; import org.eclipse.jdt.internal.javac.UnusedTreeScanner; @@ -480,7 +479,6 @@ private Map result = new HashMap<>(sourceUnits.length, 1.f); Map filesToUnits = new HashMap<>(); final UnusedProblemFactory unusedProblemFactory = new UnusedProblemFactory(new DefaultProblemFactory(), compilerOptions); diff --git a/org.eclipse.jdt.core.javac/src/org/eclipse/jdt/internal/javac/JavacCompiler.java b/org.eclipse.jdt.core.javac/src/org/eclipse/jdt/internal/javac/JavacCompiler.java index 0ae2a89a050..6a1a16b738d 100644 --- a/org.eclipse.jdt.core.javac/src/org/eclipse/jdt/internal/javac/JavacCompiler.java +++ b/org.eclipse.jdt.core.javac/src/org/eclipse/jdt/internal/javac/JavacCompiler.java @@ -19,6 +19,7 @@ import java.util.List; import java.util.Map; import java.util.Map.Entry; +import java.util.Queue; import java.util.stream.Collectors; import java.util.stream.Stream; @@ -45,9 +46,12 @@ import org.eclipse.jdt.internal.core.builder.SourceFile; import com.sun.tools.javac.api.MultiTaskListener; +import com.sun.tools.javac.comp.*; import com.sun.tools.javac.comp.CompileStates.CompileState; import com.sun.tools.javac.main.JavaCompiler; +import com.sun.tools.javac.tree.JCTree.JCClassDecl; import com.sun.tools.javac.util.Context; +import com.sun.tools.javac.util.Pair; public class JavacCompiler extends Compiler { JavacConfig compilerConfig; @@ -113,7 +117,46 @@ public void compile(ICompilationUnit[] sourceUnits) { // Configure Javac to generate the class files in a mapped temporary location var outputDir = JavacClassFile.getMappedTempOutput(outputSourceSet.getKey()).toFile(); JavacUtils.configureJavacContext(javacContext, this.compilerConfig, javaProject, outputDir, true); - JavaCompiler javac = TolerantJavaCompiler.configureCompilerInstance(javacContext); + JavaCompiler javac = new JavaCompiler(javacContext) { + boolean isInGeneration = false; + + @Override + protected boolean shouldStop(CompileState cs) { + // Never stop + return false; + } + + @Override + public void generate(Queue, JCClassDecl>> queue, Queue results) { + try { + this.isInGeneration = true; + super.generate(queue, results); + } catch (Throwable ex) { + // TODO error handling + } finally { + this.isInGeneration = false; + } + } + + @Override + protected void desugar(Env env, Queue, JCClassDecl>> results) { + try { + super.desugar(env, results); + } catch (Throwable ex) { + // TODO error handling + } + } + + @Override + public int errorCount() { + // See JavaCompiler.genCode(Env env, JCClassDecl cdef), + // it stops writeClass if errorCount is not zero. + // Force it to return 0 if we are in generation phase, and keeping + // generating class files for those files without errors. + return this.isInGeneration ? 0 : super.errorCount(); + } + }; + javacContext.put(JavaCompiler.compilerKey, javac); javac.shouldStopPolicyIfError = CompileState.GENERATE; try { javac.compile(com.sun.tools.javac.util.List.from(outputSourceSet.getValue().stream() diff --git a/org.eclipse.jdt.core.javac/src/org/eclipse/jdt/internal/javac/TolerantJavaCompiler.java b/org.eclipse.jdt.core.javac/src/org/eclipse/jdt/internal/javac/TolerantJavaCompiler.java deleted file mode 100644 index 970ebae9fb4..00000000000 --- a/org.eclipse.jdt.core.javac/src/org/eclipse/jdt/internal/javac/TolerantJavaCompiler.java +++ /dev/null @@ -1,76 +0,0 @@ -/******************************************************************************* -* Copyright (c) 2024 Microsoft Corporation and others. -* All rights reserved. This program and the accompanying materials -* are made available under the terms of the Eclipse Public License 2.0 -* which accompanies this distribution, and is available at -* https://www.eclipse.org/legal/epl-2.0/ -* -* SPDX-License-Identifier: EPL-2.0 -* -* Contributors: -* Microsoft Corporation - initial API and implementation -*******************************************************************************/ - -package org.eclipse.jdt.internal.javac; - -import java.util.Queue; - -import javax.tools.JavaFileObject; - -import com.sun.tools.javac.comp.AttrContext; -import com.sun.tools.javac.comp.CompileStates.CompileState; -import com.sun.tools.javac.comp.Env; -import com.sun.tools.javac.main.JavaCompiler; -import com.sun.tools.javac.tree.JCTree.JCClassDecl; -import com.sun.tools.javac.util.Context; -import com.sun.tools.javac.util.Pair; - -public class TolerantJavaCompiler extends JavaCompiler { - boolean isInGeneration = false; - - public TolerantJavaCompiler(Context context) { - super(context); - } - - @Override - protected boolean shouldStop(CompileState cs) { - // Never stop - return false; - } - - @Override - public void generate(Queue, JCClassDecl>> queue, Queue results) { - try { - this.isInGeneration = true; - super.generate(queue, results); - } catch (Throwable ex) { - // TODO error handling - } finally { - this.isInGeneration = false; - } - } - - @Override - protected void desugar(Env env, Queue, JCClassDecl>> results) { - try { - super.desugar(env, results); - } catch (Throwable ex) { - // TODO error handling - } - } - - @Override - public int errorCount() { - // See JavaCompiler.genCode(Env env, JCClassDecl cdef), - // it stops writeClass if errorCount is not zero. - // Force it to return 0 if we are in generation phase, and keeping - // generating class files for those files without errors. - return this.isInGeneration ? 0 : super.errorCount(); - } - - public static JavaCompiler configureCompilerInstance(Context context) { - TolerantJavaCompiler javacCompiler = new TolerantJavaCompiler(context); - context.put(JavaCompiler.compilerKey, javacCompiler); - return javacCompiler; - } -}