Le 2025-03-17 21:44, Moritz a écrit :
Yes, I built a crude generator for this based on the output from
`./gradlew [module]:dependencies --configuration compileClasspath` to
get the module dependencies with each other. I think most poms are
unchanged from the generated code. I've uploaded the code as a PR here
<https://github.com/MorMundHS-MA/gradle-maven-bootstrap/pull/2>
If you made that into a custom Gradle task like I did for
MakefileMakerTask you could get rid of the parser and the hardcoding in
SettingsParser, and possibly find ways to minimize the amount of manual
tweaking afterwards.
Not sure if Makefiles will be a good choice, as the project is large
with a lot of dependencies between the modules. The generated poms are
easily reviewable by a human, I think this will be much harder with
Makefiles. But maybe I'm overthinking the supply chain trust issues
with bootstrapping build tools.
Having looked at both I think they are both similarly inconvenient to
review ;) mostly because this is a large project.
The generated PoC Makefile for Gradle 8 is more than 7 MiB and 77k
lines, but on the other hand it lists exhaustively every single source
file, jar dependency and intermediate generated file input for every
task. This is IMO interesting for auditing source code as you can then
use that as an input to identify unused source files or graph which
tasks are run for a given source file (I add comments with the original
gradle task name and dependencies into that Makefile). There is
certainly some Graphviz potential in there.
Other technical reasons that made me choose a Makefile over other
possibilities were:
- it's a single file, and it's trivial to keep it out of the upstream
source tree and relocate it if needed (which is much more convenient for
packaging)
- it's future-proof: the generated syntax has worked for decades, and is
extremely unlikely to stop working with future releases of GNU Make
(which removes a whole source of possible future issues with the
generator code)
- dependencies are resolved at generation time by Gradle (tweaked by a
custom plugin and Debian helper libraries) which makes the build fairly
reproducible; having the dependencies resolved again at build time by a
different tool (in theory the logic is the same, but the devil is in the
details) may introduce issues.
I was hoping that bootstrapping one modern version of Gradle/Kotlin
would be enough to build future versions using the tooling itself. But
I don't know how commonly they still introduce new
functionality/breaking changes that would prevent building with older
versions.
Unfortunately with their development model that can't be ensured,
especially on the Gradle side. They don't even try to make a given
release of Gradle buildable by a previously released version. New major
releases are commonly built by rc releases, which may be built by
milestone releases or even nightly builds. I'm pretty sure that Gradle 9
for example is going to introduce breaking changes that will make it
impossible to build it with any release of Gradle 8 without downgrading
or rewriting significant parts of the build scripts, which is not
trivial. I'm expecting that bootstrapping it again is going to be
easier.
Which version of Kotlin has been bootstrapped? I think Debian had 1.3
at some point, but I'm not sure if that was completely built from
source. At least it isn't available in testing anymore.
That's 1.3.31 currently. Thank you for reminding me that it's still not
into testing, I've just closed two resolved FTBFS bugs to see if that
helps with the migration.
Gradle also references these dependencies that are built with Gradle
(list won't be complete, just the obvious ones):
* kotlin-stdlib
* kotlin-reflect
* kotlin-compiler-embeddable (dependency of
'gradle-declarative-dsl-core', probably the biggest one together with
stdlib as it requires a modern bootstrapped kotlin compiler)
These are packaged with kotlin,
* kotlinx-serialization-core
* kotlinx-serialization-json
these will be with kotlinx-serialization,
* org.jetbrains.annotations
* org.jetbrains.intellij.deps.trove4j
and these are already packaged (libjetbrains-annotations-java and
libtrove-intellij-java) and appear to be usable to rebuild gradle.
There is also one additional Gradle repository, which I cannot find
right now. But I had to downgrade its version manually as the Gradle
devs hadn't uploaded their newest version to a public registry yet when
I was working on it. But it was also built with Gradle.
native-platform and/or fileevents maybe? That happens sometimes, or they
forget to push release tags. Messaging them on their Slack usually gets
the issue quickly resolved.
Cheers,
--
Julien Plissonneau Duquène