-
-
Notifications
You must be signed in to change notification settings - Fork 51
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
Building Crates in Nix #1769
Comments
I presume that
I don't see a problem here, this should be a minor patch.
This can be disabled via
We should explore this (mis?)conception in more detail, because I don't think there's anything preventing this on principle. Actually someone from AdaCore recently submitted a test to verify that builds can be performed in air-gapped systems, see #1760.
With vendored dependencies, I'm asuming you mean local copies of dependencies? Alire has specific ways to access such dependencies for "pulling" (using a local folder or tarball). Another possibility would be to "pin" to the sources prior to building. This would require a custom index or some scripting.
If Nix can provide gnat and gprbuild, then these can also be used by Alire, bypassing any remote toolchain. I'm not sure I follow the implications of this point. On the general intent, I'm happy to help with this, and I think the rough building blocks are already there. It may require some scripting, but maybe not even big changes to Alire itself. Of course, if some new feature is needed that would save you lots of time, that's the first thing that we should identify. I guess the next steps would be to have a minimal proof-of-concept? And I can try to help you with any blockers? |
Thanks for the quick reply - I very much appreciate you correcting most of my misconceptions. I'll send a PR to fallback if $HOME doesn't have adequate perms/can't be created, and then I'll try to put together a proof of concept based on that airgapped test.
Honestly, I think I just didn't know about the mechanisms that do exist. I'll look at what that test does and see if I can't replicate it in Nix - thanks for proving me wrong there.
Cross-compilation and the like come to mind. There are cases where the toolchain specified by Alire isn't the toolchain that Nix provides, and I'd want to be able to address those. That said, it's not a crucial point yet. Again, thanks for the detailed response - I'll be back with a bit more code :) |
OK, now I understand. Good luck with the PoC! |
Nix has some somewhat aligned goals to Alire, but goes about them at the level of a package manager rather than language-level tooling. Nix can be used to wrap some build tools (traditionally autotools, but there's good integration with cmake, meson, cargo, go, &c) to enable and provide reproducible packaging.
I would like to be able to package Alire crates in Nix. To do so, I'm testing with the following derivation:
If you run this, you run into these two issues first:
/homeless-shelter
. For Alire not to complain, we have tounset HOME
prior toalr build
. Alternatively, Alire could automatically fallback to a/tmp
directory if $HOME doesn't exist and can't be created --- would that be a good thing for it to do? I'd be happy to send a PR.nativeBuildInputs
so that it's available, but then we run into a more fundamental issue: Nix doesn't allow derivations to access the internet*, and the first thing Alire tries to do is fetch the index.*Fixed-output-derivations allow for internet access in exchange for a hash of the expected output to ensure reproducibility. Nix wrappers of, e.g., Go and Cargo each use this to build a 'vendored' version of their packages, and then perform an offline build.
The broader issue, however, appears to be that there is no existing mechanism for offline and sandboxed builds. Thus, two things primarily are required to support Nix:
There's also a secret third extra difficulty in that Nix can't run binaries downloaded from the internet due to dynamic linking issues. This is obviously very much at odds with Alire's toolchain mechanism. I would think that part of an offline build involves using the native or local toolchain, but that doesn't strike me as a complete solution.
Is this impression correct? Am I understanding the problem space well; i.e., is this all required to build Alire crates with Nix? Do you think I'm missing anything or making it more complicated than it needs to be?
If this or something similar looks reasonable, I think I should be able to devote some time to implementing the changes required to get Alire working in this setting. I would appreciate some help, however, in strategizing a way to do this all incrementally and cleanly. Thanks for any input you could provide!
The text was updated successfully, but these errors were encountered: