-
Notifications
You must be signed in to change notification settings - Fork 8
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
Keep truffle runtime now that its' footprint is minimal #369
Conversation
This change only increases the Mandrel installation by 1MB, while allowing users to use Truffle maven artifacts. However it comes at the cost of the following build-time dependencies: - ANTLR4 - TRUFFLE_ASM - TRUFFLE_JCODINGS Unfortunately, dropping these dependencies results in build failures, as expected.
Let me try to sound-board this. Right now, we don't support truffle-runtime. If we were to include truffle-runtime, then we'd depend on If I did understand this correctly, then those dependencies are not worth the trouble of <insert-benefit-here\>. We haven't needed it in the past and packaging those dependencies is a can of worms I'd rather not open. Is the plan to get this merged? |
You got it right. No the plan is to not merge it. I opened it as draft to have in record what we tried and why we don't want it (at least for now). I am closing it. |
Thanks for the clarification. |
@zakkak let me know if I can help with the truffle svm runtime integration in Mandrel. Its definitely much easier now to integrate truffle in the new unchained world since 23.1. All you basically need to keep is the truffle-svm-runtime.jar and the truffle-svm macro. You should not add it to the builder class-path always as it has a lot of dependencies we can only resolve if truffle-runtime.jar is on the class or module-path. The way this works is that if truffle-runtime.jar is on the class or module-path it activates the
Customizing this allows you to put the truffle-runtime-svm.jar anywhere you want. You just should not put it on the builder class-path by default as it requires a lot of dependencies regular applications don't have. |
@chumer thanks for looking into this. Our main issue is that in order to build
If we could use the original ASM and JCODINGS it would allow us to build without issues AFAIU. |
@zakkak you should be able to use the 23.1 (or latest LTS) of truffle and its dependencies from Maven central to build truffle-svm-runtime.jar. We are currently considering to move to a build like this internally by default. No decision yet. |
We build everything from source, so an external dependency from Maven central is not possible for us. |
@jerboaa you only need it to compile you don't need to ship any of these things. |
@chumer Since it's a compile time dependency, we need to build the compile time deps from source too. That's the trouble. |
Hi, are there any plans on making truffle work in native-image with mandrel? I'm getting an error while trying to build a project using it:
|
No, sorry. There are no plans on supporting that. Use GraalVM for JDK 21 instead. |
I think that could work, will give it a try. FTR the referenced code above is https://github.com/oracle/graal/blame/d5f2e7c44a2f9c123d78d0dcffa1c096152d6286/truffle/mx.truffle/suite.py#L1088 (since the original link is not a permanent one) Disclaimer: This doesn't mean we plan to support Truffle, we are just experimenting at this stage. |
This change only increases the Mandrel installation by 1MB, while allowing users to use Truffle maven artifacts.
However it comes at the cost of the following build-time dependencies:
Unfortunately, dropping these dependencies results in build failures, as expected. As a result IMO it's not worth the effort as it's not a priority for us. @jerboaa WDYT?