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

[formatter] Format License header in module-info.java like in every other java-class #2127

Closed
enexusde opened this issue Mar 10, 2024 · 16 comments
Labels
bug Something isn't working help wanted Extra attention is needed

Comments

@enexusde
Copy link

enexusde commented Mar 10, 2024

The formatter have a bug. The formatter should not format a multiline comment before any LLOC like in every other java-class.

Steps to reproduce:

  1. Create a new workspace
  2. Create a java-project "Test".
  3. Switch to java-development-perspective.
  4. Add a package "test"
  5. Add a class "Test".
  6. Add the JPMS file module-info.java

Add this this signature to both files:

/*******************************************************************************
 * Copyright (c) 2005, 2007 BEA Systems, Inc.
 *
 * 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
 *
 *******************************************************************************/
  1. Format both files.

Expectation

The signatures are same.

Problem

The module-info.java is formatted different (3 lines instead of 4)

/*******************************************************************************
 * Copyright (c) 2005, 2007 BEA Systems, Inc.
 *
 * 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
 *
 *******************************************************************************/
module Test {
}
@enexusde enexusde changed the title [formatter] JPMS formatter bug for multiline comments (not javadoc) [formatter] JPMS formatter bug for multiline comments Mar 10, 2024
@jukzi
Copy link
Contributor

jukzi commented Mar 11, 2024

I understand you do not want your license headers to be modified. However i don't know if there is way to detect those and to treat them differently. So i doubt its a bug but a new feature you want. Can you suggest a code change?

@jukzi jukzi added the needinfo Further information is requested label Mar 11, 2024
@enexusde
Copy link
Author

enexusde commented Mar 11, 2024

I think you missed the point. Have you noticed the Test.java retain the format correctly but the module-info.java breaks the format?

So what I need is not to threat them differently, its the opposite way: I need to threat them the same!

@jukzi
Copy link
Contributor

jukzi commented Mar 11, 2024

So what I need is not to threat them differently, its the opposite way: I need to threat them the same!

please suggest a patch for that

@enexusde
Copy link
Author

Suboptimal, I am not into the code.

@jukzi jukzi changed the title [formatter] JPMS formatter bug for multiline comments [formatter] Do not format License header javadoc in module-info.java Mar 11, 2024
@jukzi jukzi added enhancement New feature or request help wanted Extra attention is needed and removed needinfo Further information is requested labels Mar 11, 2024
@enexusde
Copy link
Author

enexusde commented Mar 11, 2024

I think it is not an enhancement anyway as it should behave like in typical java-classes.

@enexusde
Copy link
Author

Please someone talk to jukzi

@enexusde enexusde changed the title [formatter] Do not format License header javadoc in module-info.java [formatter] Format License header in module-info.java like in every other java-class Mar 11, 2024
@jukzi
Copy link
Contributor

jukzi commented Mar 11, 2024

It does not matter much if it is a bug or enhancement. As long as nobody provides a PR it will stay unchanged. Please notice that JDT is open source comes without warranty and the project has not enough resources to fulfill all wishes.

@enexusde
Copy link
Author

enexusde commented Mar 11, 2024

Bugs werden eher gefixt. Dadurch dass man diesen Bug eine Erweiterung nennt sinkt die Dringlichkeit und dieser Bug wird vermutlich nicht gefixt. Es gab schon viele Verbesserungsforschläge die nie angefasst wurden. Das soll das ziel sein? Bugs nennen wir Erweiterungen damit wir die nicht fixen müssen? Das ist doch keine technische Entscheidung sondern eine politische. Warum sollte ich contributen wenn Entscheidungen politisch motiviert sind?

Wenn ich richtig geonboarded werde dann hätte ich gerne einen PR erstellt.

@akurtakov
Copy link
Contributor

Please keep comments in English.

@enexusde
Copy link
Author

Sorry, it was more like a private message to jukzi.

@iloveeclipse iloveeclipse added bug Something isn't working and removed enhancement New feature or request labels Mar 11, 2024
@iloveeclipse
Copy link
Member

@mateusz-matela : could you please check if something in formatter missing to work with module-info.java files? Any special rule one has to use?

@mateusz-matela
Copy link
Member

Sure, it looks like the comment in Test.java is not touched because the "Enable header comment formatting" setting is not checked. The formatter determines which parts of code is a header in DefaultCodeFormatter.findHeader() method. Apparently this method has been prepared to work with module-info.java with 4a2995e

If I read it right, the header is considered to end where the first type declaration begins or if there aren't any (as is the case in module-info), at the package definition. @enexusde where do you put your comment in relation to the package definition? Is the formatting retained if you move it above?

@enexusde
Copy link
Author

@mateusz-matela In my case the first character (even the first byte of the first character accordingly) in both files (module-info.java and Test.java) are already part of the signature.

After the signature-lines (my last signature-line ends with a newline accordingly) the package declaration starts. I have a newline but no empty line between the signature and the package-declaration (TWIMC).

This means the signature and the package declaration do not share a same line-number (i.e. if my signature ends in line 15 the package declaration must be in line 16).

By some testing, the signature in Test.java seems not reformated before the class-declaration (including the class-modifiers) start. This means in the import-clause it is not formatted either.

Another suggestion is to use/retain what the code-templates (Preferences -> Java -> Code Style -> Code Templates -> Comments -> Modules) say. I am not sure if this is up for debate.

@enexusde
Copy link
Author

Oh by the way, I do not and never worked for BEA Systems. So nothing I ever said or say relates to BEA System.

@mateusz-matela
Copy link
Member

OK, turns out the commit I mentioned was about packege-info and I confused it with module-info.
I've added a similar fix so it should now work for module-info as well.

@enexusde
Copy link
Author

I noticed that the fix works great. Thank!

robstryker pushed a commit to robstryker/eclipse.jdt.core that referenced this issue Jul 18, 2024
gayanper pushed a commit to gayanper/eclipse.jdt.core that referenced this issue Sep 7, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

5 participants