-
Notifications
You must be signed in to change notification settings - Fork 457
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
Enable and require Java code formatting #2963
base: master
Are you sure you want to change the base?
Conversation
So we avoid format checks for all dependencies being built. Format check is run anyway during the test step (for the specific module only).
Great, @michalmac ! Two (and a half) questions: We do have repos, having matsim-libs as parent in its pom. Some of them also with one GH action testing. I am asking because I plan to introduce this format also there, to have everything in the same style. |
Really good questions!
|
@michalmac: I have tried it out now for my other repo. Here are two things that I noticed: 1.) 2.) Similar things also happen in matsim-libs (I saw some of these changes in this PR, but am too lazy now to search for them. If wished, I can look for some of them again) --> Do we find there a suitable solution to avoid this line wrap inflation? As far as I understood, the Google code style also allows, less line-wrappings.(?) |
Thanks @kt86 for trying out the formatting. Re 1: Thanks. I have not mentioned about importing the the Google code style, because I thought it was described in the linked IntelliJ, but apparently it is not. Re 2: Unfortunately, there is no configurability. This has advantages and disadvantages. I would say the bigger the community, the more advantages. IMO splitting a long list of argument/interfaces/... into individual rows helps in spotting the actual diffs in code. Moreover, it is less likely to get many lines of diff if we add/rename/remove one argument. But the code gets longer. == I think we need to keep in mind that there is no formatting style that will make everyone happy. However, if many of us are (very) unhappy, then probably we need to come up with a different style. I think every feedback like yours is very valuable in making the final decision. |
Thank you, Michal! For me personally, I can also live with that many additional lines. Nevertheless, I will try out, what happens, when not all of these line-wrappings are there, e.g., when writing new code. --> Is this something that is enforced? Or is it not enforced because both options are allowed, and it was just coming up due to the automatic reformat? ;) So please just see it more as a note than a vote :) And I am curious, what other people — and especially the more programming-experts — will say. |
It is enforced. If you split lines in a different way, the format checker will complain.
Sure. Thanks. |
This usually takes a while to get used to. Somehow, the overall opinion seems to be that long lines are less readable. The rust formatter as well as the very popular prettier formatter for Javascript also favor rather short lines. This also is not my favorite, especially for languages with type arguments, but then I don't care enough to invent my own format :-) |
I VERY MUCH for relatively long lines.
On 4. Dec 2023, at 10:47, Janek Laudan ***@***.***> wrote:
This does not really help to improve the readability and also makes files much longer
This usually takes a while to get used to. Somehow, the overall opinion seems to be that long lines are less readable. The rust formatter as well as the very popular prettier formatter for Javascript also favor rather short lines. This also is not my favorite, especially for languages with type arguments, but then I don't care enough to invent my own format :-)
—
Reply to this email directly, view it on GitHub<#2963 (comment)>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/ACC67MIWCNDQI453WOSIBG3YHWL3RAVCNFSM6AAAAAA72ZQ6OCVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTQMZYGE4DEOBWG4>.
You are receiving this because you are subscribed to this thread.Message ID: ***@***.***>
|
Re line length: This formatter limits it at 100, but having 2-space indentation gives a little extra spaces within that limit, compared to the current style (4-space long tabs). This PR results in 10% more lines, but I guess it is mainly a small fraction of complex (often hard to read) multi-line sections that contribute to this 10% increase. I would even guess that having the limit increased from 100 to 140 will probably have no significant impact. I looked a bit to find some examples in the drt contrib. Example 1: drtCfg.getDrtSpeedUpParams().ifPresent(drtSpeedUpParams -> {
bindModal(DrtSpeedUp.class).toProvider(modalProvider(
getter -> new DrtSpeedUp(getMode(), drtSpeedUpParams, getConfig().controller(),
getter.get(Network.class), getter.getModal(FleetSpecification.class),
getter.getModal(DrtEventSequenceCollector.class)))).asEagerSingleton();
addControlerListenerBinding().to(modalKey(DrtSpeedUp.class));
}); is formatted into something more structured: drtCfg
.getDrtSpeedUpParams()
.ifPresent(
drtSpeedUpParams -> {
bindModal(DrtSpeedUp.class)
.toProvider(
modalProvider(
getter ->
new DrtSpeedUp(
getMode(),
drtSpeedUpParams,
getConfig().controller(),
getter.get(Network.class),
getter.getModal(FleetSpecification.class),
getter.getModal(DrtEventSequenceCollector.class))))
.asEagerSingleton();
addControlerListenerBinding().to(modalKey(DrtSpeedUp.class));
}); Example 2: .in(Singleton.class); // Not an eager binding, as taxi contrib doesn't need this implementation, but
// would search for VrpLegFactory which is provided in the
// DrtModeOptimizerModule if bound eagerly The comment is located a bit unfortunately, so the automated formatting leads to the following: .in(
Singleton
.class); // Not an eager binding, as taxi contrib doesn't need this implementation,
// but
// would search for VrpLegFactory which is provided in the
// DrtModeOptimizerModule if bound eagerly There is no support for more intelligent "re-formatting" of comments. However, problems like this one will get resolved over time as we modify existing code. Example 3: entriesList.forEach(entry -> writer.writeNext(
new String[] { zone.getId(), "" + c.getX(), "" + c.getY(), "" + entry.getFirst(),
"" + entry.getSecond() }, false)); gets formatted into something which is presumably more readable, but longer: entry ->
writer.writeNext(
new String[] {
zone.getId(),
"" + c.getX(),
"" + c.getY(),
"" + entry.getFirst(),
"" + entry.getSecond()
},
false)); Example 4: private record DrtLeg(Id<Request> request, double submissionTime, double departureTime, Id<Person> person, Id<DvrpVehicle> vehicle, Id<Link> fromLinkId, Coord fromCoord,
Id<Link> toLinkId, Coord toCoord, double waitTime, double unsharedDistanceEstimate_m, double unsharedTimeEstimate_m,
double arrivalTime, double fare, double earliestDepartureTime, double latestDepartureTime, double latestArrivalTime) {
} This long record definition starts to look more like a java class definition after formatting: private record DrtLeg(
Id<Request> request,
double submissionTime,
double departureTime,
Id<Person> person,
Id<DvrpVehicle> vehicle,
Id<Link> fromLinkId,
Coord fromCoord,
Id<Link> toLinkId,
Coord toCoord,
double waitTime,
double unsharedDistanceEstimate_m,
double unsharedTimeEstimate_m,
double arrivalTime,
double fare,
double earliestDepartureTime,
double latestDepartureTime,
double latestArrivalTime) {} My overall impression is that the formatted code is easier to read. Moreover, the whole codebase is formatted in the same way, which always increases the readability (regardless of the chosen formatter). |
Has there been any progress on this? Could we maybe just start deploying it per contrib (= drt ;-) ) |
No final decision yet. I think everyone wants it, but there is no formatting that satisfies everyone :-) So we are a bit stuck. I guess we need to be a bit more realistic with our expectations and weigh pros and cons. I think the easiest way to move on is to do an all-in-one-go transition:
|
Ok thanks, personally, I don't care about the style as long as there is one as a couple of other people here, I think. Maybe we should put it to vote at the MATSim User Meeting :) |
I like the code style with shorter lines :) take my vote |
There is a growing interest in standardising Java code formatting in MATSim. We discussed this topic several times in the past, and recently it was brought up during Code Sprint 2023: https://github.com/orgs/matsim-org/projects/4?pane=issue&itemId=40934408.
This PR suggests a reasonably straightforward approach:
Formatting
(excerpt from README.md)
We use fmt-maven-plugin for formatting Java code according to Google Java Style.
This maven plugin internally uses google-java-format to format code or check if it has been properly formatted.
To format code, run
mvn com.spotify.fmt:fmt-maven-plugin:format
.For ease of coding, we suggest configuring the code formatting settings in your IDE (see instructions for IntelliJ
and Eclipse).
Java code formatting is checked during the
verify
phase in maven. Passing this check is required for merging a PR to protected branches.TODO
(if we decide for this formatting approach)
This PR is a draft for evaluating this approach. If we decide to adapt it, a new PR will be created (from the latest commit on master) to avoid resolving conflicts.
After merging to master, all open PRs will need to be adapted to the new formatting before they can be merged to master. The simplest approach could look like:
We need to test this path first, but once tested, steps (2-5) can be handled automatically with a script, so only step (1) will require some manual work of the branch owner/author.
However, it would be good to merge as many open PRs as possible before the code formatting gets introduced.