top-level: Use nixpkgsFun to avoid import ../..
				
					
				
			This commit is contained in:
		
							parent
							
								
									64a3317889
								
							
						
					
					
						commit
						a113382f2c
					
				| @ -6,6 +6,7 @@ | ||||
|  * Hint: ### starts category names. | ||||
|  */ | ||||
| { system, bootStdenv, noSysDirs, config, crossSystem, platform, lib | ||||
| , nixpkgsFun | ||||
| , ... }: | ||||
| self: pkgs: | ||||
| 
 | ||||
| @ -35,10 +36,9 @@ in | ||||
|   newScope = extra: lib.callPackageWith (defaultScope // extra); | ||||
| 
 | ||||
|   # Override system. This is useful to build i686 packages on x86_64-linux. | ||||
|   forceSystem = system: kernel: (import ../..) { | ||||
|   forceSystem = system: kernel: nixpkgsFun { | ||||
|     inherit system; | ||||
|     platform = platform // { kernelArch = kernel; }; | ||||
|     inherit bootStdenv noSysDirs config crossSystem; | ||||
|   }; | ||||
| 
 | ||||
|   # Used by wine, firefox with debugging version of Flash, ... | ||||
| @ -4254,9 +4254,7 @@ in | ||||
|     # load into the Ben Nanonote | ||||
|     gccCross = | ||||
|       let | ||||
|         pkgsCross = (import ../..) { | ||||
|           inherit system; | ||||
|           inherit bootStdenv noSysDirs config; | ||||
|         pkgsCross = nixpkgsFun { | ||||
|           # Ben Nanonote system | ||||
|           crossSystem = { | ||||
|             config = "mipsel-unknown-linux"; | ||||
|  | ||||
| @ -24,13 +24,12 @@ | ||||
| 
 | ||||
| , crossSystem ? null | ||||
| , platform ? null | ||||
| }: | ||||
| } @ args: | ||||
| 
 | ||||
| 
 | ||||
| let configExpr = config; platform_ = platform; in # rename the function arguments | ||||
| 
 | ||||
| let | ||||
| 
 | ||||
|   lib = import ../../lib; | ||||
| 
 | ||||
|   # Allow both: | ||||
| @ -58,9 +57,20 @@ let | ||||
|     else config.platform or platformAuto; | ||||
| 
 | ||||
|   topLevelArguments = { | ||||
|     inherit system bootStdenv noSysDirs config crossSystem platform lib; | ||||
|     inherit system bootStdenv noSysDirs config crossSystem platform lib nixpkgsFun; | ||||
|   }; | ||||
| 
 | ||||
|   # A few packages make a new package set to draw their dependencies from. | ||||
|   # (Currently to get a cross tool chain, or forced-i686 package.) Rather than | ||||
|   # give `all-packages.nix` all the arguments to this function, even ones that | ||||
|   # don't concern it, we give it this function to "re-call" nixpkgs, inheriting | ||||
|   # whatever arguments it doesn't explicitly provide. This way, | ||||
|   # `all-packages.nix` doesn't know more than it needs too. | ||||
|   # | ||||
|   # It's OK that `args` doesn't include the defaults: they'll be | ||||
|   # deterministically inferred the same way. | ||||
|   nixpkgsFun = newArgs: import ./. (args // newArgs); | ||||
| 
 | ||||
|   stdenvAdapters = self: super: | ||||
|     let res = import ../stdenv/adapters.nix self; in res // { | ||||
|       stdenvAdapters = res; | ||||
| @ -71,7 +81,7 @@ let | ||||
|       inherit lib; inherit (self) stdenv stdenvNoCC; inherit (self.xorg) lndir; | ||||
|     }); | ||||
| 
 | ||||
|   stdenvDefault = self: super: (import ./stdenv.nix topLevelArguments) {} pkgs; | ||||
|   stdenvDefault = self: super: (import ./stdenv.nix topLevelArguments) pkgs; | ||||
| 
 | ||||
|   allPackages = self: super: | ||||
|     let res = import ./all-packages.nix topLevelArguments res self; | ||||
|  | ||||
| @ -1,12 +1,11 @@ | ||||
| { system, bootStdenv, crossSystem, config, platform, lib, ... }: | ||||
| self: super: | ||||
| 
 | ||||
| with super; | ||||
| { system, bootStdenv, crossSystem, config, platform, lib, nixpkgsFun, ... }: | ||||
| pkgs: | ||||
| 
 | ||||
| rec { | ||||
|   allStdenvs = import ../stdenv { | ||||
|     inherit system platform config lib; | ||||
|     allPackages = args: import ../.. ({ inherit config system; } // args); | ||||
|     # TODO(@Ericson2314): hack for cross-compiling until I clean that in follow-up PR | ||||
|     allPackages = args: nixpkgsFun (args // { crossSystem = null; }); | ||||
|   }; | ||||
| 
 | ||||
|   defaultStdenv = allStdenvs.stdenv // { inherit platform; }; | ||||
| @ -14,14 +13,14 @@ rec { | ||||
|   stdenv = | ||||
|     if bootStdenv != null then (bootStdenv // {inherit platform;}) else | ||||
|       if crossSystem != null then | ||||
|         stdenvCross | ||||
|         pkgs.stdenvCross | ||||
|       else | ||||
|         let | ||||
|             changer = config.replaceStdenv or null; | ||||
|         in if changer != null then | ||||
|           changer { | ||||
|             # We import again all-packages to avoid recursivities. | ||||
|             pkgs = import ../.. { | ||||
|             pkgs = nixpkgsFun { | ||||
|               # We remove packageOverrides to avoid recursivities | ||||
|               config = removeAttrs config [ "replaceStdenv" ]; | ||||
|             }; | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 John Ericson
						John Ericson