# 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 ? {}, depotOverlays ? true, ... }: 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 2022-01-27. unstableHashes = { commit = "945ec499041db73043f745fad3b2a3a01e826081"; sha256 = "1ixv310sjw0r5vda4yfwp3snyha2i9h7aqygd43cyvdk2qsjk8pq"; }; # Tracking nixos-21.11 as of 2022-01-26. stableHashes = { commit = "b3d86c56c786ad9530f1400adbd4dfac3c42877b"; sha256 = "09nslcjdgwwb6j9alxrsnq1wvhifq1nmzl2w02l305j0wsmgdial"; }; # 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 { # allow users to inject their config into builds (e.g. to test CA derivations) config = (if externalArgs ? nixpkgsConfig then externalArgs.nixpkgsConfig else { }) // { allowUnfree = true; allowBroken = true; }; overlays = [ commitsOverlay stableOverlay ] ++ (if depotOverlays then [ depot.third_party.overlays.haskell depot.third_party.overlays.emacs depot.third_party.overlays.tvl depot.third_party.overlays.ecl-static ] else []); }