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

Bugfix for #985 (ECJ throws false-positive "Package collides with type" on Windows) #3057

Conversation

nettozahler
Copy link
Contributor

What it does

Fixes #985

How to test

Use the self-contained example from the bug report to reproduce the issue. But change the setup to run it against a current version of ECJ which contains this bugfix (the original reproducer uses ecj-3.33.0.jar). The bug does not occur with this bugfix.

Review hints

To simplify the review process, there are several distinct commits to improve the code style. These are commentd with "No runtime changes". The bugfix is contained in the last commit. After review and before merge the commits can be squashed to a single one.

Author checklist

@stephan-herrmann
Copy link
Contributor

Thanks for the PR

To simplify the review process, there are several distinct commits to improve the code style. These are commentd with "No runtime changes". The bugfix is contained in the last commit. After review and before merge the commits can be squashed to a single one.

I'm glad you separated those different concerns, but frankly I can't see (a) that the changes of style have any relation to the actual bugfix, nor (b) that those are objectively corrections or otherwise improvements. E.g., adding javadoc to internal classes without providing additional information is definitely a non-goal. The same for shortening identifiers or reducing LOC (whereas simplification could be a goal, if all agree that the result is simpler).

Note that unnecessary changes are not only an issue during code review but also during subsequent maintenance. Everybody interested in the history of this file will see this commit (with a 3 lines payload) as a major change (and wonder what is the significant change?).

I don't mind genuine simplifications and refactorings that support the actual (semantic) code change, but I don't see any of this in this PR.

With that I'd prefer a bare-bones PR with only the necessary changes.

@nettozahler nettozahler force-pushed the 985-ECJ-throws-false-positive-package-collides-with-type branch from fb646a5 to 94bb454 Compare October 10, 2024 20:52
@nettozahler
Copy link
Contributor Author

It seems I have to learn which sort of PRs are welcome for Eclipse and which are not. Obviously doing more than the absolute minimum is discouraged. Maybe I will start a discussion thread to find out more background for this restrictive approach and collect pros and cons (which exist IMO). I think I quite understand the maintainer's view but I also see some implications for contributors.

@stephan-herrmann
Copy link
Contributor

It seems I have to learn which sort of PRs are welcome for Eclipse and which are not. Obviously doing more than the absolute minimum is discouraged. Maybe I will start a discussion thread to find out more background for this restrictive approach and collect pros and cons (which exist IMO). I think I quite understand the maintainer's view but I also see some implications for contributors.

I hope I didn't sound like I would speak for all of Eclipse. But it's probably safe to say that in compiler land we are more "conservative" than other parts of Eclipse. Experience tells us that a lean history is one of our most valuable assets, since many code changes start with studying the history to learn why a particular paragraph of code looks the way it does.

And as said, any changes in preparation are fine if it can be argued in which way those facilitate the 'real' change. So reducing the change to a minimum actually reduces the burden to explain your changes :)

@stephan-herrmann
Copy link
Contributor

I don't have a windows box for testing the change. @jarthana can you help?

Meanwhile, @nettozahler you could further help us by providing a unit test. I think org.eclipse.jdt.compiler.tool.tests.CompilerToolTests would be a good place where you could take inspiration from existing tests that exercise ClasspathJsr199.

@nettozahler nettozahler force-pushed the 985-ECJ-throws-false-positive-package-collides-with-type branch from 94bb454 to 3c11c57 Compare November 2, 2024 21:50
@nettozahler
Copy link
Contributor Author

OK, I have taken the proposed inspiration and added a testcase.

@stephan-herrmann
Copy link
Contributor

@jarthana as this is a windows-only issue, could you take a look?

@jarthana jarthana assigned jarthana and nettozahler and unassigned jarthana Jan 2, 2025
@jarthana jarthana self-requested a review January 6, 2025 09:30
Copy link
Member

@jarthana jarthana left a comment

Choose a reason for hiding this comment

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

Looks good. Can you please rebase and resolve the conflicts so we can go ahead with the merge? Thanks!

Edit: Actually, there's one issue with the tests. The deleteIfExists() for sourceFile1 is going to return false as it has already been deleted by the previous Files.walk(). I think we should convert that to a simple !Files.exists() check to let the tests pass, something like this:

assertTrue("Delete failed", Files.deleteIfExists(tempPath.resolve("Foo.class")));
assertFalse("Delete failed", Files.exists(sourceFile1));
assertTrue("Delete failed", Files.deleteIfExists(sourceFile2));

@jarthana jarthana force-pushed the 985-ECJ-throws-false-positive-package-collides-with-type branch from 3c11c57 to 3eb07a3 Compare January 7, 2025 05:56
@jarthana
Copy link
Member

jarthana commented Jan 7, 2025

@nettozahler I have rebased and pushed after resolving conflicts. Also fixed the failing test. Just take a look once. If you agree with the changes and tests return green, we can commit this.

@jarthana jarthana force-pushed the 985-ECJ-throws-false-positive-package-collides-with-type branch from 3eb07a3 to 74c178c Compare January 7, 2025 06:51
@jarthana jarthana merged commit 83ee4c5 into eclipse-jdt:master Jan 7, 2025
10 checks passed
@nettozahler
Copy link
Contributor Author

Î was mostly away from keyboard during New Year's break so I did not proceed with this PR. Thank you @jarthana for your polishing work and the merge! And happy new year...

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.

ECJ throws false-positive "Package collides with type" on Windows (case-insensitive compiler)
3 participants