summaryrefslogtreecommitdiffstats
path: root/krebs/3modules/nixpkgs.nix
diff options
context:
space:
mode:
authortv <tv@krebsco.de>2016-02-10 19:06:32 +0100
committertv <tv@krebsco.de>2016-02-10 19:06:32 +0100
commit8b130a66287b829e7b6f9be0130df7231c7a6605 (patch)
tree98881f9e159418bb5d8ac61669db06502fd0af6a /krebs/3modules/nixpkgs.nix
parente6ea4875d467f1fbe6f39e1460352bd0d31feaea (diff)
krebs.nixpkgs.allowUnfreePredicate: init
Diffstat (limited to 'krebs/3modules/nixpkgs.nix')
-rw-r--r--krebs/3modules/nixpkgs.nix43
1 files changed, 43 insertions, 0 deletions
diff --git a/krebs/3modules/nixpkgs.nix b/krebs/3modules/nixpkgs.nix
new file mode 100644
index 000000000..4129f9483
--- /dev/null
+++ b/krebs/3modules/nixpkgs.nix
@@ -0,0 +1,43 @@
+{ config, pkgs, lib, ... }:
+with lib;
+let
+ cfg = config.krebs.nixpkgs;
+
+ out = {
+ options.krebs.nixpkgs = api;
+ config = mkIf cfg.enable imp;
+ };
+
+ api = {
+ enable = mkEnableOption "krebs.nixpkgs" // { default = true; };
+
+ allowUnfreePredicate = mkOption {
+ description = ''
+ This option is similar to `nixpkgs.config.allowUnfreePredicate'
+ but can be defined in several modules. An unfree package will be
+ allowed if any of the defined predicates returns true.
+ '';
+ type = types.nullOr (mkOptionType {
+ name = "Predicate";
+ check = isFunction;
+ merge = _locs: defs: pkg: let
+ evalPredicateDef = def: let
+ allow = def.value pkg;
+ in if cfg.verbose && allow
+ then trace "unfree ‘${pkg.name}’ allowed in ${def.file}" allow
+ else allow;
+ in any evalPredicateDef defs;
+ });
+ default = null;
+ };
+
+ verbose = mkOption {
+ type = types.bool;
+ default = false;
+ };
+ };
+
+ imp = mkIf (cfg.allowUnfreePredicate != null) {
+ nixpkgs.config.allowUnfreePredicate = cfg.allowUnfreePredicate;
+ };
+in out