| 
									
										
										
										
											2010-05-23 15:54:10 +00:00
										 |  |  | let lib = import ./default.nix; | 
					
						
							|  |  |  |     inherit (builtins) getAttr attrNames isFunction; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | in | 
					
						
							| 
									
										
										
										
											2009-11-19 17:30:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | rec { | 
					
						
							| 
									
										
										
										
											2009-11-19 16:43:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* `overrideDerivation drv f' takes a derivation (i.e., the result
 | 
					
						
							|  |  |  |      of a call to the builtin function `derivation') and returns a new | 
					
						
							|  |  |  |      derivation in which the attributes of the original are overriden | 
					
						
							| 
									
										
										
										
											2009-11-19 17:30:21 +00:00
										 |  |  |      according to the function `f'.  The function `f' is called with | 
					
						
							|  |  |  |      the original derivation attributes. | 
					
						
							| 
									
										
										
										
											2009-11-19 16:43:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |      `overrideDerivation' allows certain "ad-hoc" customisation | 
					
						
							|  |  |  |      scenarios (e.g. in ~/.nixpkgs/config.nix).  For instance, if you | 
					
						
							|  |  |  |      want to "patch" the derivation returned by a package function in | 
					
						
							|  |  |  |      Nixpkgs to build another version than what the function itself | 
					
						
							|  |  |  |      provides, you can do something like this: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        mySed = overrideDerivation pkgs.gnused (oldAttrs: { | 
					
						
							|  |  |  |          name = "sed-4.2.2-pre"; | 
					
						
							|  |  |  |          src = fetchurl { | 
					
						
							|  |  |  |            url = ftp://alpha.gnu.org/gnu/sed/sed-4.2.2-pre.tar.bz2; | 
					
						
							|  |  |  |            sha256 = "11nq06d131y4wmf3drm0yk502d2xc6n5qy82cg88rb9nqd2lj41k"; | 
					
						
							|  |  |  |          }; | 
					
						
							|  |  |  |          patches = []; | 
					
						
							|  |  |  |        }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      For another application, see build-support/vm, where this | 
					
						
							|  |  |  |      function is used to build arbitrary derivations inside a QEMU | 
					
						
							|  |  |  |      virtual machine. */ | 
					
						
							|  |  |  |       | 
					
						
							|  |  |  |   overrideDerivation = drv: f: | 
					
						
							|  |  |  |     let | 
					
						
							| 
									
										
										
										
											2013-05-15 00:38:03 -04:00
										 |  |  |       newDrv = derivation (drv.drvAttrs // (f drv)); | 
					
						
							| 
									
										
										
										
											2013-05-15 00:39:17 -04:00
										 |  |  |     in addPassthru newDrv ( | 
					
						
							| 
									
										
										
										
											2013-05-15 00:38:03 -04:00
										 |  |  |       { meta = drv.meta or {}; | 
					
						
							| 
									
										
										
										
											2009-11-19 16:43:58 +00:00
										 |  |  |         passthru = if drv ? passthru then drv.passthru else {}; | 
					
						
							| 
									
										
										
										
											2012-01-19 22:29:26 +00:00
										 |  |  |       } | 
					
						
							|  |  |  |       // | 
					
						
							| 
									
										
										
										
											2013-05-15 00:38:03 -04:00
										 |  |  |       (drv.passthru or {}) | 
					
						
							|  |  |  |       // | 
					
						
							| 
									
										
										
										
											2012-12-28 19:08:19 +01:00
										 |  |  |       (if (drv ? crossDrv && drv ? nativeDrv) | 
					
						
							| 
									
										
										
										
											2012-01-19 22:29:26 +00:00
										 |  |  |        then { | 
					
						
							| 
									
										
										
										
											2012-12-28 19:08:19 +01:00
										 |  |  |          crossDrv = overrideDerivation drv.crossDrv f; | 
					
						
							|  |  |  |          nativeDrv = overrideDerivation drv.nativeDrv f; | 
					
						
							| 
									
										
										
										
											2012-01-19 22:29:26 +00:00
										 |  |  |        } | 
					
						
							| 
									
										
										
										
											2013-05-15 00:39:17 -04:00
										 |  |  |        else { })); | 
					
						
							| 
									
										
										
										
											2009-11-19 16:43:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-19 17:30:21 +00:00
										 |  |  |   # usage: (you can use override multiple times) | 
					
						
							|  |  |  |   # let d = makeOverridable stdenv.mkDerivation { name = ..; buildInputs; } | 
					
						
							|  |  |  |   #     noBuildInputs = d.override { buildInputs = []; } | 
					
						
							|  |  |  |   #     additionalBuildInputs = d.override ( args : args // { buildInputs = args.buildInputs ++ [ additional ]; } ) | 
					
						
							| 
									
										
										
										
											2010-08-19 22:52:53 +00:00
										 |  |  |   makeOverridable = f: origArgs: | 
					
						
							|  |  |  |     let | 
					
						
							|  |  |  |       ff = f origArgs; | 
					
						
							|  |  |  |     in | 
					
						
							|  |  |  |       if builtins.isAttrs ff then (ff // | 
					
						
							|  |  |  |         { override = newArgs: | 
					
						
							|  |  |  |             makeOverridable f (origArgs // (if builtins.isFunction newArgs then newArgs origArgs else newArgs)); | 
					
						
							|  |  |  |           deepOverride = newArgs: | 
					
						
							|  |  |  |             makeOverridable f (lib.overrideExisting (lib.mapAttrs (deepOverrider newArgs) origArgs) newArgs); | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |       else ff; | 
					
						
							| 
									
										
										
										
											2009-11-19 17:30:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-08 13:25:52 +00:00
										 |  |  |   deepOverrider = newArgs: name: x: if builtins.isAttrs x then ( | 
					
						
							| 
									
										
										
										
											2009-11-19 17:30:21 +00:00
										 |  |  |     if x ? deepOverride then (x.deepOverride newArgs) else | 
					
						
							|  |  |  |     if x ? override then (x.override newArgs) else | 
					
						
							|  |  |  |     x) else x; | 
					
						
							| 
									
										
										
										
											2010-08-02 13:57:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Call the package function in the file `fn' with the required
 | 
					
						
							|  |  |  |     arguments automatically.  The function is called with the | 
					
						
							|  |  |  |     arguments `args', but any missing arguments are obtained from | 
					
						
							|  |  |  |     `autoArgs'.  This function is intended to be partially | 
					
						
							|  |  |  |     parameterised, e.g., | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       callPackage = callPackageWith pkgs; | 
					
						
							|  |  |  |       pkgs = { | 
					
						
							|  |  |  |         libfoo = callPackage ./foo.nix { }; | 
					
						
							|  |  |  |         libbar = callPackage ./bar.nix { }; | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     If the `libbar' function expects an argument named `libfoo', it is | 
					
						
							|  |  |  |     automatically passed as an argument.  Overrides or missing | 
					
						
							|  |  |  |     arguments can be supplied in `args', e.g. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       libbar = callPackage ./bar.nix { | 
					
						
							|  |  |  |         libfoo = null; | 
					
						
							|  |  |  |         enableX11 = true; | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |   */ | 
					
						
							|  |  |  |   callPackageWith = autoArgs: fn: args: | 
					
						
							| 
									
										
										
										
											2011-01-21 08:25:06 +00:00
										 |  |  |     let f = if builtins.isFunction fn then fn else import fn; in | 
					
						
							| 
									
										
										
										
											2010-08-02 13:57:57 +00:00
										 |  |  |     makeOverridable f ((builtins.intersectAttrs (builtins.functionArgs f) autoArgs) // args); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-24 08:29:10 -04:00
										 |  |  |   /* Add attributes to each output of a derivation without changing the derivation itself */ | 
					
						
							|  |  |  |   addPassthru = drv: passthru: | 
					
						
							|  |  |  |     let | 
					
						
							|  |  |  |       outputs = drv.outputs or [ "out" ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       commonAttrs = drv // (builtins.listToAttrs outputsList) // | 
					
						
							|  |  |  |         ({ all = map (x: x.value) outputsList; }) // passthru; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       outputToAttrListElement = outputName: | 
					
						
							|  |  |  |         { name = outputName; | 
					
						
							|  |  |  |           value = commonAttrs // { | 
					
						
							|  |  |  |             inherit (builtins.getAttr outputName drv) outPath drvPath type outputName; | 
					
						
							|  |  |  |           }; | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       outputsList = map outputToAttrListElement outputs; | 
					
						
							|  |  |  |   in builtins.getAttr drv.outputName commonAttrs; | 
					
						
							| 
									
										
										
										
											2009-11-19 16:43:58 +00:00
										 |  |  | } |