Open Zopsss opened 3 months ago
I see the style guide as supporting your point pretty unambiguously, actually. Every annotation should go either before all the modifiers (declaration annotations) or after them (type-use annotations). (If an annotation is both kinds, knock yourselves out ...)
But I'm guessing that #5 is the main problem here. Without being able to know which kind of annotation it is, our moving it could just make it even "more wrong".
But I'm guessing that #5 is the main problem here. Without being able to know which kind of annotation it is, our moving it could just make it even "more wrong".
That's part of it, although the formatter now has heuristics for some well-known type annotations.
The other part is that the formatter mostly doesn't make non-whitespace changes, i.e. it only adds or removes whitespace and line breaks. There are some FRs that haven't been implemented for that reason here.
The support for reordering modifiers is a special case. It looks at the existing positions of the modifiers, sorts the modifiers, and adds them back at the original positions.
There's an Error Prone check that does do this kind of refactoring (AnnotationPosition).
When annotations are mixed with modifiers, formatter formats the code in following way:
From 4.8.7 Modifiers
There's not explicitly mentioned anything about position of annotations when mixed with modifiers or annotations should not be mixed with modifiers or something similar to that in above rule.
Also, in 4.8.5 Annotations, there's not explicitly mentioned that how annotations should be positioned when used with modifiers. But all sub-sections mostly refers to:
Attention to:
This kind of implies that annotations should be placed before any modifiers. But formatter does not places annotations before modifiers as shown in above example. So if annotations should not be mixed with modifiers and placed at the beginning or in a separate line then formatter should be updated and format the code according to this.