diff options
author | Lily Foster <lily@lily.flowers> | 2024-03-18 16:07:52 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-03-18 16:07:52 -0700 |
commit | 4e1ac556ab6753d4f0144d0303a49d72ca0d83e7 (patch) | |
tree | 09dabf27146e945a1394bfc14f6d81c55c5eb2ce /pkgs | |
parent | c2f60aeadc7af3f832c1ffa86bae06518d227fbf (diff) | |
parent | ea4eb0d5743edddb8d92171a8505fb6209340772 (diff) |
Merge pull request #296523 from lf-/jade/nix-doc-no-plugin
nix-doc: allow building without plugin
Diffstat (limited to 'pkgs')
-rw-r--r-- | pkgs/tools/package-management/nix-doc/default.nix | 25 |
1 files changed, 20 insertions, 5 deletions
diff --git a/pkgs/tools/package-management/nix-doc/default.nix b/pkgs/tools/package-management/nix-doc/default.nix index 2c7940b8d87d4..3d0069c87dba2 100644 --- a/pkgs/tools/package-management/nix-doc/default.nix +++ b/pkgs/tools/package-management/nix-doc/default.nix @@ -1,5 +1,17 @@ -{ lib, stdenv, rustPlatform, fetchFromGitHub, boost, nix, pkg-config }: +{ lib +, stdenv +, rustPlatform +, fetchFromGitHub +, boost +, nix +, pkg-config +# Whether to build the nix-doc plugin for Nix +, withPlugin ? true +}: +let + packageFlags = [ "-p" "nix-doc" ] ++ lib.optionals withPlugin [ "-p" "nix-doc-plugin" ]; +in rustPlatform.buildRustPackage rec { pname = "nix-doc"; version = "0.6.5"; @@ -12,17 +24,20 @@ rustPlatform.buildRustPackage rec { }; doCheck = true; - buildInputs = [ boost nix ]; + buildInputs = lib.optionals withPlugin [ boost nix ]; - nativeBuildInputs = [ pkg-config nix ]; + nativeBuildInputs = lib.optionals withPlugin [ pkg-config nix ]; + + cargoBuildFlags = packageFlags; + cargoTestFlags = packageFlags; # Packaging support for making the nix-doc plugin load cleanly as a no-op on # the wrong Nix version (disabling bindnow permits loading libraries # requiring unavailable symbols if they are unreached) - hardeningDisable = [ "bindnow" ]; + hardeningDisable = lib.optionals withPlugin [ "bindnow" ]; # Due to a Rust bug, setting -Z relro-level to anything including "off" on # macOS will cause link errors - env = lib.optionalAttrs stdenv.isLinux { + env = lib.optionalAttrs (withPlugin && stdenv.isLinux) { # nix-doc does not use nightly features, however, there is no other way to # set relro-level RUSTC_BOOTSTRAP = 1; |