aboutsummaryrefslogtreecommitdiff
path: root/package.nix
diff options
context:
space:
mode:
authorJade Lovelace <lix@jade.fyi>2024-08-20 16:52:46 -0700
committerjade <lix@jade.fyi>2024-08-21 17:09:10 +0000
commit651cc0e5b4ed4c70ed212b999d8cfa40ca7318e0 (patch)
treea504f0872caf718db17921b89e42973d040dab4b /package.nix
parentdba615098d3d28fdb3339e244a4aec778d269e85 (diff)
fix: build with meson 1.5 also
nixpkgs delivered us the untimely gift of a meson 1.5 upgrade, which *does* make our lives easier by allowing us to delete wrap generation code, but it does so at the cost of renaming all rust crates in such a way that the wrap logic cannot tolerate the new names on the old meson version 😭. It also means that support burden for this is going to be atrocious until we either give in and vendor meson 1.5 or we make a CI target for it. Neither seems appealing, though the latter is not super absurd for ensuring we don't break nixpkgs unstable. This commit causes meson 1.5 to ignore the .wrap files in subprojects/ entirely (since they have the wrong names lol) and instead use Cargo.lock, so it now hard-depends on our workspace reshuffling improvement. It also deletes the hack that we were using to get the sources of Cargo deps into meson by using a feature that went unnoticed when this code was originally written: MESON_PACKAGE_CACHE_DIR: https://github.com/mesonbuild/meson/blob/8a202de6ec763284cbb7160b9d43d5e7e0703f19/mesonbuild/wrap/wrap.py#L490-L502 Change-Id: I7a28f12fc2812c6ed7537b60bc3025c141a05874
Diffstat (limited to 'package.nix')
-rw-r--r--package.nix16
1 files changed, 5 insertions, 11 deletions
diff --git a/package.nix b/package.nix
index f37e177dd..8bba81e38 100644
--- a/package.nix
+++ b/package.nix
@@ -288,6 +288,11 @@ stdenv.mkDerivation (finalAttrs: {
env = {
BOOST_INCLUDEDIR = "${lib.getDev boost}/include";
BOOST_LIBRARYDIR = "${lib.getLib boost}/lib";
+
+ # Meson allows referencing a /usr/share/cargo/registry shaped thing for subproject sources.
+ # Turns out the Nix-generated Cargo dependencies are named the same as they
+ # would be in a Cargo registry cache.
+ MESON_PACKAGE_CACHE_DIR = finalAttrs.cargoDeps;
};
cargoDeps = rustPlatform.importCargoLock { lockFile = ./Cargo.lock; };
@@ -313,17 +318,6 @@ stdenv.mkDerivation (finalAttrs: {
install_name_tool -change ${boost}/lib/libboost_system.dylib $out/lib/libboost_system.dylib $out/lib/libboost_thread.dylib
''
+ ''
- # Copy the Cargo dependencies to where Meson expects them to be, so we
- # can seamlessly use Meson's subproject wraps, but just do the download
- # ahead of time. Luckily for us, importCargoLock-downloaded crates use
- # the exact naming scheme Meson expects!
- # The directory from importCargoLock does contain a lockfile, which we
- # don't need, but all the crate directories start with a word character,
- # then have a hyphen, and then a sequence of digits or periods for the
- # version.
- find "$cargoDeps" -type l -regex '.*/\w.+-[0-9.]+$' -exec \
- ln -sv "{}" "$PWD/subprojects/" ";"
-
# Fix up /usr/bin/env shebangs relied on by the build
patchShebangs --build tests/ doc/manual/
'';