2021-04-10 18:05:16 +02:00
|
|
|
# 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.
|
|
|
|
|
2022-01-18 17:28:00 +01:00
|
|
|
{ depot ? {}, externalArgs ? {}, depotOverlays ? true, ... }:
|
2021-04-10 18:05:16 +02:00
|
|
|
|
|
|
|
let
|
|
|
|
# This provides the sources of nixpkgs. We track both
|
|
|
|
# nixos-unstable, and the current stable channel of the latest NixOS
|
|
|
|
# release.
|
|
|
|
|
2022-01-27 11:33:52 +01:00
|
|
|
# Tracking nixos-unstable as of 2022-01-27.
|
2021-04-10 18:05:16 +02:00
|
|
|
unstableHashes = {
|
2022-01-27 11:33:52 +01:00
|
|
|
commit = "945ec499041db73043f745fad3b2a3a01e826081";
|
|
|
|
sha256 = "1ixv310sjw0r5vda4yfwp3snyha2i9h7aqygd43cyvdk2qsjk8pq";
|
2021-04-10 18:05:16 +02:00
|
|
|
};
|
|
|
|
|
2022-01-27 11:33:52 +01:00
|
|
|
# Tracking nixos-21.11 as of 2022-01-26.
|
2021-04-10 18:05:16 +02:00
|
|
|
stableHashes = {
|
2022-01-27 11:33:52 +01:00
|
|
|
commit = "b3d86c56c786ad9530f1400adbd4dfac3c42877b";
|
|
|
|
sha256 = "09nslcjdgwwb6j9alxrsnq1wvhifq1nmzl2w02l305j0wsmgdial";
|
2021-04-10 18:05:16 +02:00
|
|
|
};
|
|
|
|
|
2021-04-10 23:43:41 +02:00
|
|
|
# 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 {
|
2021-04-10 18:05:16 +02:00
|
|
|
url = "https://github.com/NixOS/nixpkgs/archive/${unstableHashes.commit}.tar.gz";
|
|
|
|
sha256 = unstableHashes.sha256;
|
2021-04-10 23:43:41 +02:00
|
|
|
});
|
|
|
|
|
2021-04-10 18:05:16 +02:00
|
|
|
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: {
|
2021-09-30 13:38:02 +02:00
|
|
|
# Nothing picked from stable presently.
|
2021-04-10 18:05:16 +02:00
|
|
|
};
|
2021-08-12 15:15:53 +02:00
|
|
|
|
|
|
|
# Overlay to expose the nixpkgs commits we are using to other Nix code.
|
|
|
|
commitsOverlay = _: _: {
|
|
|
|
nixpkgsCommits = {
|
|
|
|
unstable = unstableHashes.commit;
|
|
|
|
stable = stableHashes.commit;
|
|
|
|
};
|
|
|
|
};
|
2021-12-27 23:46:27 +01:00
|
|
|
|
2021-04-10 18:05:16 +02:00
|
|
|
in import nixpkgsSrc {
|
2021-12-27 23:46:27 +01:00
|
|
|
# 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;
|
|
|
|
};
|
2022-01-18 17:28:00 +01:00
|
|
|
|
2021-04-10 18:05:16 +02:00
|
|
|
overlays = [
|
2021-08-12 15:15:53 +02:00
|
|
|
commitsOverlay
|
2021-04-10 18:05:16 +02:00
|
|
|
stableOverlay
|
2022-01-18 17:28:00 +01:00
|
|
|
] ++ (if depotOverlays then [
|
2021-04-10 18:05:16 +02:00
|
|
|
depot.third_party.overlays.haskell
|
2021-04-13 22:16:46 +02:00
|
|
|
depot.third_party.overlays.emacs
|
2021-09-01 12:14:37 +02:00
|
|
|
depot.third_party.overlays.tvl
|
2021-08-09 02:47:07 +02:00
|
|
|
depot.third_party.overlays.ecl-static
|
2022-01-18 17:28:00 +01:00
|
|
|
] else []);
|
2021-04-10 18:05:16 +02:00
|
|
|
}
|