-
Notifications
You must be signed in to change notification settings - Fork 461
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
Quick up-to-date checking for custom rules (sub to #31) #47
Comments
I don't think we need this. Writing rules as standalone classes is straightforward enough for people who want the performance. Groovy has an EqualsAndHashcode annotation that does the boilerplate for you. Plus many build scripts will be totally fine with just the built in rules. |
After these preliminary explorations, I agree that most users won't need it, but I like having a quick shortcut available to users who want it Also, as implemented in eefdc50, I think that even if users don't call |
Final name for this rule is |
In order for incremental builds and up-to-date checking to work, we need
FormatCheckTask
to properly implement serializable, equals, and hashCode. This means that FormatStep and all of its implementations (eclipse, google-java-format, regex, etc.) will also have to implement these contracts, which is straightforward to do.The downside is that custom rules, along the lines of:
will always be out-of-date unless they properly implement the contract. One quick way to resolve this is to have a
ForwardingFormatStep
which delegates all of its serializable/equals/hashCode tasks to some delegate object. Then custom rules could easily be written asBut if any rule in a list has changed, then the entire format has to rerun. Sooo, instead of checking each rule, we could instead check them globally across the format:
If a project has even two custom rules, then this format-global approach is easier than having a version per custom rule.
The next question is whether we want to use this functionality to remove the requirement for FormatTasks to implement serializable/equals/hashCode at all, and just rely on
bumpThisNumberIfRulesChange()
to entirely encapsulate changes to the rules.On the one side, we should have spotless be as fast as possible with as little user input as possible, and there are plenty of users that are only using built-in rules, so
bumpThisNumberIfRulesChange()
should be limited to a useful override for handling custom rules. Thoughts?The text was updated successfully, but these errors were encountered: