summary refs log tree commit diff
path: root/pkgs/stdenv/generic/default.nix
diff options
context:
space:
mode:
authorVladimír Čunát <vcunat@gmail.com>2013-11-16 20:32:20 +0100
committerVladimír Čunát <vcunat@gmail.com>2013-11-16 20:32:44 +0100
commit68430cf3d7dae00f8eda1156de6b90243424e25a (patch)
tree4b008270a344486a20c8603047821923bf71e223 /pkgs/stdenv/generic/default.nix
parent8e0d77632e02720a8adf8126f126990501299191 (diff)
parentb5356f7f275e6fb15c6fda0ce65de26de98a87d0 (diff)
downloadnixpkgs-68430cf3d7dae00f8eda1156de6b90243424e25a.tar
nixpkgs-68430cf3d7dae00f8eda1156de6b90243424e25a.tar.gz
nixpkgs-68430cf3d7dae00f8eda1156de6b90243424e25a.tar.bz2
nixpkgs-68430cf3d7dae00f8eda1156de6b90243424e25a.tar.lz
nixpkgs-68430cf3d7dae00f8eda1156de6b90243424e25a.tar.xz
nixpkgs-68430cf3d7dae00f8eda1156de6b90243424e25a.tar.zst
nixpkgs-68430cf3d7dae00f8eda1156de6b90243424e25a.zip
Merge branch master into x-updates
Conflicts (trivial, minor update on master, major here):
	pkgs/development/libraries/mesa/default.nix
Diffstat (limited to 'pkgs/stdenv/generic/default.nix')
-rw-r--r--pkgs/stdenv/generic/default.nix6
1 files changed, 6 insertions, 0 deletions
diff --git a/pkgs/stdenv/generic/default.nix b/pkgs/stdenv/generic/default.nix
index f8aff33a327..fcd7439e97e 100644
--- a/pkgs/stdenv/generic/default.nix
+++ b/pkgs/stdenv/generic/default.nix
@@ -18,6 +18,8 @@ let
 
   allowUnfree = config.allowUnfree or true && builtins.getEnv "HYDRA_DISALLOW_UNFREE" != "1";
 
+  allowBroken = builtins.getEnv "NIXPKGS_ALLOW_BROKEN" == "1";
+
   stdenvGenerator = setupScript: rec {
 
     # The stdenv that we are producing.
@@ -51,6 +53,10 @@ let
         mkDerivation = attrs:
           if !allowUnfree && (let l = lib.lists.toList attrs.meta.license or []; in lib.lists.elem "unfree" l || lib.lists.elem "unfree-redistributable" l) then
             throw "package ‘${attrs.name}’ has an unfree license, refusing to evaluate"
+          else if !allowBroken && attrs.meta.broken or false then
+            throw "you can't use package ‘${attrs.name}’ because it has been marked as broken"
+          else if !allowBroken && attrs.meta.platforms or null != null && !lib.lists.elem result.system attrs.meta.platforms then
+            throw "the package ‘${attrs.name}’ is not supported on ‘${result.system}’"
           else
             lib.addPassthru (derivation (
               (removeAttrs attrs ["meta" "passthru" "crossAttrs"])