From 8a60bff63de34fe76875a74bd32bfd7f212bfe49 Mon Sep 17 00:00:00 2001 From: Jeff Johnston Date: Thu, 6 Jun 2024 17:01:13 -0400 Subject: [PATCH] Fix code mining parameter name logic - add two new preferences regarding the default filter and the filtering of implied parameter names - for filtering of implied parameter names, do not filter out parameter names that are 3 characters or less that are contained in the argument but filter them out if they are equal - bump up jdt.ui minor version as new preference constants are added - fixes #1437 --- org.eclipse.jdt.ui/META-INF/MANIFEST.MF | 2 +- org.eclipse.jdt.ui/pom.xml | 2 +- .../CalleeJavaMethodParameterVisitor.java | 25 ++++++++++++++--- ...avaEditorCodeMiningConfigurationBlock.java | 26 +++++++++++++++--- .../ui/preferences/PreferencesMessages.java | 2 ++ .../PreferencesMessages.properties | 2 ++ .../eclipse/jdt/ui/PreferenceConstants.java | 27 +++++++++++++++++++ 7 files changed, 77 insertions(+), 9 deletions(-) diff --git a/org.eclipse.jdt.ui/META-INF/MANIFEST.MF b/org.eclipse.jdt.ui/META-INF/MANIFEST.MF index 896f597d2eb..4672a97a4c8 100644 --- a/org.eclipse.jdt.ui/META-INF/MANIFEST.MF +++ b/org.eclipse.jdt.ui/META-INF/MANIFEST.MF @@ -3,7 +3,7 @@ Automatic-Module-Name: org.eclipse.jdt.ui Bundle-ManifestVersion: 2 Bundle-Name: %pluginName Bundle-SymbolicName: org.eclipse.jdt.ui; singleton:=true -Bundle-Version: 3.32.200.qualifier +Bundle-Version: 3.33.0.qualifier Bundle-Activator: org.eclipse.jdt.internal.ui.JavaPlugin Bundle-ActivationPolicy: lazy Bundle-Vendor: %providerName diff --git a/org.eclipse.jdt.ui/pom.xml b/org.eclipse.jdt.ui/pom.xml index 9f0d94e24da..251ed3163cc 100644 --- a/org.eclipse.jdt.ui/pom.xml +++ b/org.eclipse.jdt.ui/pom.xml @@ -18,7 +18,7 @@ org.eclipse.jdt org.eclipse.jdt.ui - 3.32.200-SNAPSHOT + 3.33.0-SNAPSHOT eclipse-plugin diff --git a/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/javaeditor/codemining/CalleeJavaMethodParameterVisitor.java b/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/javaeditor/codemining/CalleeJavaMethodParameterVisitor.java index db3b400c353..11f14a89ef0 100644 --- a/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/javaeditor/codemining/CalleeJavaMethodParameterVisitor.java +++ b/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/javaeditor/codemining/CalleeJavaMethodParameterVisitor.java @@ -1,5 +1,5 @@ /******************************************************************************* - * Copyright (c) 2017, 2023 Angelo Zerr and others. + * Copyright (c) 2017, 2024 Angelo Zerr and others. * * This program and the accompanying materials * are made available under the terms of the Eclipse Public License 2.0 @@ -16,6 +16,11 @@ import java.util.List; +import org.eclipse.jface.preference.IPreferenceStore; + +import org.eclipse.jface.text.codemining.ICodeMining; +import org.eclipse.jface.text.codemining.ICodeMiningProvider; + import org.eclipse.jdt.core.IJavaElement; import org.eclipse.jdt.core.IMethod; import org.eclipse.jdt.core.dom.ClassInstanceCreation; @@ -25,10 +30,12 @@ import org.eclipse.jdt.core.dom.IMethodBinding; import org.eclipse.jdt.core.dom.MethodInvocation; import org.eclipse.jdt.core.dom.SuperConstructorInvocation; + import org.eclipse.jdt.internal.corext.dom.HierarchicalASTVisitor; + +import org.eclipse.jdt.ui.PreferenceConstants; + import org.eclipse.jdt.internal.ui.JavaPlugin; -import org.eclipse.jface.text.codemining.ICodeMining; -import org.eclipse.jface.text.codemining.ICodeMiningProvider; public class CalleeJavaMethodParameterVisitor extends HierarchicalASTVisitor { @@ -147,9 +154,14 @@ private boolean skipParameterNameCodeMining(String[] parameterNames, List arg if (parameterNames.length < parameterIndex) { return true; } + IPreferenceStore store= JavaPlugin.getDefault().getPreferenceStore(); + boolean filter= store.getBoolean(PreferenceConstants.EDITOR_JAVA_CODEMINING_FILTER_IMPLIED_PARAMETER_NAMES); + if (!filter) { + return false; + } String parameterName= parameterNames[parameterIndex].toLowerCase(); String expression= arguments.get(parameterIndex).toString().toLowerCase(); - return expression.contains(parameterName); + return parameterName.length() > 3 && expression.contains(parameterName) || parameterName.equals(expression); } private boolean skipParameterNamesCodeMinings(IMethod method) { @@ -157,6 +169,11 @@ private boolean skipParameterNamesCodeMinings(IMethod method) { } private boolean skipParameterNamesCodeMinings(IMethod method, String[] parameterNames) { + IPreferenceStore store= JavaPlugin.getDefault().getPreferenceStore(); + boolean filter= store.getBoolean(PreferenceConstants.EDITOR_JAVA_CODEMINING_DEFAULT_FILTER_FOR_PARAMETER_NAMES); + if (!filter) { + return false; + } // add default filtering to skip parameter names (based on original plug-in defaults) String typeName= method.getDeclaringType().getTypeQualifiedName(); if (typeName.equals("Math")) { //$NON-NLS-1$ diff --git a/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/preferences/JavaEditorCodeMiningConfigurationBlock.java b/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/preferences/JavaEditorCodeMiningConfigurationBlock.java index 03a9351e240..06c4ebfd659 100644 --- a/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/preferences/JavaEditorCodeMiningConfigurationBlock.java +++ b/org.eclipse.jdt.ui/ui/org/eclipse/jdt/internal/ui/preferences/JavaEditorCodeMiningConfigurationBlock.java @@ -75,6 +75,12 @@ public class JavaEditorCodeMiningConfigurationBlock extends OptionsConfiguration private static final Key PREF_SHOW_PARAMETER_NAMES= getJDTUIKey( PreferenceConstants.EDITOR_JAVA_CODEMINING_SHOW_PARAMETER_NAMES); + private static final Key PREF_FILTER_IMPLIED_PARAMETER_NAMES= getJDTUIKey( + PreferenceConstants.EDITOR_JAVA_CODEMINING_FILTER_IMPLIED_PARAMETER_NAMES); + + private static final Key PREF_DEFAULT_FILTER_FOR_PARAMETER_NAMES= getJDTUIKey( + PreferenceConstants.EDITOR_JAVA_CODEMINING_DEFAULT_FILTER_FOR_PARAMETER_NAMES); + private static final String SETTINGS_SECTION_NAME= "JavaEditorCodeMiningConfigurationBlock"; //$NON-NLS-1$ private static final String[] TRUE_FALSE= new String[] { "true", "false" }; //$NON-NLS-1$ //$NON-NLS-2$ @@ -95,7 +101,7 @@ public JavaEditorCodeMiningConfigurationBlock(IStatusChangeListener context, public static Key[] getAllKeys() { return new Key[] { PREF_CODEMINING_ENABLED, PREF_SHOW_CODEMINING_AT_LEAST_ONE, PREF_SHOW_REFERENCES, PREF_SHOW_REFERENCES_ON_TYPES, PREF_SHOW_REFERENCES_ON_FIELDS, PREF_SHOW_REFERENCES_ON_METHODS, - PREF_SHOW_IMPLEMENTATIONS, PREF_SHOW_PARAMETER_NAMES, PREF_IGNORE_INEXACT_MATCHES }; + PREF_SHOW_IMPLEMENTATIONS, PREF_SHOW_PARAMETER_NAMES, PREF_IGNORE_INEXACT_MATCHES, PREF_FILTER_IMPLIED_PARAMETER_NAMES, PREF_DEFAULT_FILTER_FOR_PARAMETER_NAMES }; } @Override @@ -183,6 +189,7 @@ private void createGeneralSection(int nColumns, Composite parent) { Composite inner= createInnerComposite(excomposite, nColumns, parent.getFont()); + // - Show references PreferenceTreeNode