Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Migration to Java #78

Open
britter opened this issue Mar 11, 2022 · 6 comments
Open

Migration to Java #78

britter opened this issue Mar 11, 2022 · 6 comments

Comments

@britter
Copy link
Owner

britter commented Mar 11, 2022

Rewrite the plugin only using plain old Java with minimal dependencies.

@britter britter added this to the 1.0.0 milestone Mar 11, 2022
@sschuberth
Copy link

sschuberth commented Aug 30, 2024

Or maybe use Kotlin also for the remaining Groovy code by now?

@britter
Copy link
Owner Author

britter commented Aug 31, 2024

Ditching Groovy for Kotlin is an interesting idea. I really love the expressiveness of Spock tests. But Spock is the only reason Groovy is in my stack everywhere.

My ultimate goal is to move the plugin to https://gradlex.org and we have the convention to have all plugins implemented in Java. That's why I want to port this one to Java as well.
The reasoning behind this is that we avoid issues with Groovy / Kotlin language version incompatibilities.

@sschuberth
Copy link

I really love the expressiveness of Spock tests. But Spock is the only reason Groovy is in my stack everywhere.

I guess you're familiar with Kotest? It has several similar test styles as well.

we have the convention to have all plugins implemented in Java. That's why I want to port this one to Java as well.

So just to double-check: Porting from Kotlin to Java? That sounds like a severe step backwards, IMO...

The reasoning behind this is that we avoid issues with Groovy / Kotlin language version incompatibilities.

I'd be interested in the details if you can share!

@britter
Copy link
Owner Author

britter commented Aug 31, 2024

So just to double-check: Porting from Kotlin to Java? That sounds like a severe step backwards, IMO...

I don't think that Kotlin or Java is a step forward or backward in either direction. Language selection should depend on the requirements. For GradleX we decided to use Java to have the least friction for users.

I'd be interested in the details if you can share!

There's not a lot to share. Let's say you build your plugin against Kotlin 1.9.x and you use a language feature that's not available in 2.x anymore. Once Gradle moves the Kotlin language level to 2.x the plugin build on 1.9.x won't work anymore. Since Gradle is implemented in Java and Java is generally pretty backwards compatible, it's less likely to run in these kinds of issues. This is also the reason why we try to avoid to have any dependencies in GradleX plugins. This can very easily cause problems, see gradle/gradle#19457.

@sschuberth
Copy link

sschuberth commented Aug 31, 2024

Once Gradle moves the Kotlin language level to 2.x the plugin build on 1.9.x won't work anymore.

Is that so? I mean, in the end it all gets compiled to JVM bytecode, and that's all what Gradle "sees" when executing a plugin, or?

This is also the reason why we try to avoid to have any dependencies in GradleX plugins.

Reducing dependencies to a minimum, with a balance of reinventing the wheel, is certainly always a good idea.

@sschuberth
Copy link

I don't think that Kotlin or Java is a step forward or backward in either direction. Language selection should depend on the requirements. For GradleX we decided to use Java to have the least friction for users.

I've seen that discussion on Slack, but I want to share another perspective: With Gradle pushing Kotlin DSL, I doubt that migrating from Kotlin to Java would attract more contributors to this plugin. On the contrary, as Java feels so extremely verbose compared to Kotlin, I myself would not want to contribute to this project if it was written in Java.

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants