summary refs log tree commit diff
path: root/lib
diff options
context:
space:
mode:
authorGleb Peregud <gleber.p@gmail.com>2017-06-24 12:42:56 +0200
committerGleb Peregud <gleber.p@gmail.com>2017-06-24 12:47:57 +0200
commit0123200dee6bd3f94dbf6fed376b3208dcefe309 (patch)
tree07b73a9024b5f39a145e625bab1cc63e1519b03f /lib
parent5e2de6d846e7e7f88378b730936b07f2fb410e0a (diff)
downloadnixpkgs-0123200dee6bd3f94dbf6fed376b3208dcefe309.tar
nixpkgs-0123200dee6bd3f94dbf6fed376b3208dcefe309.tar.gz
nixpkgs-0123200dee6bd3f94dbf6fed376b3208dcefe309.tar.bz2
nixpkgs-0123200dee6bd3f94dbf6fed376b3208dcefe309.tar.lz
nixpkgs-0123200dee6bd3f94dbf6fed376b3208dcefe309.tar.xz
nixpkgs-0123200dee6bd3f94dbf6fed376b3208dcefe309.tar.zst
nixpkgs-0123200dee6bd3f94dbf6fed376b3208dcefe309.zip
stdenv: add stawman docs for `makeOverridable`
Also fix a typo in docs in haskell-modules.
Diffstat (limited to 'lib')
-rw-r--r--lib/customisation.nix18
1 files changed, 18 insertions, 0 deletions
diff --git a/lib/customisation.nix b/lib/customisation.nix
index 6d6c0234087..98a46ca6c61 100644
--- a/lib/customisation.nix
+++ b/lib/customisation.nix
@@ -51,6 +51,24 @@ rec {
        else { }));
 
 
+  /* `makeOverridable` takes a function from attribute set to attribute set and
+     injects `override` attibute which can be used to override arguments of
+     the function.
+
+       nix-repl> x = {a, b}: { result = a + b; }
+
+       nix-repl> y = lib.makeOverridable x { a = 1; b = 2; }
+
+       nix-repl> y
+       { override = «lambda»; overrideDerivation = «lambda»; result = 3; }
+
+       nix-repl> y.override { a = 10; }
+       { override = «lambda»; overrideDerivation = «lambda»; result = 12; }
+
+     Please refer to "Nixpkgs Contributors Guide" section
+     "<pkg>.overrideDerivation" to learn about `overrideDerivation` and caveats
+     related to its use.
+  */
   makeOverridable = f: origArgs:
     let
       ff = f origArgs;