idiomatic-gradle
How do I idiomatically structure a large build with Gradle 7.2+? (by jjohannes)
kotlin-plugin
Build kotlin code using sbt (by pfn)
idiomatic-gradle | kotlin-plugin | |
---|---|---|
5 | 1 | |
480 | 136 | |
- | - | |
3.9 | 0.0 | |
3 months ago | over 1 year ago | |
Java | Scala | |
Apache License 2.0 | MIT License |
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
idiomatic-gradle
Posts with mentions or reviews of idiomatic-gradle.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2023-04-13.
-
Android Developers Blog: Kotlin DSL is Now the Default for New Gradle Builds
You should look into how https://github.com/jjohannes/idiomatic-gradle and similar projects handle it (nowinandroid has a good set up as well).
-
just enough gradle
And finally, look at the idiomatic gradle repo. There is also a free video series that goes with this Understanding Gradle – Video Series. There are lots of bad practices in gradle that will slow your builds down, like using allProjects {}
-
For builds: Gradle vs Maven vs IntelliJ
I'd suggest getting rid of buildSrc, and just using build composition. I mentioned in another response, but check out https://github.com/jjohannes/idiomatic-gradle for how to use precompiled script plugins that are connected to the project via includedBuilds. The only issues I've had with this are generally resolved by just running the sub-build independently to resolve any caching issues in the 'primary' build. A simple gradlew build --settings-file ./build-logic/settings.gradle.kts run will generally resolve that, and that issue seems largely because of the 'root' build being a peer or anscestor of the included build (due to legacy structure of the project, an issue the linked example repo does not have).
-
Herding elephants: Wrangling a 3,500-module Gradle project
When we initially migrated from buildSrc to an included build, it seemed an elegant solution to the problems outlined above. We were dropping buildSrc, with all its problems, and using the modern facility that Gradle considers the preferred, idiomatic replacement for buildSrc. (For a very elaborate example of this, see the idiomatic-gradle repo by former Gradle engineer Jendrik Johannes.) Included builds are indeed the best of both worlds in many ways: they can exist under version control in the same repository as the build that uses them; they can be easily opened in a separate IDE instance, improving build engineer productivity; they don't have the automatic test behavior of buildSrc, which improves feature engineer performance; and they're generally very well-behaved, without any of the magic of buildSrc.
kotlin-plugin
Posts with mentions or reviews of kotlin-plugin.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2022-05-25.
-
For builds: Gradle vs Maven vs IntelliJ
You’d need a Kotlin sbt plugin. The build is declared in ./build.sbt using Scala syntax. The official docs are comprehensive. You could generate an empty Scala project in IntelliJ and add the Kotlin plug-in, and then copy your code package by package and see how well it gets built and integrates, something small, a sort of a smoke test.
What are some alternatives?
When comparing idiomatic-gradle and kotlin-plugin you can also consider the following projects:
gradle-maven-publish-plugin - A Gradle plugin that publishes your Android and Kotlin libraries, including sources and javadoc, to Maven Central or any other Nexus instance.
slack-gradle-plugin - Gradle and IntelliJ build tooling used in Slack's Android repo
custom-floating-action-button - This view is for replacement of standard Floating Action Button from Google Support Library. It is easy to use, customizable and you can also add text to button
nowinandroid - A fully functional Android app built entirely with Kotlin and Jetpack Compose
Gradle buildSrcVersions - Life is too short to google for dependencies and versions