-
-
Notifications
You must be signed in to change notification settings - Fork 14.7k
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
zig: commonify & bootstrap #331011
base: master
Are you sure you want to change the base?
zig: commonify & bootstrap #331011
Conversation
92ca0ed
to
511678d
Compare
pkgs/by-name/me/meson/package.nix
Outdated
hash = "sha256-dDOmSRBKl/gs7I3kmLXIyQk3zsOdlaYov72pPSel4+I="; | ||
}) | ||
]; | ||
./linker-support-zig-cc.patch; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why are we patching this in Nixpkgs at all instead of fixing it properly upstream? My read of the upstream PR was that upstream was responsive and interested, and that there was just the small issue of getting the test suite fixed left to do, and upstream had even provided a hint for how to do that.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Because there's already an upstream PR. This is just a vendored copy after reading the feedback left after #318034 was merged. I don't see anything about a test suite fix and I'm not familiar with how meson works.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I understand that this is just vendoring the patch, but I'm not thrilled that it was added in the first place — the original author of the upstream PR doesn't seem to be continuing with it, which means that we have to keep this patch around (with the implied maintenance burden on Nixpkgs' Meson maintainers) until somebody else picks it up. We can add patches to Nixpkgs when they're urgent, when it's not feasible to upstream them, or when it's doing something Nixpkgs-specific, but allowing patches like this, where none of those things are true, means that, for non-maintainers, there's never any incentive to upstream anything, resulting in packages getting more and more complicated until they collapse under their own weight. For that reason, I think this patch needs to be sorted out upstream, and that we should not keep it around in Nixpkgs in the meantime. The path to getting it upstream is clear, and doesn't sound like it would be a lot of work.
I don't see anything about a test suite fix
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, @tomberek and I talked yesterday about this patch. I only added it so meson projects would at least configure in pkgsZig
. I understand the patch isn't exactly stable but there's not really any other way around the error which occurs without this patch. The problem looks like tests in meson fail because Zig doesn't support a flag which means we likely would have to implement the -rpath-link
flag.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
there's not really any other way around the error which occurs without this patch.
Well, there is, and it's to help this get fixed upstream, which as far as I can see means just extending an existing check to also check for Zig.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Alright, I've made a patch mesonbuild/meson#13493
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great, thanks. For testing on NixOS I just use a nix-shell with python3 and whatever else the test suite needs.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah it looks like I'll need to pull in the CC wrapper for the tests to perform correctly.
c19a377
to
ace18eb
Compare
The CI is considered not correct on unused arguments in this case, as noted in #331085. |
a0c11c2
to
5af85b0
Compare
|
5af85b0
to
6f3ab6e
Compare
|
I've figured out that Zig 0.9 and 0.10 have the |
we can soon remove 0.9 benbusby/colorstorm#15 |
zig 0.10 is also unused after #365116 |
4a3852d
to
56506fd
Compare
db214ed
to
356a033
Compare
@RossComputerGuy is it possible to extract "commonify" portion into separate PR that can be merged sooner ? |
Sorry for the late reply, yes it is possible however this PR contains fixes for pkgsZig which we should get in. |
understood, let me know if there is anything i can do to help to get this merged |
Only reviews are required, I'm low on bandwidth so I'll be slow to update things. |
356a033
to
4c49050
Compare
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looking at wrapBintoolsWith and wrapCCWith's source code, it seems that ld should go in bintools instead of cc, and clang/clang++ must not be prefixed with targetPrefix to be wrapped correctly:
if [ -e ''${ld:-$ldPath/${targetPrefix}ld} ]; then |
elif [ -e $ccPath/clang ]; then |
elif [ -e $ccPath/clang++ ]; then |
} | ||
'' | ||
mkdir -p $out/bin | ||
for tool in ar objcopy ranlib; do |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
for tool in ar objcopy ranlib; do | |
for tool in ar ld.lld objcopy ranlib; do |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
makeWrapper "$zig/bin/zig" "$out/bin/${targetPrefix}$tool" \ | ||
--add-flags "$tool" \ | ||
--run "export ZIG_GLOBAL_CACHE_DIR=\$(mktemp -d)" | ||
done |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done | |
done | |
mv $out/bin/${targetPrefix}ld.lld $out/bin/${targetPrefix}ld |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
for tool in cc c++ ld.lld; do | ||
makeWrapper "$zig/bin/zig" "$out/bin/${targetPrefix}$tool" \ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
for tool in cc c++ ld.lld; do | |
makeWrapper "$zig/bin/zig" "$out/bin/${targetPrefix}$tool" \ | |
for tool in cc c++; do | |
makeWrapper "$zig/bin/zig" "$out/bin/$tool" \ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
mv $out/bin/${targetPrefix}c++ $out/bin/${targetPrefix}clang++ | ||
mv $out/bin/${targetPrefix}cc $out/bin/${targetPrefix}clang | ||
mv $out/bin/${targetPrefix}ld.lld $out/bin/${targetPrefix}ld |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
mv $out/bin/${targetPrefix}c++ $out/bin/${targetPrefix}clang++ | |
mv $out/bin/${targetPrefix}cc $out/bin/${targetPrefix}clang | |
mv $out/bin/${targetPrefix}ld.lld $out/bin/${targetPrefix}ld | |
mv $out/bin/cc $out/bin/clang | |
mv $out/bin/c++ $out/bin/clang++ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Using the $TMPDIR variable (with a default to /tmp) instead of calling mktemp on each invokation of zig speeds up compilation (or even configure scripts) by an order of magnitude on my machine.
]; | ||
|
||
preBuild = '' | ||
export ZIG_GLOBAL_CACHE_DIR="$TMPDIR/zig-cache"; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
export ZIG_GLOBAL_CACHE_DIR="$TMPDIR/zig-cache"; | |
export ZIG_GLOBAL_CACHE_DIR="$TMPDIR/zig-cache" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
for tool in cc c++ ld.lld; do | ||
makeWrapper "$zig/bin/zig" "$out/bin/${targetPrefix}$tool" \ | ||
--add-flags "$tool" \ | ||
--run "export ZIG_GLOBAL_CACHE_DIR=\$(mktemp -d)" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
--run "export ZIG_GLOBAL_CACHE_DIR=\$(mktemp -d)" | |
--run "export ZIG_GLOBAL_CACHE_DIR=\''${TMPDIR-/tmp}/zig-cache" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
for tool in ar objcopy ranlib; do | ||
makeWrapper "$zig/bin/zig" "$out/bin/${targetPrefix}$tool" \ | ||
--add-flags "$tool" \ | ||
--run "export ZIG_GLOBAL_CACHE_DIR=\$(mktemp -d)" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
--run "export ZIG_GLOBAL_CACHE_DIR=\$(mktemp -d)" | |
--run "export ZIG_GLOBAL_CACHE_DIR=\''${TMPDIR-/tmp}/zig-cache" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
4c49050
to
b6ef265
Compare
@kirillrdy Those errors should be fixed now, |
b6ef265
to
baebc26
Compare
Would it hurt if this pr includes a patch for std.system.darwin.getSdk or does a seperate pr need to be made? |
|
Description of changes
This is the first step towards my goal of being able to bootstrap LLVM in Nix with Zig. A couple things this PR does is commonify Zig to make handling future updates simpler, I've been meaning to do this for a while. This PR also implements the bootstrap derivations for Zig.
Things done
nix.conf
? (See Nix manual)sandbox = relaxed
sandbox = true
nix-shell -p nixpkgs-review --run "nixpkgs-review rev HEAD"
. Note: all changes have to be committed, also see nixpkgs-review usage./result/bin/
)Add a 👍 reaction to pull requests you find important.