* Switch from (unused) NixOS 21.05 to newly released NixOS 21.11 channel. * grfn/machines/yeren: Linux 5.14.x -> 5.15.x * 3p/gerrit, 3p/gerrit_plugin/oauth: update dependency bundle output hashes to what whitby comes up with now. Change-Id: Id3bfe3d07b9223f77ec628954783a6b0a48f4086 Reviewed-on: https://cl.tvl.fyi/c/depot/+/4310 Tested-by: BuildkiteCI Autosubmit: sterni <sternenseemann@systemli.org> Reviewed-by: grfn <grfn@gws.fyi> Reviewed-by: tazjin <mail@tazj.in>
		
			
				
	
	
		
			71 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| # This file imports the pinned nixpkgs sets and applies relevant
 | |
| # modifications, such as our overlays.
 | |
| #
 | |
| # Note that the attribute exposed by this (third_party.nixpkgs) is
 | |
| # "special" in that the fixpoint used as readTree's config parameter
 | |
| # in //default.nix passes this attribute as the `pkgs` argument to all
 | |
| # readTree derivations.
 | |
| 
 | |
| { depot, externalArgs, ... }:
 | |
| 
 | |
| let
 | |
|   # This provides the sources of nixpkgs. We track both
 | |
|   # nixos-unstable, and the current stable channel of the latest NixOS
 | |
|   # release.
 | |
| 
 | |
|   # Tracking nixos-unstable as of 2021-12-15.
 | |
|   unstableHashes = {
 | |
|     commit = "a2e281f5770247855b85d70c43454ba5bff34613";
 | |
|     sha256 = "03m6b3yvx7v8gwib848aclwqpg02rhqdh9h511w9byyfvha9g0fg";
 | |
|   };
 | |
| 
 | |
|   # Tracking nixos-21.11 as of 2021-12-12.
 | |
|   stableHashes = {
 | |
|     commit = "573095944e7c1d58d30fc679c81af63668b54056";
 | |
|     sha256 = "07s5cwhskqvy82b4rld9b14ljc0013pig23i3jx3l3f957rk95pg";
 | |
|   };
 | |
| 
 | |
|   # import the nixos-unstable package set, or optionally use the
 | |
|   # source (e.g. a path) specified by the `nixpkgsBisectPath`
 | |
|   # argument. This is intended for use-cases where the depot is
 | |
|   # bisected against nixpkgs to find the root cause of an issue in a
 | |
|   # channel bump.
 | |
|   nixpkgsSrc = externalArgs.nixpkgsBisectPath or (fetchTarball {
 | |
|     url = "https://github.com/NixOS/nixpkgs/archive/${unstableHashes.commit}.tar.gz";
 | |
|     sha256 = unstableHashes.sha256;
 | |
|   });
 | |
| 
 | |
|   stableNixpkgsSrc = fetchTarball {
 | |
|     url = "https://github.com/NixOS/nixpkgs/archive/${stableHashes.commit}.tar.gz";
 | |
|     sha256 = stableHashes.sha256;
 | |
|   };
 | |
| 
 | |
|   # Stable package set is imported, but not exposed, to overlay
 | |
|   # required packages into the unstable set.
 | |
|   stableNixpkgs = import stableNixpkgsSrc {};
 | |
| 
 | |
|   # Overlay for packages that should come from the stable channel
 | |
|   # instead (e.g. because something is broken in unstable).
 | |
|   stableOverlay = self: super: {
 | |
|     # Nothing picked from stable presently.
 | |
|   };
 | |
| 
 | |
|   # Overlay to expose the nixpkgs commits we are using to other Nix code.
 | |
|   commitsOverlay = _: _: {
 | |
|     nixpkgsCommits = {
 | |
|       unstable = unstableHashes.commit;
 | |
|       stable = stableHashes.commit;
 | |
|     };
 | |
|   };
 | |
| in import nixpkgsSrc {
 | |
|   config.allowUnfree = true;
 | |
|   config.allowBroken = true;
 | |
|   overlays = [
 | |
|     commitsOverlay
 | |
|     stableOverlay
 | |
|     depot.third_party.overlays.haskell
 | |
|     depot.third_party.overlays.emacs
 | |
|     depot.third_party.overlays.tvl
 | |
|     depot.third_party.overlays.ecl-static
 | |
|   ];
 | |
| }
 |