-
Notifications
You must be signed in to change notification settings - Fork 710
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
[Bazel] Dynamically generate Emscripten cache #1401
Comments
One alternative long term solution might be build all the system libraries from source via bazel rules. I know @walkingeyerobot has been thinking about this for a while now, but I'm not sure how close it is. |
I am not necessarily against that approach but that would take a bit of time, right? From (thin) LTO, PIC, and 64-bit, we have 16 (?) possible combinations multiplied by around 40 different ports/libraries? That's 640 jobs based on my estimates... |
The idea is that those system libraries would be just like any other sources in your project so only the precise config that you need to for a given build would be produced. There would be no need to enumerate them or build all of them ever. |
I am fine with this change in general. I'm too far from getting runtimes on demand to work with bazel, and if you have the bandwidth and motivation to contribute this, I'm happy to accept it. However, I don't think we can make use of bash in genrules. The bazel toolchain works on linux, mac, and windows, and while the bash that you have will work great on linux, bash on mac has some odd quirks and on windows it simply doesn't exist. If you can write this in something more portable (i.e. python) then I think that'll be fine. Also, this is complex enough that I would ask for a smoketest to be written for CI for all three supported platforms. |
I think it can be easily wrapped into a Python script, after all, it is mostly just running embuilder.py anyway. |
I am investigating a solution for solving the problem of the frozen cache + wasm64, lto, and pic once and for all. The idea is to pass both the settings and the ports that you want built to
emscripten_deps
which will generate the appropriate genrules and pull the generated files into the correct file groups so that everything is made available once during toolchain set up.To make this work, I would change
emscripten_deps
to take a two addition arguments as follows with defaults set up for backwards compatibility:The idea would be to then loop over the targets, creating a genrule for each and calling embuilder to make the asset available in the cache. The string of all genrules would then be injected into
BUILD_FILE_CONTENT_TEMPLATE
. I started work on a rough prototype but before taking it further, please let me know if there are any reservations that would prevent this getting merged.At the moment, my rough prototype sits external to
@emscripten_bin_linux//
but the idea will be to move this code inside it so that I can tweak what is available in the cache.The text was updated successfully, but these errors were encountered: