diff --git a/org.eclipse.jdt.bcoview/pom.xml b/org.eclipse.jdt.bcoview/pom.xml
index acb05a03870..1d8ea8a1408 100644
--- a/org.eclipse.jdt.bcoview/pom.xml
+++ b/org.eclipse.jdt.bcoview/pom.xml
@@ -14,7 +14,7 @@
eclipse.jdt.ui
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
org.eclipse.jdt
org.eclipse.jdt.bcoview
diff --git a/org.eclipse.jdt.core.manipulation/common/org/eclipse/jdt/internal/ui/fix/RenameUnusedVariableCleanUpCore.java b/org.eclipse.jdt.core.manipulation/common/org/eclipse/jdt/internal/ui/fix/RenameUnusedVariableCleanUpCore.java
index f65c9f59a8a..f2e6a63809d 100644
--- a/org.eclipse.jdt.core.manipulation/common/org/eclipse/jdt/internal/ui/fix/RenameUnusedVariableCleanUpCore.java
+++ b/org.eclipse.jdt.core.manipulation/common/org/eclipse/jdt/internal/ui/fix/RenameUnusedVariableCleanUpCore.java
@@ -26,14 +26,11 @@
import org.eclipse.jdt.core.JavaCore;
import org.eclipse.jdt.core.compiler.IProblem;
import org.eclipse.jdt.core.dom.CompilationUnit;
-import org.eclipse.jdt.core.dom.Pattern;
import org.eclipse.jdt.core.dom.SimpleName;
-import org.eclipse.jdt.core.dom.SingleVariableDeclaration;
import org.eclipse.jdt.internal.corext.fix.CleanUpConstants;
import org.eclipse.jdt.internal.corext.fix.RenameUnusedVariableFixCore;
import org.eclipse.jdt.internal.corext.fix.UnusedCodeFixCore;
-import org.eclipse.jdt.internal.corext.util.JavaModelUtil;
import org.eclipse.jdt.ui.cleanup.CleanUpRequirements;
import org.eclipse.jdt.ui.cleanup.ICleanUpFix;
@@ -150,9 +147,7 @@ public int computeNumberOfFixes(CompilationUnit compilationUnit) {
if (id == IProblem.LocalVariableIsNeverUsed) {
ProblemLocation location= new ProblemLocation(problem);
SimpleName name= UnusedCodeFixCore.getUnusedName(compilationUnit, location);
- if (JavaModelUtil.is22OrHigher(compilationUnit.getJavaElement().getJavaProject()) &&
- name.getParent() instanceof SingleVariableDeclaration nameParent &&
- nameParent.getParent() instanceof Pattern) {
+ if (RenameUnusedVariableFixCore.canRenameToUnnamedVariable(compilationUnit, name)) {
result++;
}
} else if (id == IProblem.LambdaParameterIsNeverUsed) {
diff --git a/org.eclipse.jdt.core.manipulation/common/org/eclipse/jdt/internal/ui/fix/UnusedCodeCleanUpCore.java b/org.eclipse.jdt.core.manipulation/common/org/eclipse/jdt/internal/ui/fix/UnusedCodeCleanUpCore.java
index 5dfcc4bfa6f..21b0f6e0545 100644
--- a/org.eclipse.jdt.core.manipulation/common/org/eclipse/jdt/internal/ui/fix/UnusedCodeCleanUpCore.java
+++ b/org.eclipse.jdt.core.manipulation/common/org/eclipse/jdt/internal/ui/fix/UnusedCodeCleanUpCore.java
@@ -26,13 +26,11 @@
import org.eclipse.jdt.core.JavaCore;
import org.eclipse.jdt.core.compiler.IProblem;
import org.eclipse.jdt.core.dom.CompilationUnit;
-import org.eclipse.jdt.core.dom.Pattern;
import org.eclipse.jdt.core.dom.SimpleName;
-import org.eclipse.jdt.core.dom.SingleVariableDeclaration;
import org.eclipse.jdt.internal.corext.fix.CleanUpConstants;
+import org.eclipse.jdt.internal.corext.fix.RenameUnusedVariableFixCore;
import org.eclipse.jdt.internal.corext.fix.UnusedCodeFixCore;
-import org.eclipse.jdt.internal.corext.util.JavaModelUtil;
import org.eclipse.jdt.ui.cleanup.CleanUpRequirements;
import org.eclipse.jdt.ui.cleanup.ICleanUpFix;
@@ -277,9 +275,7 @@ public int computeNumberOfFixes(CompilationUnit compilationUnit) {
if (id == IProblem.LocalVariableIsNeverUsed) {
ProblemLocation location= new ProblemLocation(problem);
SimpleName name= UnusedCodeFixCore.getUnusedName(compilationUnit, location);
- if (!JavaModelUtil.is22OrHigher(compilationUnit.getJavaElement().getJavaProject()) ||
- !(name.getParent() instanceof SingleVariableDeclaration nameParent) ||
- !(nameParent.getParent() instanceof Pattern)) {
+ if (!RenameUnusedVariableFixCore.canRenameToUnnamedVariable(compilationUnit, name)) {
result++;
}
}
diff --git a/org.eclipse.jdt.core.manipulation/core extension/org/eclipse/jdt/internal/corext/fix/RenameUnusedVariableFixCore.java b/org.eclipse.jdt.core.manipulation/core extension/org/eclipse/jdt/internal/corext/fix/RenameUnusedVariableFixCore.java
index ea84dca4965..b7adc600cb9 100644
--- a/org.eclipse.jdt.core.manipulation/core extension/org/eclipse/jdt/internal/corext/fix/RenameUnusedVariableFixCore.java
+++ b/org.eclipse.jdt.core.manipulation/core extension/org/eclipse/jdt/internal/corext/fix/RenameUnusedVariableFixCore.java
@@ -28,6 +28,7 @@
import org.eclipse.jdt.core.dom.ASTNode;
import org.eclipse.jdt.core.dom.CompilationUnit;
import org.eclipse.jdt.core.dom.EnhancedForStatement;
+import org.eclipse.jdt.core.dom.ForStatement;
import org.eclipse.jdt.core.dom.IBinding;
import org.eclipse.jdt.core.dom.IVariableBinding;
import org.eclipse.jdt.core.dom.LambdaExpression;
@@ -35,10 +36,11 @@
import org.eclipse.jdt.core.dom.Pattern;
import org.eclipse.jdt.core.dom.SimpleName;
import org.eclipse.jdt.core.dom.SingleVariableDeclaration;
+import org.eclipse.jdt.core.dom.TryStatement;
+import org.eclipse.jdt.core.dom.VariableDeclarationExpression;
import org.eclipse.jdt.core.dom.VariableDeclarationFragment;
import org.eclipse.jdt.core.dom.rewrite.ASTRewrite;
-import org.eclipse.jdt.internal.corext.dom.ASTNodes;
import org.eclipse.jdt.internal.corext.refactoring.structure.CompilationUnitRewrite;
import org.eclipse.jdt.internal.corext.util.JavaModelUtil;
@@ -78,15 +80,10 @@ public static RenameUnusedVariableFixCore createRenameToUnnamedFix(CompilationUn
if (name != null) {
IBinding binding= name.resolveBinding();
if (binding != null) {
- if (JavaModelUtil.is22OrHigher(compilationUnit.getJavaElement().getJavaProject())) {
- if (name.getParent() instanceof SingleVariableDeclaration parent &&
- parent.getParent() instanceof Pattern ||
- name.getParent() instanceof VariableDeclarationFragment parent2 &&
- parent2.getParent() instanceof LambdaExpression) {
- String label= FixMessages.UnusedCodeFix_RenameToUnnamedVariable_description;
- RenameToUnnamedVariableOperation operation= new RenameToUnnamedVariableOperation(name);
- return new RenameUnusedVariableFixCore(label, compilationUnit, new CompilationUnitRewriteOperation[] { operation }, getCleanUpOptions());
- }
+ if (canRenameToUnnamedVariable(compilationUnit, name)) {
+ String label= FixMessages.UnusedCodeFix_RenameToUnnamedVariable_description;
+ RenameToUnnamedVariableOperation operation= new RenameToUnnamedVariableOperation(name);
+ return new RenameUnusedVariableFixCore(label, compilationUnit, new CompilationUnitRewriteOperation[] { operation }, getCleanUpOptions());
}
}
}
@@ -131,16 +128,8 @@ public static ICleanUpFix createCleanUp(CompilationUnit compilationUnit, IProble
if (name != null) {
IBinding binding= name.resolveBinding();
if (binding instanceof IVariableBinding) {
- VariableDeclarationFragment parent= ASTNodes.getParent(name, VariableDeclarationFragment.class);
- if (parent == null || id == IProblem.LambdaParameterIsNeverUsed) {
- if (JavaModelUtil.is22OrHigher(compilationUnit.getJavaElement().getJavaProject())) {
- if (name.getParent() instanceof SingleVariableDeclaration nameParent &&
- nameParent.getParent() instanceof Pattern ||
- name.getParent() instanceof VariableDeclarationFragment varFragment &&
- varFragment.getParent() instanceof LambdaExpression) {
- result.add(new RenameToUnnamedVariableOperation(name));
- }
- }
+ if (canRenameToUnnamedVariable(compilationUnit, name)) {
+ result.add(new RenameToUnnamedVariableOperation(name));
}
}
}
@@ -153,8 +142,23 @@ public static ICleanUpFix createCleanUp(CompilationUnit compilationUnit, IProble
return new RenameUnusedVariableFixCore(FixMessages.UnusedCodeFix_change_name, compilationUnit, result.toArray(new CompilationUnitRewriteOperation[result.size()]));
}
- public static boolean isFormalParameterInEnhancedForStatement(SimpleName name) {
- return name.getParent() instanceof SingleVariableDeclaration && name.getParent().getLocationInParent() == EnhancedForStatement.PARAMETER_PROPERTY;
+ public static boolean canRenameToUnnamedVariable(CompilationUnit compilationUnit, SimpleName name) {
+ if (JavaModelUtil.is22OrHigher(compilationUnit.getJavaElement().getJavaProject())) {
+ if (name.getParent() instanceof SingleVariableDeclaration nameParent) {
+ if (nameParent.getParent() instanceof Pattern || nameParent.getParent() instanceof EnhancedForStatement) {
+ return true;
+ }
+ } else if (name.getParent() instanceof VariableDeclarationFragment varFragment) {
+ if (varFragment.getParent() instanceof LambdaExpression) {
+ return true;
+ } else if (varFragment.getParent() instanceof VariableDeclarationExpression varFragmentParent) {
+ if (varFragmentParent.getParent() instanceof TryStatement || varFragmentParent.getParent() instanceof ForStatement) {
+ return true;
+ }
+ }
+ }
+ }
+ return false;
}
public static SimpleName getUnusedName(CompilationUnit compilationUnit, IProblemLocation problem) {
diff --git a/org.eclipse.jdt.core.manipulation/core extension/org/eclipse/jdt/internal/corext/fix/UnusedCodeFixCore.java b/org.eclipse.jdt.core.manipulation/core extension/org/eclipse/jdt/internal/corext/fix/UnusedCodeFixCore.java
index 2d87696ef2d..21770ea24fe 100644
--- a/org.eclipse.jdt.core.manipulation/core extension/org/eclipse/jdt/internal/corext/fix/UnusedCodeFixCore.java
+++ b/org.eclipse.jdt.core.manipulation/core extension/org/eclipse/jdt/internal/corext/fix/UnusedCodeFixCore.java
@@ -65,7 +65,6 @@
import org.eclipse.jdt.core.dom.Modifier;
import org.eclipse.jdt.core.dom.NodeFinder;
import org.eclipse.jdt.core.dom.ParenthesizedExpression;
-import org.eclipse.jdt.core.dom.Pattern;
import org.eclipse.jdt.core.dom.PostfixExpression;
import org.eclipse.jdt.core.dom.PrefixExpression;
import org.eclipse.jdt.core.dom.QualifiedName;
@@ -90,7 +89,6 @@
import org.eclipse.jdt.internal.corext.dom.ReplaceRewrite;
import org.eclipse.jdt.internal.corext.dom.StatementRewrite;
import org.eclipse.jdt.internal.corext.refactoring.structure.CompilationUnitRewrite;
-import org.eclipse.jdt.internal.corext.util.JavaModelUtil;
import org.eclipse.jdt.internal.corext.util.Messages;
import org.eclipse.jdt.ui.cleanup.CleanUpOptions;
@@ -930,7 +928,7 @@ public static ICleanUpFix createCleanUp(CompilationUnit compilationUnit, IProble
if ((removeUnusedLocalVariables && id == IProblem.LocalVariableIsNeverUsed) || (removeUnusedPrivateFields && id == IProblem.UnusedPrivateField)) {
SimpleName name= getUnusedName(compilationUnit, problem);
- if (name != null) {
+ if (name != null && !RenameUnusedVariableFixCore.canRenameToUnnamedVariable(compilationUnit, name)) {
IBinding binding= name.resolveBinding();
if (binding instanceof IVariableBinding && !isFormalParameterInEnhancedForStatement(name) && (!((IVariableBinding) binding).isField() || isSideEffectFree(name, compilationUnit))) {
VariableDeclarationFragment parent= ASTNodes.getParent(name, VariableDeclarationFragment.class);
@@ -941,16 +939,7 @@ public static ICleanUpFix createCleanUp(CompilationUnit compilationUnit, IProble
}
variableDeclarations.get(varDecl).add(name);
} else {
- if (id == IProblem.LocalVariableIsNeverUsed) {
- SimpleName nameNode= UnusedCodeFixCore.getUnusedName(compilationUnit, problem);
- if (!JavaModelUtil.is22OrHigher(compilationUnit.getJavaElement().getJavaProject()) ||
- !(nameNode.getParent() instanceof SingleVariableDeclaration nameParent) ||
- !(nameParent.getParent() instanceof Pattern)) {
- result.add(new RemoveUnusedMemberOperation(new SimpleName[] { name }, false));
- }
- } else {
- result.add(new RemoveUnusedMemberOperation(new SimpleName[] { name }, false));
- }
+ result.add(new RemoveUnusedMemberOperation(new SimpleName[] { name }, false));
}
}
}
diff --git a/org.eclipse.jdt.junit.runtime/pom.xml b/org.eclipse.jdt.junit.runtime/pom.xml
index 2ed1065d40a..d1add87a0e4 100644
--- a/org.eclipse.jdt.junit.runtime/pom.xml
+++ b/org.eclipse.jdt.junit.runtime/pom.xml
@@ -14,7 +14,7 @@
eclipse.jdt.ui
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
org.eclipse.jdt
org.eclipse.jdt.junit.runtime
diff --git a/org.eclipse.jdt.junit/META-INF/MANIFEST.MF b/org.eclipse.jdt.junit/META-INF/MANIFEST.MF
index 03b2f8832c5..6d7694d24c7 100644
--- a/org.eclipse.jdt.junit/META-INF/MANIFEST.MF
+++ b/org.eclipse.jdt.junit/META-INF/MANIFEST.MF
@@ -3,7 +3,7 @@ Automatic-Module-Name: org.eclipse.jdt.junit
Bundle-ManifestVersion: 2
Bundle-Name: %pluginName
Bundle-SymbolicName: org.eclipse.jdt.junit;singleton:=true
-Bundle-Version: 3.16.600.qualifier
+Bundle-Version: 3.16.700.qualifier
Bundle-Activator: org.eclipse.jdt.internal.junit.ui.JUnitPlugin
Bundle-ActivationPolicy: lazy
Bundle-Vendor: %providerName
diff --git a/org.eclipse.jdt.junit/icons/full/etool16/run_exc.png b/org.eclipse.jdt.junit/icons/full/etool16/run_exc.png
index 08571c1f22e..6c3191d6965 100644
Binary files a/org.eclipse.jdt.junit/icons/full/etool16/run_exc.png and b/org.eclipse.jdt.junit/icons/full/etool16/run_exc.png differ
diff --git a/org.eclipse.jdt.junit/icons/full/etool16/run_exc@2x.png b/org.eclipse.jdt.junit/icons/full/etool16/run_exc@2x.png
index 156df21c3f4..2fa5cf5c6c6 100644
Binary files a/org.eclipse.jdt.junit/icons/full/etool16/run_exc@2x.png and b/org.eclipse.jdt.junit/icons/full/etool16/run_exc@2x.png differ
diff --git a/org.eclipse.jdt.junit4.runtime/pom.xml b/org.eclipse.jdt.junit4.runtime/pom.xml
index 82b597ed832..635a3a084ce 100644
--- a/org.eclipse.jdt.junit4.runtime/pom.xml
+++ b/org.eclipse.jdt.junit4.runtime/pom.xml
@@ -14,7 +14,7 @@
eclipse.jdt.ui
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
org.eclipse.jdt
org.eclipse.jdt.junit4.runtime
diff --git a/org.eclipse.jdt.junit5.runtime/pom.xml b/org.eclipse.jdt.junit5.runtime/pom.xml
index 9dc9f8a02dc..a1005dfe022 100644
--- a/org.eclipse.jdt.junit5.runtime/pom.xml
+++ b/org.eclipse.jdt.junit5.runtime/pom.xml
@@ -14,7 +14,7 @@
eclipse.jdt.ui
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
org.eclipse.jdt
org.eclipse.jdt.junit5.runtime
diff --git a/org.eclipse.jdt.text.tests/pom.xml b/org.eclipse.jdt.text.tests/pom.xml
index b0fb8632da0..67c19fdd529 100644
--- a/org.eclipse.jdt.text.tests/pom.xml
+++ b/org.eclipse.jdt.text.tests/pom.xml
@@ -15,7 +15,7 @@
tests-pom
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
../tests-pom/
org.eclipse.jdt
diff --git a/org.eclipse.jdt.ui.examples.projects/pom.xml b/org.eclipse.jdt.ui.examples.projects/pom.xml
index ee337f075e6..c7a04b10965 100644
--- a/org.eclipse.jdt.ui.examples.projects/pom.xml
+++ b/org.eclipse.jdt.ui.examples.projects/pom.xml
@@ -11,7 +11,7 @@
eclipse.jdt.ui
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
org.eclipse.jdt
org.eclipse.jdt.ui.examples.projects
diff --git a/org.eclipse.jdt.ui.junit.sampleproject/pom.xml b/org.eclipse.jdt.ui.junit.sampleproject/pom.xml
index 67a70d1c649..4f6b87738cc 100644
--- a/org.eclipse.jdt.ui.junit.sampleproject/pom.xml
+++ b/org.eclipse.jdt.ui.junit.sampleproject/pom.xml
@@ -19,7 +19,7 @@
eclipse.jdt.ui
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
org.eclipse.jdt.ui
org.eclipse.jdt.ui.junit.sampleproject
diff --git a/org.eclipse.jdt.ui.tests.refactoring/pom.xml b/org.eclipse.jdt.ui.tests.refactoring/pom.xml
index f64248519cd..ea744d4d55d 100644
--- a/org.eclipse.jdt.ui.tests.refactoring/pom.xml
+++ b/org.eclipse.jdt.ui.tests.refactoring/pom.xml
@@ -14,7 +14,7 @@
tests-pom
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
../tests-pom/
org.eclipse.jdt
diff --git a/org.eclipse.jdt.ui.tests/leaks/org/eclipse/jdt/ui/leaktest/reftracker/ReferenceTracker.java b/org.eclipse.jdt.ui.tests/leaks/org/eclipse/jdt/ui/leaktest/reftracker/ReferenceTracker.java
index cf8ac221d6c..49daa9fd2b3 100644
--- a/org.eclipse.jdt.ui.tests/leaks/org/eclipse/jdt/ui/leaktest/reftracker/ReferenceTracker.java
+++ b/org.eclipse.jdt.ui.tests/leaks/org/eclipse/jdt/ui/leaktest/reftracker/ReferenceTracker.java
@@ -81,6 +81,11 @@ private void followFieldReference(ReferencedObject ref, Object curr, Field fld)
if (fieldVal != null) {
fQueue.add(new ReferencedFieldElement(ref, fld, fieldVal));
}
+ } catch (IllegalArgumentException e) {
+ // XXX workaround for error in JDK: https://bugs.openjdk.org/browse/JDK-8337622
+ if (!"Can not get final java.lang.Class field java.lang.Class.componentType on java.lang.Class".equals(e.getMessage())) {
+ throw e;
+ }
} catch (IllegalAccessException e) {
handleError(e, fld);
}
diff --git a/org.eclipse.jdt.ui.tests/pom.xml b/org.eclipse.jdt.ui.tests/pom.xml
index 5cb5abdc32a..a08ead2af49 100644
--- a/org.eclipse.jdt.ui.tests/pom.xml
+++ b/org.eclipse.jdt.ui.tests/pom.xml
@@ -15,7 +15,7 @@
tests-pom
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
../tests-pom/
org.eclipse.jdt
diff --git a/org.eclipse.jdt.ui.tests/ui/org/eclipse/jdt/ui/tests/quickfix/AssistQuickFixTest12.java b/org.eclipse.jdt.ui.tests/ui/org/eclipse/jdt/ui/tests/quickfix/AssistQuickFixTest12.java
index 9a634ca7551..a6b1707192c 100644
--- a/org.eclipse.jdt.ui.tests/ui/org/eclipse/jdt/ui/tests/quickfix/AssistQuickFixTest12.java
+++ b/org.eclipse.jdt.ui.tests/ui/org/eclipse/jdt/ui/tests/quickfix/AssistQuickFixTest12.java
@@ -1,5 +1,5 @@
/*******************************************************************************
- * Copyright (c) 2019, 2020 IBM Corporation and others.
+ * Copyright (c) 2019, 2024 IBM Corporation and others.
*
* This program and the accompanying materials
* are made available under the terms of the Eclipse Public License 2.0
@@ -126,7 +126,7 @@ enum Day {
public void testSplitSwitchCaseLabelRuleStatement() throws Exception {
fJProject1= JavaProjectHelper.createJavaProject("TestProject1", "bin");
fJProject1.setRawClasspath(projectSetup.getDefaultClasspath(), null);
- JavaProjectHelper.set12CompilerOptions(fJProject1, true);
+ JavaProjectHelper.set14CompilerOptions(fJProject1, true);
fSourceFolder= JavaProjectHelper.addSourceContainer(fJProject1, "src");
String str= """
diff --git a/org.eclipse.jdt.ui.tests/ui/org/eclipse/jdt/ui/tests/quickfix/QuickFixTest22.java b/org.eclipse.jdt.ui.tests/ui/org/eclipse/jdt/ui/tests/quickfix/QuickFixTest22.java
index 2eb15307d38..c9f54966ee4 100644
--- a/org.eclipse.jdt.ui.tests/ui/org/eclipse/jdt/ui/tests/quickfix/QuickFixTest22.java
+++ b/org.eclipse.jdt.ui.tests/ui/org/eclipse/jdt/ui/tests/quickfix/QuickFixTest22.java
@@ -173,4 +173,161 @@ case R(_, long _) -> {}
assertEqualString(preview1, expected1);
}
+ @Test
+ public void testRenameToUnnamedProposal3() throws Exception {
+ fJProject1= JavaProjectHelper.createJavaProject("TestProject1", "bin");
+ fJProject1.setRawClasspath(projectsetup.getDefaultClasspath(), null);
+ JavaProjectHelper.set22CompilerOptions(fJProject1);
+
+ fSourceFolder= JavaProjectHelper.addSourceContainer(fJProject1, "src");
+ IPackageFragment pack1= fSourceFolder.createPackageFragment("test", false, null);
+
+ String test= """
+ package test;
+
+ public class Unused {
+
+ public static void main(String[] args) {
+ for (String arg : args) {
+ System.out.println("abc");
+ }
+ }
+ }
+ """;
+
+ ICompilationUnit cu= pack1.createCompilationUnit("Unused.java", test, false, null);
+
+ CompilationUnit astRoot= getASTRoot(cu);
+ ArrayList proposals= collectCorrections(cu, astRoot, 1);
+ assertCorrectLabels(proposals);
+
+ CUCorrectionProposal proposal1= (CUCorrectionProposal) proposals.get(0);
+ String preview1= getPreviewContent(proposal1);
+
+ String expected1= """
+ package test;
+
+ public class Unused {
+
+ public static void main(String[] args) {
+ for (String _ : args) {
+ System.out.println("abc");
+ }
+ }
+ }
+ """;
+
+ assertEqualString(preview1, expected1);
+ }
+
+ @Test
+ public void testRenameToUnnamedProposal4() throws Exception {
+ fJProject1= JavaProjectHelper.createJavaProject("TestProject1", "bin");
+ fJProject1.setRawClasspath(projectsetup.getDefaultClasspath(), null);
+ JavaProjectHelper.set22CompilerOptions(fJProject1);
+
+ fSourceFolder= JavaProjectHelper.addSourceContainer(fJProject1, "src");
+ IPackageFragment pack1= fSourceFolder.createPackageFragment("test", false, null);
+
+ String test= """
+ package test;
+ import java.io.FileInputStream;
+
+ public class Unused {
+
+ public static void main(String[] args) {
+ try (FileInputStream x = new FileInputStream("a.b")) {
+ System.out.println("abc");
+ } catch (Exception e) {
+ }
+ }
+ }
+ """;
+
+ ICompilationUnit cu= pack1.createCompilationUnit("Unused.java", test, false, null);
+
+ CompilationUnit astRoot= getASTRoot(cu);
+ ArrayList proposals= collectCorrections(cu, astRoot, 1);
+ assertCorrectLabels(proposals);
+
+ CUCorrectionProposal proposal1= (CUCorrectionProposal) proposals.get(0);
+ String preview1= getPreviewContent(proposal1);
+
+ String expected1= """
+ package test;
+ import java.io.FileInputStream;
+
+ public class Unused {
+
+ public static void main(String[] args) {
+ try (FileInputStream _ = new FileInputStream("a.b")) {
+ System.out.println("abc");
+ } catch (Exception e) {
+ }
+ }
+ }
+ """;
+
+ assertEqualString(preview1, expected1);
+ }
+
+ @Test
+ public void testRenameToUnnamedProposal5() throws Exception {
+ fJProject1= JavaProjectHelper.createJavaProject("TestProject1", "bin");
+ fJProject1.setRawClasspath(projectsetup.getDefaultClasspath(), null);
+ JavaProjectHelper.set22CompilerOptions(fJProject1);
+
+ fSourceFolder= JavaProjectHelper.addSourceContainer(fJProject1, "src");
+ IPackageFragment pack1= fSourceFolder.createPackageFragment("test", false, null);
+
+ String test= """
+ package test;
+
+ public class Unused {
+
+ private static int x = 1;
+
+ private static int sideEffect() {
+ return ++x;
+ }
+
+ public static void main(String[] args) {
+ for (int i = 0, se = sideEffect(); i < 9; ++i) {
+ System.out.println("abc");
+ }
+ }
+ }
+ """;
+
+ ICompilationUnit cu= pack1.createCompilationUnit("Unused.java", test, false, null);
+
+ CompilationUnit astRoot= getASTRoot(cu);
+ ArrayList proposals= collectCorrections(cu, astRoot, 1);
+ assertCorrectLabels(proposals);
+
+ CUCorrectionProposal proposal1= (CUCorrectionProposal) proposals.get(0);
+ String preview1= getPreviewContent(proposal1);
+
+ String expected1= """
+ package test;
+
+ public class Unused {
+
+ private static int x = 1;
+
+ private static int sideEffect() {
+ return ++x;
+ }
+
+ public static void main(String[] args) {
+ for (int i = 0, _ = sideEffect(); i < 9; ++i) {
+ System.out.println("abc");
+ }
+ }
+ }
+ """;
+
+ assertEqualString(preview1, expected1);
+ }
+
}
diff --git a/org.eclipse.jdt.ui.unittest.junit.feature/pom.xml b/org.eclipse.jdt.ui.unittest.junit.feature/pom.xml
index a45a9707e4b..0c3e3c88625 100644
--- a/org.eclipse.jdt.ui.unittest.junit.feature/pom.xml
+++ b/org.eclipse.jdt.ui.unittest.junit.feature/pom.xml
@@ -16,7 +16,7 @@
eclipse.jdt.ui
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
org.eclipse.jdt.feature
org.eclipse.jdt.ui.unittest.junit.feature
diff --git a/org.eclipse.jdt.ui.unittest.junit/pom.xml b/org.eclipse.jdt.ui.unittest.junit/pom.xml
index a2b2b17e890..05ed1f45a55 100644
--- a/org.eclipse.jdt.ui.unittest.junit/pom.xml
+++ b/org.eclipse.jdt.ui.unittest.junit/pom.xml
@@ -14,7 +14,7 @@
eclipse.jdt.ui
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
org.eclipse.jdt
org.eclipse.jdt.ui.unittest.junit
diff --git a/org.eclipse.jdt.ui/pom.xml b/org.eclipse.jdt.ui/pom.xml
index e589abb74e8..fffaedcc7ea 100644
--- a/org.eclipse.jdt.ui/pom.xml
+++ b/org.eclipse.jdt.ui/pom.xml
@@ -14,7 +14,7 @@
eclipse.jdt.ui
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
org.eclipse.jdt
org.eclipse.jdt.ui
diff --git a/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/javaeditor/JavaElementHyperlinkDetector.java b/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/javaeditor/JavaElementHyperlinkDetector.java
index 60f2620d9f8..57fa5ef0d9b 100644
--- a/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/javaeditor/JavaElementHyperlinkDetector.java
+++ b/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/javaeditor/JavaElementHyperlinkDetector.java
@@ -58,6 +58,7 @@
import org.eclipse.jdt.internal.ui.search.SearchMessages;
import org.eclipse.jdt.internal.ui.text.JavaWordFinder;
+import org.eclipse.jdt.internal.ui.util.SelectionUtil;
/**
@@ -75,7 +76,6 @@ public class JavaElementHyperlinkDetector extends AbstractHyperlinkDetector {
private static IRegion fLastWordRegion;
private static IJavaElement[] fLastElements;
-
/*
* @see org.eclipse.jface.text.hyperlink.IHyperlinkDetector#detectHyperlinks(org.eclipse.jface.text.ITextViewer, org.eclipse.jface.text.IRegion, boolean)
*/
@@ -99,14 +99,13 @@ private IHyperlink[] detectHyperlinksCached(IRegion region) {
if (input == null)
return null;
+ IDocumentProvider documentProvider= textEditor.getDocumentProvider();
+ IEditorInput editorInput= textEditor.getEditorInput();
+ IDocument document= documentProvider.getDocument(editorInput);
+ IRegion wordRegion= JavaWordFinder.findWord(document, offset);
+ if (wordRegion == null || wordRegion.getLength() == 0)
+ return null;
try {
- IDocumentProvider documentProvider= textEditor.getDocumentProvider();
- IEditorInput editorInput= textEditor.getEditorInput();
- IDocument document= documentProvider.getDocument(editorInput);
- IRegion wordRegion= JavaWordFinder.findWord(document, offset);
- if (wordRegion == null || wordRegion.getLength() == 0)
- return null;
-
if (isInheritDoc(document, wordRegion) && getClass() != JavaElementHyperlinkDetector.class)
return null;
@@ -143,7 +142,9 @@ private IHyperlink[] detectHyperlinksCached(IRegion region) {
return null;
return CollectionsUtil.toArray(links, IHyperlink.class);
-
+ } catch (RuntimeException e) {
+ SelectionUtil.logException("computing hyperlink", e, textEditor.getTitle(), document, offset); //$NON-NLS-1$
+ return null;
} catch (JavaModelException e) {
return null;
}
diff --git a/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/text/java/CompletionProposalComputerDescriptor.java b/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/text/java/CompletionProposalComputerDescriptor.java
index 4c152b2ca60..d954c5cbcbf 100644
--- a/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/text/java/CompletionProposalComputerDescriptor.java
+++ b/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/text/java/CompletionProposalComputerDescriptor.java
@@ -17,7 +17,6 @@
import java.util.Collections;
import java.util.HashSet;
import java.util.List;
-import java.util.Objects;
import java.util.Set;
import org.osgi.framework.Bundle;
@@ -27,7 +26,6 @@
import org.eclipse.core.runtime.IConfigurationElement;
import org.eclipse.core.runtime.IContributor;
import org.eclipse.core.runtime.IExtension;
-import org.eclipse.core.runtime.ILog;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.InvalidRegistryObjectException;
@@ -35,11 +33,12 @@
import org.eclipse.core.runtime.Platform;
import org.eclipse.core.runtime.Status;
-import org.eclipse.jface.text.BadLocationException;
import org.eclipse.jface.text.IDocument;
import org.eclipse.jface.text.contentassist.ICompletionProposal;
import org.eclipse.jface.text.contentassist.IContextInformation;
+import org.eclipse.jdt.core.ICompilationUnit;
+
import org.eclipse.jdt.internal.corext.util.Messages;
import org.eclipse.jdt.ui.text.IJavaPartitions;
@@ -49,6 +48,7 @@
import org.eclipse.jdt.internal.ui.JavaPlugin;
import org.eclipse.jdt.internal.ui.javaeditor.JavaSourceViewer;
+import org.eclipse.jdt.internal.ui.util.SelectionUtil;
/**
* The description of an extension to the
@@ -328,7 +328,6 @@ public IJavaCompletionProposalComputer createComputer() throws CoreException, In
return (IJavaCompletionProposalComputer) fElement.createExecutableExtension(CLASS);
}
- private String lastErrorMsg;
/**
* Safely computes completion proposals through the described extension. If the extension
* is disabled, throws an exception or otherwise does not adhere to the contract described in
@@ -360,8 +359,8 @@ public List computeCompletionProposals(ContentAssistInvocat
}
} finally {
// If computers are using non-ui thread, don't report delays.
- fIsReportingDelay= !(context.getViewer() instanceof JavaSourceViewer)
- || !((JavaSourceViewer) context.getViewer()).isAsyncCompletionActive();
+ fIsReportingDelay= !(context.getViewer() instanceof JavaSourceViewer viewer)
+ || !viewer.isAsyncCompletionActive();
}
status= createAPIViolationStatus(COMPUTE_COMPLETION_PROPOSALS);
} catch (InvalidRegistryObjectException x) {
@@ -370,25 +369,8 @@ public List computeCompletionProposals(ContentAssistInvocat
status= createExceptionStatus(x);
} catch (RuntimeException x) {
// log error and keep going with other providers
- String where= ""; //$NON-NLS-1$
- if (context instanceof JavaContentAssistInvocationContext ctx) {
- if (ctx.getCompilationUnit() != null) {
- where+= ctx.getCompilationUnit().getElementName();
- }
- }
- where+= " at offset " + context.getInvocationOffset(); //$NON-NLS-1$
- try {
- IDocument doc= context.getDocument();
- int lineOfOffset= doc.getLineOfOffset(context.getInvocationOffset());
- where+= " line " + (lineOfOffset + 1); //$NON-NLS-1$
- int CONTEXT_LINES= 10;
- where+= " :\n" + doc.get(doc.getLineOffset(Math.max(0, lineOfOffset - CONTEXT_LINES)), context.getInvocationOffset()) + '|'; //$NON-NLS-1$
- } catch (BadLocationException e1) {
- }
- if (!Objects.equals(lastErrorMsg, where)) { // avoid repetitive logging
- lastErrorMsg= where;
- ILog.get().error("RuntimeException computing completion proposal for " + where, x); //$NON-NLS-1$
- }
+ String title= (context instanceof JavaContentAssistInvocationContext ctx) && (ctx.getCompilationUnit() instanceof ICompilationUnit cu) ? cu.getElementName() : null;
+ SelectionUtil.logException("computing completion proposal", x, title, context.getDocument(), context.getInvocationOffset()); //$NON-NLS-1$
status= createExceptionStatus(x);
return Collections.emptyList();
} finally {
diff --git a/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/text/java/hover/AbstractJavaEditorTextHover.java b/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/text/java/hover/AbstractJavaEditorTextHover.java
index b259b229dd2..f0911c4e0e7 100644
--- a/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/text/java/hover/AbstractJavaEditorTextHover.java
+++ b/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/text/java/hover/AbstractJavaEditorTextHover.java
@@ -40,6 +40,7 @@
import org.eclipse.jdt.internal.ui.javaeditor.IClassFileEditorInput;
import org.eclipse.jdt.internal.ui.javaeditor.WorkingCopyManager;
import org.eclipse.jdt.internal.ui.text.JavaWordFinder;
+import org.eclipse.jdt.internal.ui.util.SelectionUtil;
/**
@@ -119,6 +120,9 @@ protected IJavaElement[] getJavaElementsAt(ITextViewer textViewer, IRegion hover
if (resolve != null) {
try {
return resolve.codeSelect(hoverRegion.getOffset(), hoverRegion.getLength());
+ } catch (RuntimeException e) {
+ SelectionUtil.logException("computing hover information", e, getEditor().getTitle(), document, hoverRegion.getOffset()); //$NON-NLS-1$
+ return null;
} catch (JavaModelException x) {
return null;
}
diff --git a/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/util/SelectionUtil.java b/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/util/SelectionUtil.java
index c3aaa9a1e25..0c82d9ed6a9 100644
--- a/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/util/SelectionUtil.java
+++ b/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/util/SelectionUtil.java
@@ -17,6 +17,9 @@
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
+import java.util.Objects;
+
+import org.eclipse.core.runtime.ILog;
import org.eclipse.core.resources.IResource;
@@ -24,6 +27,9 @@
import org.eclipse.jface.viewers.IStructuredSelection;
import org.eclipse.jface.viewers.StructuredSelection;
+import org.eclipse.jface.text.BadLocationException;
+import org.eclipse.jface.text.IDocument;
+
import org.eclipse.ui.IWorkbenchPage;
import org.eclipse.ui.IWorkbenchPart;
import org.eclipse.ui.IWorkbenchPartReference;
@@ -121,4 +127,34 @@ public static void selectAndReveal(IResource[] resources, IWorkbenchWindow windo
private SelectionUtil() {
}
+ private static String lastErrorMsg;
+
+ public static void logException(String action, RuntimeException e, String title, IDocument document, int offset) {
+ // log error and keep going
+ String errorMsg= e.getClass().getSimpleName() + " " + action; //$NON-NLS-1$
+ if (title != null) {
+ errorMsg+= " in " + title; //$NON-NLS-1$
+ }
+ errorMsg+= " at offset " + offset; //$NON-NLS-1$
+ try {
+ int lineOfOffset= document.getLineOfOffset(offset);
+ String source= "Source line " + (lineOfOffset + 1); //$NON-NLS-1$
+ int CONTEXT_LINES= 10;
+ int startLineOffset= document.getLineOffset(Math.max(0, lineOfOffset - CONTEXT_LINES));
+ source+= " :"+System.lineSeparator(); //$NON-NLS-1$
+ source+= "-----" + System.lineSeparator(); //$NON-NLS-1$
+ source+= document.get(startLineOffset, offset - startLineOffset); // source until offset
+ source+= '|'; // cursor
+ source+= document.get(offset, document.getLineOffset(lineOfOffset) + document.getLineLength(lineOfOffset) - offset); // rest of line
+ source+= "-----"; //$NON-NLS-1$
+ e.addSuppressed(new Throwable(source));
+ } catch (BadLocationException ble) {
+ e.addSuppressed(ble);
+ }
+ if (!Objects.equals(lastErrorMsg, errorMsg)) { // avoid repetitive logging
+ lastErrorMsg= errorMsg;
+ ILog.get().error(errorMsg, e);
+ }
+ }
+
}
diff --git a/pom.xml b/pom.xml
index 9a274ae941e..f2de4b86fac 100644
--- a/pom.xml
+++ b/pom.xml
@@ -15,7 +15,7 @@
org.eclipse
eclipse-platform-parent
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
../eclipse-platform-parent
diff --git a/tests-pom/pom.xml b/tests-pom/pom.xml
index 3366b4f9eed..901fcabb93e 100644
--- a/tests-pom/pom.xml
+++ b/tests-pom/pom.xml
@@ -14,7 +14,7 @@
eclipse.jdt.ui
eclipse.jdt.ui
- 4.34.0-SNAPSHOT
+ 4.35.0-SNAPSHOT
tests-pom
pom