summary refs log tree commit diff
path: root/pkgs/build-support/rust/hooks
diff options
context:
space:
mode:
authorDaniël de Kok <me@danieldk.eu>2021-02-11 19:17:06 +0100
committerDaniël de Kok <me@danieldk.eu>2021-02-12 08:40:43 +0100
commit160cf87086694f6d2007e7d427a6dee089266e93 (patch)
tree614a6147736c93b4e2862a3744ebb8ec5d5b57d8 /pkgs/build-support/rust/hooks
parent7876d1c252af514423296473143964112ef88148 (diff)
downloadnixpkgs-160cf87086694f6d2007e7d427a6dee089266e93.tar
nixpkgs-160cf87086694f6d2007e7d427a6dee089266e93.tar.gz
nixpkgs-160cf87086694f6d2007e7d427a6dee089266e93.tar.bz2
nixpkgs-160cf87086694f6d2007e7d427a6dee089266e93.tar.lz
nixpkgs-160cf87086694f6d2007e7d427a6dee089266e93.tar.xz
nixpkgs-160cf87086694f6d2007e7d427a6dee089266e93.tar.zst
nixpkgs-160cf87086694f6d2007e7d427a6dee089266e93.zip
rustPlatform.maturinBuildHook: init
This build hook can be used to build Python packages using maturin.
Diffstat (limited to 'pkgs/build-support/rust/hooks')
-rw-r--r--pkgs/build-support/rust/hooks/default.nix11
-rw-r--r--pkgs/build-support/rust/hooks/maturin-build-hook.sh39
2 files changed, 50 insertions, 0 deletions
diff --git a/pkgs/build-support/rust/hooks/default.nix b/pkgs/build-support/rust/hooks/default.nix
index e33d5813a13..d4b2cc15605 100644
--- a/pkgs/build-support/rust/hooks/default.nix
+++ b/pkgs/build-support/rust/hooks/default.nix
@@ -4,6 +4,7 @@
 , diffutils
 , lib
 , makeSetupHook
+, maturin
 , rust
 , stdenv
 , target ? rust.toRustTargetSpec stdenv.hostPlatform
@@ -62,4 +63,14 @@ in {
         '';
       };
     } ./cargo-setup-hook.sh) {};
+
+  maturinBuildHook = callPackage ({ }:
+    makeSetupHook {
+      name = "maturin-build-hook.sh";
+      deps = [ cargo maturin ];
+      substitutions = {
+        inherit ccForBuild ccForHost cxxForBuild cxxForHost
+          rustBuildPlatform rustTargetPlatform rustTargetPlatformSpec;
+      };
+    } ./maturin-build-hook.sh) {};
 }
diff --git a/pkgs/build-support/rust/hooks/maturin-build-hook.sh b/pkgs/build-support/rust/hooks/maturin-build-hook.sh
new file mode 100644
index 00000000000..7e2599d9224
--- /dev/null
+++ b/pkgs/build-support/rust/hooks/maturin-build-hook.sh
@@ -0,0 +1,39 @@
+maturinBuildHook() {
+    echo "Executing maturinBuildHook"
+
+    runHook preBuild
+
+    if [ ! -z "${buildAndTestSubdir-}" ]; then
+        pushd "${buildAndTestSubdir}"
+    fi
+
+    (
+    set -x
+    env \
+      "CC_@rustBuildPlatform@=@ccForBuild@" \
+      "CXX_@rustBuildPlatform@=@cxxForBuild@" \
+      "CC_@rustTargetPlatform@=@ccForHost@" \
+      "CXX_@rustTargetPlatform@=@cxxForHost@" \
+      maturin build \
+        --cargo-extra-args="-j $NIX_BUILD_CORES --frozen" \
+        --target @rustTargetPlatformSpec@ \
+        --manylinux off \
+        --strip \
+        --release \
+        ${maturinBuildFlags-}
+    )
+
+    runHook postBuild
+
+    if [ ! -z "${buildAndTestSubdir-}" ]; then
+        popd
+    fi
+
+    # Move the wheel to dist/ so that regular Python tooling can find it.
+    mkdir -p dist
+    mv target/wheels/*.whl dist/
+
+    echo "Finished maturinBuildHook"
+}
+
+buildPhase=maturinBuildHook