Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Provide name for parameters in 1-arg methods when using code minings #1813

Merged
merged 1 commit into from
Dec 19, 2024

Conversation

jannisCode
Copy link
Contributor

@jannisCode jannisCode commented Nov 26, 2024

What it does

This PR will enable the possability to show code minings in all Methods, also those who expect just one argument.

Before:

When a method only had one parameter, it was eligible for code minings, except if it was from a record class. As you can see in the screenshot and snippet, the code minings are shown for car but not for Cat.

import java.util.Objects;

class Main {
	public static void main(String...args) {
		Car c = new Car(3);
		Cat car = new Cat(5);
		car.equals(c);
		car.doSomething(12, 13);
	}
}

 class Cat {
    private int size;

    public Cat(int size) {
        this.size = size;
    }
    public Cat(long age) {}

    public int getSize() {
        return size;
    }

    public void doSomething(int a, int b) {}
    @Override
    public boolean equals(Object obj) {
        if (this == obj) return true;
        if (obj == null || getClass() != obj.getClass()) return false;
        Cat cat = (Cat) obj;
        return size == cat.size;
    }

    @Override
    public int hashCode() {
        return Objects.hash(size);
    }

    @Override
    public String toString() {
        return "Cat{size=" + size + "}";
    }
}

public record Car(int side) {}

image

@mickaelistria Is there a reason, why it always checks if there are more than one parameter? Because if not, I think it would be beneficial if the code minings are always shown.

After this change

Code minings are always shown no matter how many Parameters there are.

Author checklist

@jannisCode jannisCode marked this pull request as ready for review November 26, 2024 14:11
@eclipse-jdt-bot
Copy link
Contributor

This pull request changes some projects for the first time in this development cycle.
Therefore the following files need a version increment:

org.eclipse.jdt.ui/META-INF/MANIFEST.MF
org.eclipse.jdt.ui/pom.xml

An additional commit containing all the necessary changes was pushed to the top of this PR's branch. To obtain these changes (for example if you want to push more changes) either fetch from your fork or apply the git patch.

Git patch
From 158338fd1268d2e07ae9ca97d4843c56b2fab3d5 Mon Sep 17 00:00:00 2001
From: Eclipse JDT Bot <[email protected]>
Date: Tue, 26 Nov 2024 14:13:19 +0000
Subject: [PATCH] Version bump(s) for 4.35 stream


diff --git a/org.eclipse.jdt.ui/META-INF/MANIFEST.MF b/org.eclipse.jdt.ui/META-INF/MANIFEST.MF
index 0a5b80724a..d1e2321293 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.33.200.qualifier
+Bundle-Version: 3.33.300.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 fffaedcc7e..3818bc298e 100644
--- a/org.eclipse.jdt.ui/pom.xml
+++ b/org.eclipse.jdt.ui/pom.xml
@@ -18,7 +18,7 @@
   </parent>
   <groupId>org.eclipse.jdt</groupId>
   <artifactId>org.eclipse.jdt.ui</artifactId>
-  <version>3.33.200-SNAPSHOT</version>
+  <version>3.33.300-SNAPSHOT</version>
   <packaging>eclipse-plugin</packaging>
 
 	<build>
-- 
2.47.0

Further information are available in Common Build Issues - Missing version increments.

@mickaelistria
Copy link
Contributor

Is there a reason, why it always checks if there are more than one parameter?

Back then when I developed this, I found those names useless for single-arg methods. Parameter names are convenient to identify what an argument is intended too; when there is a single arg, the method name is most often sufficient to sort out what's going to happen with the given arg.

@fedejeanne
Copy link
Contributor

fedejeanne commented Nov 27, 2024

Is there a reason, why it always checks if there are more than one parameter?

[...] when there is a single arg, the method name is most often sufficient to sort out what's going to happen with the given arg.

Not always, think of constructors

image

I find having the names for methods with 1 argument is useful and also more consistent with the rest of the behavior. Thank you @jannisCode for this suggestion!

@@ -165,7 +165,7 @@ private boolean skipParameterNameCodeMining(String[] parameterNames, List<?> arg
}

private boolean skipParameterNamesCodeMinings(IMethod method) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Remove this method altogether.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Outdated: agreed on adding a parameter which makes this method necessary.

@mickaelistria
Copy link
Contributor

Not always, think of constructors

The relevant case to check is when you read code. Even if there are several possible constructors, it's not likely to me that having the parameter name will help readability, eg new Shell(SWT.ON_TOP) or new Shell(Display.getCurrent()) or new Shell(mainShell).... read well without showing the parameter: you rarely wonder what the parameter actually is and what it's used for (unless you poorly name you variables).

more consistent with the rest of the behavior.

Consistency is less important that being useful and lean ;)

I would strongly hate having the parameter names in 1 method args, it would just add noise to me in the very vast majority of use cases, and useless noise hurts readability more than it helps.
So please add a preference to allow users like me to skip such parameter names annotations for those single-args methods.

@jannisCode jannisCode changed the title The Code works now for every method Provide name for parameters in 1-arg methods when using code minings Nov 29, 2024
Copy link
Contributor

@mickaelistria mickaelistria left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please also provide an option in preferences to skip those.

@fedejeanne
Copy link
Contributor

fedejeanne commented Nov 29, 2024

more consistent with the rest of the behavior.

Consistency is less important that being useful and lean ;)

Consistency is important so that users don't end up reporting "bugs" that are not bugs and simply some "other arbitrary behavior". What I meant by that is not that the 1-arg methods don't show the name of the argument but that this behavior is not the same across the board: records don't exhibit this behavior.

Please also provide an option in preferences to skip those.

I'd rather not have such an option, I think the configuration is complex enough. But there are maybe some other opinions on that. Does anyone else (other than Mickael and me) reading this PR care to vote?

@mickaelistria
Copy link
Contributor

records don't exhibit this behavior.

That is more a bug to me, to fix separately.

I'd rather not have such an option, I think the configuration is complex enough.

Please make sure you actually try to work with this proposal on various classes before considering it for a merge. My arbitrary choice was based on actual usage of the feature while it was being implemented. My impression based on that experience is that in the vast majority of cases, single arg name is noise and hurts readability.
If several people can actually try it for real, on real code, for some a few days, and report that this the hint are more often useful to them, I will stop arguing; but at the moment, I seem to be the only one who actually experimented that (some years ago) and my feedback is that this is going to hurt readability and would perceived, at least by 1 user, as a regression in usability.
So an option is a must-have to me.

@@ -165,7 +165,7 @@ private boolean skipParameterNameCodeMining(String[] parameterNames, List<?> arg
}

private boolean skipParameterNamesCodeMinings(IMethod method) {
return method.getNumberOfParameters() <= 1;
return false;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please use a preference here

Suggested change
return false;
return PreferenceConstants.getPreferenceStore().getBoolean(PreferencesConstants.EDITOR_JAVA_CODEMINING_SHOW_PARAMETER_NAME_SINGLE_ARG) && method.getNumberOfParameters() == 1) || method.getNumberOfParameters() == 0;

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Rather the opposite:

boolean showNamesOfSingleArguments= PreferenceConstants.getPreferenceStore().getBoolean(PreferenceConstants.EDITOR_JAVA_CODEMINING_SHOW_PARAMETER_NAME_SINGLE_ARG);
return !showNamesOfSingleArguments && method.getNumberOfParameters() == 1
		|| method.getNumberOfParameters() == 0;

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

if you're into renaming with opposite meanings, I suggest renaming (and reversing conditions) from skipParameterNamesCodeMinings to showParameterNamesCodeMinings() { return number > 1 || PreferenceConstants.getPreferenceStore().getBoolean(PreferencesConstants.EDITOR_JAVA_CODEMINING_SHOW_PARAMETER_NAME_SINGLE_ARG)). That should make things simpler to understand and maintain.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No need to rename the method in this PR, it is fine as it is and it is overloaded so the renaming would have to be done for these 4 methods just so the class stays consistent:

image

@mickaelistria
Copy link
Contributor

Thanks. That proposal is good to me!

@@ -165,7 +165,13 @@ private boolean skipParameterNameCodeMining(String[] parameterNames, List<?> arg
}

private boolean skipParameterNamesCodeMinings(IMethod method) {
IPreferenceStore store= JavaPlugin.getDefault().getPreferenceStore();
boolean showFromOneParameter = store.getBoolean(PreferenceConstants.EDITOR_JAVA_SHOW_ONE_PARAMETER);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you really want to read from the store for each method?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

And in line 179 another preference store access?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would it be ok to leave that to another PR so that this one doesn't blow up?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, sure.

@jannisCode jannisCode force-pushed the Code_minings_changes branch 6 times, most recently from 8dab19f to e301be1 Compare December 10, 2024 14:42
@@ -227,6 +230,9 @@ private void createGeneralSection(int nColumns, Composite parent) {
PreferencesMessages.JavaEditorCodeMiningConfigurationBlock_defaultFilterForParameterNames_label,
PREF_DEFAULT_FILTER_FOR_PARAMETER_NAMES, TRUE_FALSE, extraIndent, section);

fFilteredPrefTree.addCheckBox(inner,
"Show one Parameter", //$NON-NLS-1$
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'd suggest something more descriptive, like:

Suggested change
"Show one Parameter", //$NON-NLS-1$
"Show parameter names in methods with only 1 parameter", //$NON-NLS-1$

@@ -165,7 +165,7 @@ private boolean skipParameterNameCodeMining(String[] parameterNames, List<?> arg
}

private boolean skipParameterNamesCodeMinings(IMethod method) {
return method.getNumberOfParameters() <= 1;
return false;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No need to rename the method in this PR, it is fine as it is and it is overloaded so the renaming would have to be done for these 4 methods just so the class stays consistent:

image

@@ -165,7 +165,13 @@ private boolean skipParameterNameCodeMining(String[] parameterNames, List<?> arg
}

private boolean skipParameterNamesCodeMinings(IMethod method) {
IPreferenceStore store= JavaPlugin.getDefault().getPreferenceStore();
boolean showFromOneParameter = store.getBoolean(PreferenceConstants.EDITOR_JAVA_SHOW_ONE_PARAMETER);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would it be ok to leave that to another PR so that this one doesn't blow up?

@szarnekow
Copy link
Contributor

Would it be ok to leave that to another PR so that this one doesn't blow up?

Yes, sure.

Copy link
Contributor

@fedejeanne fedejeanne left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I tested it and it works as expected. There is only one small typo in the label of the preferences.

After fixing that, a committer can merge this one.

@@ -1038,6 +1038,7 @@ JavaEditorCodeMiningConfigurationBlock_showImplementations_label=Show &implement
JavaEditorCodeMiningConfigurationBlock_showParameterNames_label=Show method &parameter names
JavaEditorCodeMiningConfigurationBlock_defaultFilterForParameterNames_label=&Default filter for some specified methods and method parameter names (e.g. compare())
JavaEditorCodeMiningConfigurationBlock_filterImpliedParameterNames_label=Filter parameter &names that are implied by parameter
JavaEditorCodeMiningShowOneParameter_label=Show code minnigs when method has one parameter
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
JavaEditorCodeMiningShowOneParameter_label=Show code minnigs when method has one parameter
JavaEditorCodeMiningShowOneParameter_label=Show code minings when method has one parameter

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

thanks for noticing! I changed it

@jannisCode jannisCode force-pushed the Code_minings_changes branch 2 times, most recently from 462d700 to 5cec185 Compare December 17, 2024 09:18
Copy link
Contributor

@fedejeanne fedejeanne left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The code looks sound and the minings work as expected.

Would a JDT committer be so kind to (review/test and) merge this one? Thank you in advance.

@jukzi / @jjohnstn / @iloveeclipse

@jukzi
Copy link
Contributor

jukzi commented Dec 18, 2024

you need to get a green CI first. failing JdtTextTestSuite ParameterNamesCodeMiningTest.testRecordConstructorOneParameter sounds related

@fedejeanne
Copy link
Contributor

you need to get a green CI first. failing JdtTextTestSuite ParameterNamesCodeMiningTest.testRecordConstructorOneParameter sounds related

@jukzi sorry, I missed that one.

@jannisCode, like we spoke last week, you need to replace the testRecordConstructorOneParameter with these 2 tests so you also test the new parameter:

@Test
public void testRecordConstructorOneParameterPreferenceFalse() throws Exception {
	assertParameterNamesShown(false, 0);
}

@Test
public void testRecordConstructorOneParameterPreferenceTrue() throws Exception {
	assertParameterNamesShown(true, 1);
}

private void assertParameterNamesShown(boolean preferenceValue, int expectedShownNames) throws JavaModelException, PartInitException, InterruptedException, ExecutionException {
	PreferenceConstants.getPreferenceStore().setValue(PreferenceConstants.EDITOR_JAVA_CODEMINING_SHOW_PARAMETER_NAME_SINGLE_ARG, preferenceValue);
	String contents= """
			public class Ant {
		record Ca (int size){

		}

		Ca c = new Ca(0);

	}
	""";
	ICompilationUnit compilationUnit= fPackage.createCompilationUnit("Ant.java", contents, true, new NullProgressMonitor());
	JavaEditor editor= (JavaEditor) EditorUtility.openInEditor(compilationUnit);
	fParameterNameCodeMiningProvider.setContext(editor);
	JavaSourceViewer viewer= (JavaSourceViewer)editor.getViewer();
	waitReconciled(viewer);

	assertEquals(expectedShownNames, fParameterNameCodeMiningProvider.provideCodeMinings(viewer, new NullProgressMonitor()).get().size());
}

I don't have committer rights so you need to do it once you're back in the office.

Copy link
Contributor

@fedejeanne fedejeanne left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please adapt the tests

should be displayed when using the code minings
Copy link
Contributor

@fedejeanne fedejeanne left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM now.

@jukzi ?

@jukzi jukzi merged commit 9c980bf into eclipse-jdt:master Dec 19, 2024
10 checks passed
@jukzi
Copy link
Contributor

jukzi commented Dec 19, 2024

thanks for contributing

@fedejeanne
Copy link
Contributor

thanks for contributing

Thank you for merging!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants