summary refs log tree commit diff
path: root/pkgs/build-support
diff options
context:
space:
mode:
authorAndreas Rammhold <andreas@rammhold.de>2020-03-17 16:33:13 +0100
committerAndreas Rammhold <andreas@rammhold.de>2020-04-13 16:01:21 +0200
commita9fdfebc6bab2782b0751f19d2885b195002b2bd (patch)
tree34dde6e1652c0f80481b2fc265db80db6e8cfdd9 /pkgs/build-support
parent9e2a52f239f99e460ec4a0d54f9b3cb7bc781f4a (diff)
downloadnixpkgs-a9fdfebc6bab2782b0751f19d2885b195002b2bd.tar
nixpkgs-a9fdfebc6bab2782b0751f19d2885b195002b2bd.tar.gz
nixpkgs-a9fdfebc6bab2782b0751f19d2885b195002b2bd.tar.bz2
nixpkgs-a9fdfebc6bab2782b0751f19d2885b195002b2bd.tar.lz
nixpkgs-a9fdfebc6bab2782b0751f19d2885b195002b2bd.tar.xz
nixpkgs-a9fdfebc6bab2782b0751f19d2885b195002b2bd.tar.zst
nixpkgs-a9fdfebc6bab2782b0751f19d2885b195002b2bd.zip
buildRustCrate: support proc-macro in default prelude
Diffstat (limited to 'pkgs/build-support')
-rw-r--r--pkgs/build-support/rust/build-rust-crate/build-crate.nix3
-rw-r--r--pkgs/build-support/rust/build-rust-crate/test/default.nix12
2 files changed, 15 insertions, 0 deletions
diff --git a/pkgs/build-support/rust/build-rust-crate/build-crate.nix b/pkgs/build-support/rust/build-rust-crate/build-crate.nix
index 9759235e30e..d6d1cebb2e9 100644
--- a/pkgs/build-support/rust/build-rust-crate/build-crate.nix
+++ b/pkgs/build-support/rust/build-rust-crate/build-crate.nix
@@ -16,6 +16,9 @@
       ++ [crateFeatures]
       ++ extraRustcOpts
       ++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "--target ${rust.toRustTarget stdenv.hostPlatform} -C linker=${stdenv.hostPlatform.config}-gcc"
+      # since rustc 1.42 the "proc_macro" crate is part of the default crate prelude
+      # https://github.com/rust-lang/cargo/commit/4d64eb99a4#diff-7f98585dbf9d30aa100c8318e2c77e79R1021-R1022
+      ++ lib.optional (lib.elem "proc-macro" crateType) "--extern proc_macro"
     ;
     rustcMeta = "-C metadata=${metadata} -C extra-filename=-${metadata}";
 
diff --git a/pkgs/build-support/rust/build-rust-crate/test/default.nix b/pkgs/build-support/rust/build-rust-crate/test/default.nix
index fba938f6237..674ef259909 100644
--- a/pkgs/build-support/rust/build-rust-crate/test/default.nix
+++ b/pkgs/build-support/rust/build-rust-crate/test/default.nix
@@ -412,6 +412,18 @@ let
               "test ignore_main ... ok"
             ];
           };
+      procMacroInPrelude = {
+        procMacro = true;
+        edition = "2018";
+        src = symlinkJoin {
+          name = "proc-macro-in-prelude";
+          paths = [
+            (mkFile "src/lib.rs" ''
+              use proc_macro::TokenTree;
+            '')
+          ];
+        };
+      };
     };
     brotliCrates = (callPackage ./brotli-crates.nix {});
     tests = lib.mapAttrs (key: value: mkTest (value // lib.optionalAttrs (!value?crateName) { crateName = key; })) cases;