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

Feature request: add support for running on gradle source sets #2240

Closed
staktrace opened this issue Aug 28, 2024 · 2 comments
Closed

Feature request: add support for running on gradle source sets #2240

staktrace opened this issue Aug 28, 2024 · 2 comments

Comments

@staktrace
Copy link
Contributor

The below is inspired specifically by using the ktfmt/ktlint formatters on kotlin code in a gradle project, but perhaps applies to other languages/tools too.

When running spotless before compile, there is a chance that it runs on uncompilable code (because the author has syntax errors or whatever). In such cases, the compiler error messages may be obscured by spotless tool failures. ktlint in particular has pretty bad error messages when it encounters code with syntax errors. This makes it hard to resolve the syntax errors.

A better approach is to use finalizedBy to run spotless linting after compile. This still ensures the code is linted as it is being written, but without obscuring compiler errors. However, in gradle, compilation runs on a per-sourceset basis. That is, a gradle project may have multiple sourcesets (main, test, etc.) and each one has its own compilation task. The spotlessApply (or spotlessKotlinApply) task, however, runs on the per-project basis. This means you could still encounter the same problem: make broken-syntax changes to the test sourceset, make a compilable change to the main sourceset, and then compile the main sourceset - this will compile main, then run the "finalizer" spotlessApply, which will fail on the test code.

One way to resolve this would be to introduce tasks that run on a per-sourceset basis. So then we could do things like finalize the compileKotlin task with spotlessApplyMain and finalize compileTestKotlin with spotlessApplyTest and so on. There might be other ways to resolve the issue as well, I'm open to suggestions.

We could probably prove out the concept in a separate plugin that uses the "IDE hook" integration point to iterate through files in a sourceset, but it seems like it would be better if it were implemented directly in the spotless plugin.

@nedtwigg
Copy link
Member

One way to resolve this would be to introduce tasks that run on a per-sourceset basis.

Spotless lets you do that, although it takes a fair bit of custom configuration on your part.

compiler error messages may be obscured by spotless tool failures

This will be improved by

@staktrace
Copy link
Contributor Author

Spotless lets you do that, although it takes a fair bit of custom configuration on your part.

Do you have any examples of prior art or APIs that might be useful in this custom configuration? In particular if there's something better than the IDE hook and iterating over files one at a time (which I suspect would be kinda slow because of gradle overhead) I'd love to hear about it!

Thanks 🙇

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

No branches or pull requests

2 participants