2019-04-08 18:28:05 +03:00
|
|
|
|
{
|
|
|
|
|
description = "The purely functional package manager";
|
|
|
|
|
|
2023-11-19 12:38:47 +02:00
|
|
|
|
inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixos-23.05-small";
|
2022-05-16 21:46:44 +03:00
|
|
|
|
inputs.nixpkgs-regression.url = "github:NixOS/nixpkgs/215d4d0fd80ca5163643b03a33fde804a29cc1e2";
|
2021-09-24 16:21:41 +03:00
|
|
|
|
inputs.lowdown-src = { url = "github:kristapsdz/lowdown"; flake = false; };
|
2023-03-06 21:51:58 +02:00
|
|
|
|
inputs.flake-compat = { url = "github:edolstra/flake-compat"; flake = false; };
|
2023-11-14 14:30:51 +02:00
|
|
|
|
inputs.libgit2 = { url = "github:libgit2/libgit2"; flake = false; };
|
2019-04-08 18:28:05 +03:00
|
|
|
|
|
2023-11-14 14:30:51 +02:00
|
|
|
|
outputs = { self, nixpkgs, nixpkgs-regression, lowdown-src, flake-compat, libgit2 }:
|
2019-04-08 18:28:05 +03:00
|
|
|
|
|
2019-10-04 11:45:33 +03:00
|
|
|
|
let
|
2022-03-02 04:40:18 +02:00
|
|
|
|
inherit (nixpkgs) lib;
|
2019-05-29 18:25:41 +03:00
|
|
|
|
|
2022-12-06 19:00:10 +02:00
|
|
|
|
officialRelease = false;
|
|
|
|
|
|
2023-11-24 16:48:41 +02:00
|
|
|
|
# Set to true to build the release notes for the next release.
|
|
|
|
|
buildUnreleasedNotes = false;
|
|
|
|
|
|
2022-03-02 04:40:18 +02:00
|
|
|
|
version = lib.fileContents ./.version + versionSuffix;
|
2020-04-01 01:20:12 +03:00
|
|
|
|
versionSuffix =
|
|
|
|
|
if officialRelease
|
|
|
|
|
then ""
|
2020-10-21 22:31:19 +03:00
|
|
|
|
else "pre${builtins.substring 0 8 (self.lastModifiedDate or self.lastModified or "19700101")}_${self.shortRev or "dirty"}";
|
2020-03-13 19:28:01 +02:00
|
|
|
|
|
2023-08-23 21:28:24 +03:00
|
|
|
|
linux32BitSystems = [ "i686-linux" ];
|
2020-10-28 07:13:18 +02:00
|
|
|
|
linux64BitSystems = [ "x86_64-linux" "aarch64-linux" ];
|
2023-08-23 21:28:24 +03:00
|
|
|
|
linuxSystems = linux32BitSystems ++ linux64BitSystems;
|
|
|
|
|
darwinSystems = [ "x86_64-darwin" "aarch64-darwin" ];
|
|
|
|
|
systems = linuxSystems ++ darwinSystems;
|
2023-08-31 05:57:59 +03:00
|
|
|
|
|
|
|
|
|
crossSystems = [
|
|
|
|
|
"armv6l-linux" "armv7l-linux"
|
|
|
|
|
"x86_64-freebsd13" "x86_64-netbsd"
|
|
|
|
|
];
|
2021-02-06 02:07:48 +02:00
|
|
|
|
|
2022-09-23 12:21:19 +03:00
|
|
|
|
stdenvs = [ "gccStdenv" "clangStdenv" "clang11Stdenv" "stdenv" "libcxxStdenv" "ccacheStdenv" ];
|
2021-07-08 18:01:51 +03:00
|
|
|
|
|
2022-03-02 04:40:18 +02:00
|
|
|
|
forAllSystems = lib.genAttrs systems;
|
|
|
|
|
|
|
|
|
|
forAllCrossSystems = lib.genAttrs crossSystems;
|
|
|
|
|
|
|
|
|
|
forAllStdenvs = f:
|
|
|
|
|
lib.listToAttrs
|
2021-07-08 18:01:51 +03:00
|
|
|
|
(map
|
2022-03-02 04:40:18 +02:00
|
|
|
|
(stdenvName: {
|
|
|
|
|
name = "${stdenvName}Packages";
|
|
|
|
|
value = f stdenvName;
|
|
|
|
|
})
|
|
|
|
|
stdenvs);
|
2021-07-08 18:01:51 +03:00
|
|
|
|
|
Add positive source filter
Source filtering is a really cool Nix feature that lets us avoid a
lot of rebuilds, which speeds up the iteration cycle a lot in cases
where the relevant source files aren't actually modified.
We used to have a source filter that marked a few files as irrelevant,
but this is the wrong approach, as we have many more files that are
irrelevant. We may call this negative filtering.
This commit switches the source filtering to positive filtering, which
is a lot more robust. Instead of marking which files we don't need
we marked the files that we do need.
It's a superior approach because it is fail safe. Instead of allowing
build performance problems to creep in over time, we require that all
source inputs are declared.
I shouldn't have to explain that declaring inputs is a good practice,
so I'll stop over-explaining here.
I do have to acknowledge that this will cause a build failure when the
filter is incomplete. This is *good*, because it's the only realistic
way we could be reminded of these problems. These events will be
infrequent, so the small cost of extending the filter is worth it,
compared to the hidden cost of longer dev cycles for things like tests,
docker image, etc, etc.
(Also rebuilding Nix for stupid unnecessary reasons makes my blood boil)
2023-08-14 13:24:26 +03:00
|
|
|
|
# Experimental fileset library: https://github.com/NixOS/nixpkgs/pull/222981
|
|
|
|
|
# Not an "idiomatic" flake input because:
|
|
|
|
|
# - Propagation to dependent locks: https://github.com/NixOS/nix/issues/7730
|
|
|
|
|
# - Subflake would download redundant and huge parent flake
|
|
|
|
|
# - No git tree hash support: https://github.com/NixOS/nix/issues/6044
|
2023-08-16 17:01:46 +03:00
|
|
|
|
inherit (import (builtins.fetchTarball { url = "https://github.com/NixOS/nix/archive/1bdcd7fc8a6a40b2e805bad759b36e64e911036b.tar.gz"; sha256 = "sha256:14ljlpdsp4x7h1fkhbmc4bd3vsqnx8zdql4h3037wh09ad6a0893"; }))
|
Add positive source filter
Source filtering is a really cool Nix feature that lets us avoid a
lot of rebuilds, which speeds up the iteration cycle a lot in cases
where the relevant source files aren't actually modified.
We used to have a source filter that marked a few files as irrelevant,
but this is the wrong approach, as we have many more files that are
irrelevant. We may call this negative filtering.
This commit switches the source filtering to positive filtering, which
is a lot more robust. Instead of marking which files we don't need
we marked the files that we do need.
It's a superior approach because it is fail safe. Instead of allowing
build performance problems to creep in over time, we require that all
source inputs are declared.
I shouldn't have to explain that declaring inputs is a good practice,
so I'll stop over-explaining here.
I do have to acknowledge that this will cause a build failure when the
filter is incomplete. This is *good*, because it's the only realistic
way we could be reminded of these problems. These events will be
infrequent, so the small cost of extending the filter is worth it,
compared to the hidden cost of longer dev cycles for things like tests,
docker image, etc, etc.
(Also rebuilding Nix for stupid unnecessary reasons makes my blood boil)
2023-08-14 13:24:26 +03:00
|
|
|
|
fileset;
|
|
|
|
|
|
|
|
|
|
baseFiles =
|
|
|
|
|
# .gitignore has already been processed, so any changes in it are irrelevant
|
|
|
|
|
# at this point. It is not represented verbatim for test purposes because
|
|
|
|
|
# that would interfere with repo semantics.
|
|
|
|
|
fileset.fileFilter (f: f.name != ".gitignore") ./.;
|
|
|
|
|
|
2023-10-06 18:57:31 +03:00
|
|
|
|
configureFiles = fileset.unions [
|
|
|
|
|
./.version
|
|
|
|
|
./configure.ac
|
|
|
|
|
./m4
|
|
|
|
|
# TODO: do we really need README.md? It doesn't seem used in the build.
|
|
|
|
|
./README.md
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
topLevelBuildFiles = fileset.unions [
|
|
|
|
|
./local.mk
|
|
|
|
|
./Makefile
|
|
|
|
|
./Makefile.config.in
|
|
|
|
|
./mk
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
functionalTestFiles = fileset.unions [
|
|
|
|
|
./tests/functional
|
|
|
|
|
(fileset.fileFilter (f: lib.strings.hasPrefix "nix-profile" f.name) ./scripts)
|
|
|
|
|
];
|
|
|
|
|
|
Add positive source filter
Source filtering is a really cool Nix feature that lets us avoid a
lot of rebuilds, which speeds up the iteration cycle a lot in cases
where the relevant source files aren't actually modified.
We used to have a source filter that marked a few files as irrelevant,
but this is the wrong approach, as we have many more files that are
irrelevant. We may call this negative filtering.
This commit switches the source filtering to positive filtering, which
is a lot more robust. Instead of marking which files we don't need
we marked the files that we do need.
It's a superior approach because it is fail safe. Instead of allowing
build performance problems to creep in over time, we require that all
source inputs are declared.
I shouldn't have to explain that declaring inputs is a good practice,
so I'll stop over-explaining here.
I do have to acknowledge that this will cause a build failure when the
filter is incomplete. This is *good*, because it's the only realistic
way we could be reminded of these problems. These events will be
infrequent, so the small cost of extending the filter is worth it,
compared to the hidden cost of longer dev cycles for things like tests,
docker image, etc, etc.
(Also rebuilding Nix for stupid unnecessary reasons makes my blood boil)
2023-08-14 13:24:26 +03:00
|
|
|
|
nixSrc = fileset.toSource {
|
|
|
|
|
root = ./.;
|
2023-10-05 19:12:18 +03:00
|
|
|
|
fileset = fileset.intersect baseFiles (fileset.unions [
|
2023-10-06 18:57:31 +03:00
|
|
|
|
configureFiles
|
|
|
|
|
topLevelBuildFiles
|
2023-10-05 19:12:18 +03:00
|
|
|
|
./boehmgc-coroutine-sp-fallback.diff
|
|
|
|
|
./doc
|
|
|
|
|
./misc
|
|
|
|
|
./precompiled-headers.h
|
|
|
|
|
./src
|
|
|
|
|
./unit-test-data
|
|
|
|
|
./COPYING
|
|
|
|
|
./scripts/local.mk
|
2023-10-06 18:57:31 +03:00
|
|
|
|
functionalTestFiles
|
2023-10-05 19:12:18 +03:00
|
|
|
|
]);
|
Add positive source filter
Source filtering is a really cool Nix feature that lets us avoid a
lot of rebuilds, which speeds up the iteration cycle a lot in cases
where the relevant source files aren't actually modified.
We used to have a source filter that marked a few files as irrelevant,
but this is the wrong approach, as we have many more files that are
irrelevant. We may call this negative filtering.
This commit switches the source filtering to positive filtering, which
is a lot more robust. Instead of marking which files we don't need
we marked the files that we do need.
It's a superior approach because it is fail safe. Instead of allowing
build performance problems to creep in over time, we require that all
source inputs are declared.
I shouldn't have to explain that declaring inputs is a good practice,
so I'll stop over-explaining here.
I do have to acknowledge that this will cause a build failure when the
filter is incomplete. This is *good*, because it's the only realistic
way we could be reminded of these problems. These events will be
infrequent, so the small cost of extending the filter is worth it,
compared to the hidden cost of longer dev cycles for things like tests,
docker image, etc, etc.
(Also rebuilding Nix for stupid unnecessary reasons makes my blood boil)
2023-08-14 13:24:26 +03:00
|
|
|
|
};
|
Support non-x86_64-linux system types in flakes
A command like
$ nix run nixpkgs#hello
will now build the attribute 'packages.${system}.hello' rather than
'packages.hello'. Note that this does mean that the flake needs to
export an attribute for every system type it supports, and you can't
build on unsupported systems. So 'packages' typically looks like this:
packages = nixpkgs.lib.genAttrs ["x86_64-linux" "i686-linux"] (system: {
hello = ...;
});
The 'checks', 'defaultPackage', 'devShell', 'apps' and 'defaultApp'
outputs similarly are now attrsets that map system types to
derivations/apps. 'nix flake check' checks that the derivations for
all platforms evaluate correctly, but only builds the derivations in
'checks.${system}'.
Fixes #2861. (That issue also talks about access to ~/.config/nixpkgs
and --arg, but I think it's reasonable to say that flakes shouldn't
support those.)
The alternative to attribute selection is to pass the system type as
an argument to the flake's 'outputs' function, e.g. 'outputs = { self,
nixpkgs, system }: ...'. However, that approach would be at odds with
hermetic evaluation and make it impossible to enumerate the packages
provided by a flake.
2019-10-15 18:52:10 +03:00
|
|
|
|
|
2019-10-04 11:45:33 +03:00
|
|
|
|
# Memoize nixpkgs for different platforms for efficiency.
|
2022-03-02 04:40:18 +02:00
|
|
|
|
nixpkgsFor = forAllSystems
|
|
|
|
|
(system: let
|
|
|
|
|
make-pkgs = crossSystem: stdenv: import nixpkgs {
|
2023-08-31 05:57:59 +03:00
|
|
|
|
localSystem = {
|
|
|
|
|
inherit system;
|
|
|
|
|
};
|
|
|
|
|
crossSystem = if crossSystem == null then null else {
|
|
|
|
|
system = crossSystem;
|
|
|
|
|
} // lib.optionalAttrs (crossSystem == "x86_64-freebsd13") {
|
|
|
|
|
useLLVM = true;
|
|
|
|
|
};
|
2022-03-02 04:40:18 +02:00
|
|
|
|
overlays = [
|
|
|
|
|
(overlayFor (p: p.${stdenv}))
|
|
|
|
|
];
|
|
|
|
|
};
|
|
|
|
|
stdenvs = forAllStdenvs (make-pkgs null);
|
|
|
|
|
native = stdenvs.stdenvPackages;
|
|
|
|
|
in {
|
|
|
|
|
inherit stdenvs native;
|
|
|
|
|
static = native.pkgsStatic;
|
|
|
|
|
cross = forAllCrossSystems (crossSystem: make-pkgs crossSystem "stdenv");
|
|
|
|
|
});
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2023-02-21 17:15:24 +02:00
|
|
|
|
commonDeps =
|
|
|
|
|
{ pkgs
|
|
|
|
|
, isStatic ? pkgs.stdenv.hostPlatform.isStatic
|
|
|
|
|
}:
|
|
|
|
|
with pkgs; rec {
|
2019-10-04 11:45:33 +03:00
|
|
|
|
# Use "busybox-sandbox-shell" if present,
|
|
|
|
|
# if not (legacy) fallback and hope it's sufficient.
|
|
|
|
|
sh = pkgs.busybox-sandbox-shell or (busybox.override {
|
|
|
|
|
useMusl = true;
|
|
|
|
|
enableStatic = true;
|
|
|
|
|
enableMinimal = true;
|
|
|
|
|
extraConfig = ''
|
|
|
|
|
CONFIG_FEATURE_FANCY_ECHO y
|
|
|
|
|
CONFIG_FEATURE_SH_MATH y
|
|
|
|
|
CONFIG_FEATURE_SH_MATH_64 y
|
|
|
|
|
|
|
|
|
|
CONFIG_ASH y
|
|
|
|
|
CONFIG_ASH_OPTIMIZE_FOR_SIZE y
|
|
|
|
|
|
|
|
|
|
CONFIG_ASH_ALIAS y
|
|
|
|
|
CONFIG_ASH_BASH_COMPAT y
|
|
|
|
|
CONFIG_ASH_CMDCMD y
|
|
|
|
|
CONFIG_ASH_ECHO y
|
|
|
|
|
CONFIG_ASH_GETOPTS y
|
|
|
|
|
CONFIG_ASH_INTERNAL_GLOB y
|
|
|
|
|
CONFIG_ASH_JOB_CONTROL y
|
|
|
|
|
CONFIG_ASH_PRINTF y
|
|
|
|
|
CONFIG_ASH_TEST y
|
|
|
|
|
'';
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
configureFlags =
|
2023-02-20 21:27:50 +02:00
|
|
|
|
lib.optionals stdenv.isLinux [
|
2023-12-01 01:50:20 +02:00
|
|
|
|
"--with-boost=${boost}/lib"
|
2019-10-04 11:45:33 +03:00
|
|
|
|
"--with-sandbox-shell=${sh}/bin/busybox"
|
2022-07-11 21:56:19 +03:00
|
|
|
|
]
|
|
|
|
|
++ lib.optionals (stdenv.isLinux && !(isStatic && stdenv.system == "aarch64-linux")) [
|
2020-09-23 17:05:47 +03:00
|
|
|
|
"LDFLAGS=-fuse-ld=gold"
|
2019-10-04 11:45:33 +03:00
|
|
|
|
];
|
2023-03-02 17:11:49 +02:00
|
|
|
|
|
2023-02-20 21:27:50 +02:00
|
|
|
|
testConfigureFlags = [
|
2023-02-13 19:37:35 +02:00
|
|
|
|
"RAPIDCHECK_HEADERS=${lib.getDev rapidcheck}/extras/gtest/include"
|
2023-11-14 17:52:57 +02:00
|
|
|
|
] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
|
|
|
|
|
"--enable-install-unit-tests"
|
|
|
|
|
"--with-check-bin-dir=${builtins.placeholder "check"}/bin"
|
|
|
|
|
"--with-check-lib-dir=${builtins.placeholder "check"}/lib"
|
2023-02-13 19:37:35 +02:00
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
internalApiDocsConfigureFlags = [
|
|
|
|
|
"--enable-internal-api-docs"
|
2023-02-20 21:27:50 +02:00
|
|
|
|
];
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2023-11-24 17:27:10 +02:00
|
|
|
|
changelog-d = pkgs.buildPackages.changelog-d;
|
2023-11-19 16:05:21 +02:00
|
|
|
|
|
2020-07-30 22:59:57 +03:00
|
|
|
|
nativeBuildDeps =
|
|
|
|
|
[
|
|
|
|
|
buildPackages.bison
|
|
|
|
|
buildPackages.flex
|
2021-09-27 11:31:13 +03:00
|
|
|
|
(lib.getBin buildPackages.lowdown-nix)
|
2020-09-04 05:40:36 +03:00
|
|
|
|
buildPackages.mdbook
|
2023-01-03 09:53:29 +02:00
|
|
|
|
buildPackages.mdbook-linkcheck
|
2020-09-04 05:30:12 +03:00
|
|
|
|
buildPackages.autoconf-archive
|
2020-07-30 22:59:57 +03:00
|
|
|
|
buildPackages.autoreconfHook
|
2021-12-15 20:13:06 +02:00
|
|
|
|
buildPackages.pkg-config
|
2020-07-30 22:59:57 +03:00
|
|
|
|
|
|
|
|
|
# Tests
|
|
|
|
|
buildPackages.git
|
2021-10-06 19:29:20 +03:00
|
|
|
|
buildPackages.mercurial # FIXME: remove? only needed for tests
|
2022-05-26 17:47:40 +03:00
|
|
|
|
buildPackages.jq # Also for custom mdBook preprocessor.
|
2023-10-20 22:18:01 +03:00
|
|
|
|
buildPackages.openssh # only needed for tests (ssh-keygen)
|
2021-03-24 15:50:15 +02:00
|
|
|
|
]
|
2023-11-19 16:05:21 +02:00
|
|
|
|
++ lib.optionals stdenv.hostPlatform.isLinux [(buildPackages.util-linuxMinimal or buildPackages.utillinuxMinimal)]
|
|
|
|
|
# Official releases don't have rl-next, so we don't need to compile a changelog
|
2023-11-24 16:48:41 +02:00
|
|
|
|
++ lib.optional (!officialRelease && buildUnreleasedNotes) changelog-d
|
2023-11-19 16:05:21 +02:00
|
|
|
|
;
|
2020-07-30 22:59:57 +03:00
|
|
|
|
|
2020-03-13 19:28:01 +02:00
|
|
|
|
buildDeps =
|
2022-11-26 22:06:29 +02:00
|
|
|
|
[ curl
|
2021-04-15 14:51:00 +03:00
|
|
|
|
bzip2 xz brotli editline
|
2020-09-04 05:30:12 +03:00
|
|
|
|
openssl sqlite
|
2019-12-20 13:45:58 +02:00
|
|
|
|
libarchive
|
2023-11-14 14:30:51 +02:00
|
|
|
|
(pkgs.libgit2.overrideAttrs (attrs: {
|
|
|
|
|
src = libgit2;
|
|
|
|
|
version = libgit2.lastModifiedDate;
|
|
|
|
|
cmakeFlags = (attrs.cmakeFlags or []) ++ ["-DUSE_SSH=exec"];
|
|
|
|
|
}))
|
2023-12-01 01:50:20 +02:00
|
|
|
|
boost
|
2021-09-27 11:31:13 +03:00
|
|
|
|
lowdown-nix
|
2023-08-31 06:29:17 +03:00
|
|
|
|
libsodium
|
2019-10-04 11:45:33 +03:00
|
|
|
|
]
|
2021-03-24 15:50:15 +02:00
|
|
|
|
++ lib.optionals stdenv.isLinux [libseccomp]
|
2021-03-09 19:40:16 +02:00
|
|
|
|
++ lib.optional stdenv.hostPlatform.isx86_64 libcpuid;
|
2020-07-30 22:59:57 +03:00
|
|
|
|
|
2023-02-20 21:27:50 +02:00
|
|
|
|
checkDeps = [
|
|
|
|
|
gtest
|
|
|
|
|
rapidcheck
|
|
|
|
|
];
|
|
|
|
|
|
2023-02-13 19:37:35 +02:00
|
|
|
|
internalApiDocsDeps = [
|
|
|
|
|
buildPackages.doxygen
|
|
|
|
|
];
|
|
|
|
|
|
2020-07-30 22:59:57 +03:00
|
|
|
|
awsDeps = lib.optional (stdenv.isLinux || stdenv.isDarwin)
|
|
|
|
|
(aws-sdk-cpp.override {
|
|
|
|
|
apis = ["s3" "transfer"];
|
|
|
|
|
customMemoryManagement = false;
|
|
|
|
|
});
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2020-02-15 22:48:28 +02:00
|
|
|
|
propagatedDeps =
|
2023-01-24 15:57:18 +02:00
|
|
|
|
[ ((boehmgc.override {
|
2021-06-24 19:02:51 +03:00
|
|
|
|
enableLargeConfig = true;
|
2023-01-24 15:57:18 +02:00
|
|
|
|
}).overrideAttrs(o: {
|
|
|
|
|
patches = (o.patches or []) ++ [
|
|
|
|
|
./boehmgc-coroutine-sp-fallback.diff
|
2023-11-20 14:38:52 +02:00
|
|
|
|
|
|
|
|
|
# https://github.com/ivmai/bdwgc/pull/586
|
|
|
|
|
./boehmgc-traceable_allocator-public.diff
|
2023-01-24 15:57:18 +02:00
|
|
|
|
];
|
2022-11-26 22:06:29 +02:00
|
|
|
|
})
|
2023-01-24 15:57:18 +02:00
|
|
|
|
)
|
2022-01-26 12:41:51 +02:00
|
|
|
|
nlohmann_json
|
2020-02-15 22:48:28 +02:00
|
|
|
|
];
|
2019-10-04 11:45:33 +03:00
|
|
|
|
};
|
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
installScriptFor = systems:
|
2022-03-02 04:40:18 +02:00
|
|
|
|
with nixpkgsFor.x86_64-linux.native;
|
2021-02-15 12:20:54 +02:00
|
|
|
|
runCommand "installer-script"
|
|
|
|
|
{ buildInputs = [ nix ];
|
|
|
|
|
}
|
|
|
|
|
''
|
|
|
|
|
mkdir -p $out/nix-support
|
|
|
|
|
|
2021-10-05 15:50:55 +03:00
|
|
|
|
# Converts /nix/store/50p3qk8k...-nix-2.4pre20201102_550e11f/bin/nix to 50p3qk8k.../bin/nix.
|
2021-02-15 12:20:54 +02:00
|
|
|
|
tarballPath() {
|
|
|
|
|
# Remove the store prefix
|
|
|
|
|
local path=''${1#${builtins.storeDir}/}
|
|
|
|
|
# Get the path relative to the derivation root
|
|
|
|
|
local rest=''${path#*/}
|
|
|
|
|
# Get the derivation hash
|
|
|
|
|
local drvHash=''${path%%-*}
|
|
|
|
|
echo "$drvHash/$rest"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
substitute ${./scripts/install.in} $out/install \
|
|
|
|
|
${pkgs.lib.concatMapStrings
|
2021-06-26 08:12:03 +03:00
|
|
|
|
(system: let
|
|
|
|
|
tarball = if builtins.elem system crossSystems then self.hydraJobs.binaryTarballCross.x86_64-linux.${system} else self.hydraJobs.binaryTarball.${system};
|
|
|
|
|
in '' \
|
|
|
|
|
--replace '@tarballHash_${system}@' $(nix --experimental-features nix-command hash-file --base16 --type sha256 ${tarball}/*.tar.xz) \
|
|
|
|
|
--replace '@tarballPath_${system}@' $(tarballPath ${tarball}/*.tar.xz) \
|
2021-02-15 12:20:54 +02:00
|
|
|
|
''
|
|
|
|
|
)
|
|
|
|
|
systems
|
|
|
|
|
} --replace '@nixVersion@' ${version}
|
|
|
|
|
|
|
|
|
|
echo "file installer $out/install" >> $out/nix-support/hydra-build-products
|
|
|
|
|
'';
|
|
|
|
|
|
2022-07-11 21:56:19 +03:00
|
|
|
|
testNixVersions = pkgs: client: daemon: with commonDeps { inherit pkgs; }; with pkgs.lib; pkgs.stdenv.mkDerivation {
|
2021-03-16 14:43:08 +02:00
|
|
|
|
NIX_DAEMON_PACKAGE = daemon;
|
|
|
|
|
NIX_CLIENT_PACKAGE = client;
|
2021-10-05 15:50:55 +03:00
|
|
|
|
name =
|
|
|
|
|
"nix-tests"
|
|
|
|
|
+ optionalString
|
|
|
|
|
(versionAtLeast daemon.version "2.4pre20211005" &&
|
|
|
|
|
versionAtLeast client.version "2.4pre20211005")
|
|
|
|
|
"-${client.version}-against-${daemon.version}";
|
2021-03-16 14:43:08 +02:00
|
|
|
|
inherit version;
|
|
|
|
|
|
2023-10-06 18:57:31 +03:00
|
|
|
|
src = fileset.toSource {
|
|
|
|
|
root = ./.;
|
|
|
|
|
fileset = fileset.intersect baseFiles (fileset.unions [
|
|
|
|
|
configureFiles
|
|
|
|
|
topLevelBuildFiles
|
|
|
|
|
functionalTestFiles
|
|
|
|
|
]);
|
|
|
|
|
};
|
2021-03-16 14:43:08 +02:00
|
|
|
|
|
|
|
|
|
VERSION_SUFFIX = versionSuffix;
|
|
|
|
|
|
|
|
|
|
nativeBuildInputs = nativeBuildDeps;
|
2023-02-20 21:27:50 +02:00
|
|
|
|
buildInputs = buildDeps ++ awsDeps ++ checkDeps;
|
2021-03-16 14:43:08 +02:00
|
|
|
|
propagatedBuildInputs = propagatedDeps;
|
|
|
|
|
|
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
|
|
2023-10-06 18:57:31 +03:00
|
|
|
|
configureFlags =
|
|
|
|
|
testConfigureFlags # otherwise configure fails
|
|
|
|
|
++ [ "--disable-build" ];
|
|
|
|
|
dontBuild = true;
|
2021-03-16 14:43:08 +02:00
|
|
|
|
doInstallCheck = true;
|
|
|
|
|
|
|
|
|
|
installPhase = ''
|
|
|
|
|
mkdir -p $out
|
|
|
|
|
'';
|
|
|
|
|
|
2023-10-06 18:57:31 +03:00
|
|
|
|
installCheckPhase = ''
|
|
|
|
|
mkdir -p src/nix-channel
|
|
|
|
|
make installcheck -j$NIX_BUILD_CORES -l$NIX_BUILD_CORES
|
|
|
|
|
'';
|
2021-03-16 14:43:08 +02:00
|
|
|
|
};
|
|
|
|
|
|
2022-03-02 04:40:18 +02:00
|
|
|
|
binaryTarball = nix: pkgs:
|
2022-01-25 02:28:44 +02:00
|
|
|
|
let
|
2022-03-02 04:40:18 +02:00
|
|
|
|
inherit (pkgs) buildPackages;
|
2022-01-25 02:28:44 +02:00
|
|
|
|
inherit (pkgs) cacert;
|
|
|
|
|
installerClosureInfo = buildPackages.closureInfo { rootPaths = [ nix cacert ]; };
|
|
|
|
|
in
|
|
|
|
|
|
|
|
|
|
buildPackages.runCommand "nix-binary-tarball-${version}"
|
|
|
|
|
{ #nativeBuildInputs = lib.optional (system != "aarch64-linux") shellcheck;
|
|
|
|
|
meta.description = "Distribution-independent Nix bootstrap binaries for ${pkgs.system}";
|
|
|
|
|
}
|
|
|
|
|
''
|
|
|
|
|
cp ${installerClosureInfo}/registration $TMPDIR/reginfo
|
|
|
|
|
cp ${./scripts/create-darwin-volume.sh} $TMPDIR/create-darwin-volume.sh
|
|
|
|
|
substitute ${./scripts/install-nix-from-closure.sh} $TMPDIR/install \
|
|
|
|
|
--subst-var-by nix ${nix} \
|
|
|
|
|
--subst-var-by cacert ${cacert}
|
|
|
|
|
|
|
|
|
|
substitute ${./scripts/install-darwin-multi-user.sh} $TMPDIR/install-darwin-multi-user.sh \
|
|
|
|
|
--subst-var-by nix ${nix} \
|
|
|
|
|
--subst-var-by cacert ${cacert}
|
|
|
|
|
substitute ${./scripts/install-systemd-multi-user.sh} $TMPDIR/install-systemd-multi-user.sh \
|
|
|
|
|
--subst-var-by nix ${nix} \
|
|
|
|
|
--subst-var-by cacert ${cacert}
|
|
|
|
|
substitute ${./scripts/install-multi-user.sh} $TMPDIR/install-multi-user \
|
|
|
|
|
--subst-var-by nix ${nix} \
|
|
|
|
|
--subst-var-by cacert ${cacert}
|
|
|
|
|
|
|
|
|
|
if type -p shellcheck; then
|
|
|
|
|
# SC1090: Don't worry about not being able to find
|
|
|
|
|
# $nix/etc/profile.d/nix.sh
|
|
|
|
|
shellcheck --exclude SC1090 $TMPDIR/install
|
|
|
|
|
shellcheck $TMPDIR/create-darwin-volume.sh
|
|
|
|
|
shellcheck $TMPDIR/install-darwin-multi-user.sh
|
|
|
|
|
shellcheck $TMPDIR/install-systemd-multi-user.sh
|
|
|
|
|
|
|
|
|
|
# SC1091: Don't panic about not being able to source
|
|
|
|
|
# /etc/profile
|
|
|
|
|
# SC2002: Ignore "useless cat" "error", when loading
|
|
|
|
|
# .reginfo, as the cat is a much cleaner
|
|
|
|
|
# implementation, even though it is "useless"
|
|
|
|
|
# SC2116: Allow ROOT_HOME=$(echo ~root) for resolving
|
|
|
|
|
# root's home directory
|
|
|
|
|
shellcheck --external-sources \
|
|
|
|
|
--exclude SC1091,SC2002,SC2116 $TMPDIR/install-multi-user
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
chmod +x $TMPDIR/install
|
|
|
|
|
chmod +x $TMPDIR/create-darwin-volume.sh
|
|
|
|
|
chmod +x $TMPDIR/install-darwin-multi-user.sh
|
|
|
|
|
chmod +x $TMPDIR/install-systemd-multi-user.sh
|
|
|
|
|
chmod +x $TMPDIR/install-multi-user
|
|
|
|
|
dir=nix-${version}-${pkgs.system}
|
|
|
|
|
fn=$out/$dir.tar.xz
|
|
|
|
|
mkdir -p $out/nix-support
|
|
|
|
|
echo "file binary-dist $fn" >> $out/nix-support/hydra-build-products
|
|
|
|
|
tar cvfJ $fn \
|
|
|
|
|
--owner=0 --group=0 --mode=u+rw,uga+r \
|
2022-09-05 15:44:01 +03:00
|
|
|
|
--mtime='1970-01-01' \
|
2022-01-25 02:28:44 +02:00
|
|
|
|
--absolute-names \
|
|
|
|
|
--hard-dereference \
|
|
|
|
|
--transform "s,$TMPDIR/install,$dir/install," \
|
|
|
|
|
--transform "s,$TMPDIR/create-darwin-volume.sh,$dir/create-darwin-volume.sh," \
|
|
|
|
|
--transform "s,$TMPDIR/reginfo,$dir/.reginfo," \
|
|
|
|
|
--transform "s,$NIX_STORE,$dir/store,S" \
|
|
|
|
|
$TMPDIR/install \
|
|
|
|
|
$TMPDIR/create-darwin-volume.sh \
|
|
|
|
|
$TMPDIR/install-darwin-multi-user.sh \
|
|
|
|
|
$TMPDIR/install-systemd-multi-user.sh \
|
|
|
|
|
$TMPDIR/install-multi-user \
|
|
|
|
|
$TMPDIR/reginfo \
|
|
|
|
|
$(cat ${installerClosureInfo}/store-paths)
|
|
|
|
|
'';
|
2021-06-26 08:12:03 +03:00
|
|
|
|
|
2021-07-08 18:01:51 +03:00
|
|
|
|
overlayFor = getStdenv: final: prev:
|
2022-01-25 02:28:44 +02:00
|
|
|
|
let currentStdenv = getStdenv final; in
|
|
|
|
|
{
|
|
|
|
|
nixStable = prev.nix;
|
2020-11-10 11:43:33 +02:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
# Forward from the previous stage as we don’t want it to pick the lowdown override
|
|
|
|
|
nixUnstable = prev.nixUnstable;
|
2021-09-20 15:37:09 +03:00
|
|
|
|
|
2023-02-21 17:15:24 +02:00
|
|
|
|
nix =
|
|
|
|
|
with final;
|
|
|
|
|
with commonDeps {
|
|
|
|
|
inherit pkgs;
|
|
|
|
|
inherit (currentStdenv.hostPlatform) isStatic;
|
|
|
|
|
};
|
|
|
|
|
let
|
2022-03-02 04:40:18 +02:00
|
|
|
|
canRunInstalled = currentStdenv.buildPlatform.canExecute currentStdenv.hostPlatform;
|
2023-02-20 21:27:50 +02:00
|
|
|
|
in currentStdenv.mkDerivation (finalAttrs: {
|
2022-01-25 02:28:44 +02:00
|
|
|
|
name = "nix-${version}";
|
|
|
|
|
inherit version;
|
2020-03-13 19:28:01 +02:00
|
|
|
|
|
Add positive source filter
Source filtering is a really cool Nix feature that lets us avoid a
lot of rebuilds, which speeds up the iteration cycle a lot in cases
where the relevant source files aren't actually modified.
We used to have a source filter that marked a few files as irrelevant,
but this is the wrong approach, as we have many more files that are
irrelevant. We may call this negative filtering.
This commit switches the source filtering to positive filtering, which
is a lot more robust. Instead of marking which files we don't need
we marked the files that we do need.
It's a superior approach because it is fail safe. Instead of allowing
build performance problems to creep in over time, we require that all
source inputs are declared.
I shouldn't have to explain that declaring inputs is a good practice,
so I'll stop over-explaining here.
I do have to acknowledge that this will cause a build failure when the
filter is incomplete. This is *good*, because it's the only realistic
way we could be reminded of these problems. These events will be
infrequent, so the small cost of extending the filter is worth it,
compared to the hidden cost of longer dev cycles for things like tests,
docker image, etc, etc.
(Also rebuilding Nix for stupid unnecessary reasons makes my blood boil)
2023-08-14 13:24:26 +03:00
|
|
|
|
src = nixSrc;
|
2022-01-25 02:28:44 +02:00
|
|
|
|
VERSION_SUFFIX = versionSuffix;
|
2020-04-01 01:20:12 +03:00
|
|
|
|
|
2023-11-14 17:52:57 +02:00
|
|
|
|
outputs = [ "out" "dev" "doc" ]
|
|
|
|
|
++ lib.optional (currentStdenv.hostPlatform != currentStdenv.buildPlatform) "check";
|
2019-10-07 15:02:52 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
nativeBuildInputs = nativeBuildDeps;
|
2022-03-02 04:40:18 +02:00
|
|
|
|
buildInputs = buildDeps
|
|
|
|
|
# There have been issues building these dependencies
|
2023-02-20 21:27:50 +02:00
|
|
|
|
++ lib.optionals (currentStdenv.hostPlatform == currentStdenv.buildPlatform) awsDeps
|
|
|
|
|
++ lib.optionals finalAttrs.doCheck checkDeps;
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
propagatedBuildInputs = propagatedDeps;
|
2020-02-15 22:48:28 +02:00
|
|
|
|
|
2023-12-01 01:50:20 +02:00
|
|
|
|
disallowedReferences = [ boost ];
|
2022-01-14 16:41:14 +02:00
|
|
|
|
|
2022-03-02 04:40:18 +02:00
|
|
|
|
preConfigure = lib.optionalString (! currentStdenv.hostPlatform.isStatic)
|
2022-01-25 02:28:44 +02:00
|
|
|
|
''
|
|
|
|
|
# Copy libboost_context so we don't get all of Boost in our closure.
|
|
|
|
|
# https://github.com/NixOS/nixpkgs/issues/45462
|
|
|
|
|
mkdir -p $out/lib
|
2023-12-01 01:50:20 +02:00
|
|
|
|
cp -pd ${boost}/lib/{libboost_context*,libboost_thread*,libboost_system*} $out/lib
|
2022-01-25 02:28:44 +02:00
|
|
|
|
rm -f $out/lib/*.a
|
2022-03-02 04:40:18 +02:00
|
|
|
|
${lib.optionalString currentStdenv.hostPlatform.isLinux ''
|
2022-01-25 02:28:44 +02:00
|
|
|
|
chmod u+w $out/lib/*.so.*
|
|
|
|
|
patchelf --set-rpath $out/lib:${currentStdenv.cc.cc.lib}/lib $out/lib/libboost_thread.so.*
|
|
|
|
|
''}
|
2022-03-02 04:40:18 +02:00
|
|
|
|
${lib.optionalString currentStdenv.hostPlatform.isDarwin ''
|
2022-01-25 02:28:44 +02:00
|
|
|
|
for LIB in $out/lib/*.dylib; do
|
|
|
|
|
chmod u+w $LIB
|
|
|
|
|
install_name_tool -id $LIB $LIB
|
2023-12-01 01:50:20 +02:00
|
|
|
|
install_name_tool -delete_rpath ${boost}/lib/ $LIB || true
|
2022-01-25 02:28:44 +02:00
|
|
|
|
done
|
2023-12-01 01:50:20 +02:00
|
|
|
|
install_name_tool -change ${boost}/lib/libboost_system.dylib $out/lib/libboost_system.dylib $out/lib/libboost_thread.dylib
|
2022-01-25 02:28:44 +02:00
|
|
|
|
''}
|
|
|
|
|
'';
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
configureFlags = configureFlags ++
|
2022-03-02 04:40:18 +02:00
|
|
|
|
[ "--sysconfdir=/etc" ] ++
|
|
|
|
|
lib.optional stdenv.hostPlatform.isStatic "--enable-embedded-sandbox-shell" ++
|
2023-02-28 16:56:46 +02:00
|
|
|
|
[ (lib.enableFeature finalAttrs.doCheck "tests") ] ++
|
|
|
|
|
lib.optionals finalAttrs.doCheck testConfigureFlags ++
|
2022-03-02 04:40:18 +02:00
|
|
|
|
lib.optional (!canRunInstalled) "--disable-doc-gen";
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
enableParallelBuilding = true;
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
makeFlags = "profiledir=$(out)/etc/profile.d PRECOMPILE_HEADERS=1";
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
doCheck = true;
|
2020-03-13 19:28:01 +02:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
installFlags = "sysconfdir=$(out)/etc";
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
postInstall = ''
|
|
|
|
|
mkdir -p $doc/nix-support
|
|
|
|
|
echo "doc manual $doc/share/doc/nix/manual" >> $doc/nix-support/hydra-build-products
|
2023-03-02 20:02:55 +02:00
|
|
|
|
${lib.optionalString currentStdenv.hostPlatform.isStatic ''
|
|
|
|
|
mkdir -p $out/nix-support
|
|
|
|
|
echo "file binary-dist $out/bin/nix" >> $out/nix-support/hydra-build-products
|
|
|
|
|
''}
|
2022-01-25 02:28:44 +02:00
|
|
|
|
${lib.optionalString currentStdenv.isDarwin ''
|
|
|
|
|
install_name_tool \
|
2023-12-01 01:50:20 +02:00
|
|
|
|
-change ${boost}/lib/libboost_context.dylib \
|
2022-01-25 02:28:44 +02:00
|
|
|
|
$out/lib/libboost_context.dylib \
|
|
|
|
|
$out/lib/libnixutil.dylib
|
|
|
|
|
''}
|
|
|
|
|
'';
|
2020-05-28 13:55:24 +03:00
|
|
|
|
|
2023-02-20 21:27:50 +02:00
|
|
|
|
doInstallCheck = finalAttrs.doCheck;
|
2022-01-25 02:28:44 +02:00
|
|
|
|
installCheckFlags = "sysconfdir=$(out)/etc";
|
2023-03-08 14:38:04 +02:00
|
|
|
|
installCheckTarget = "installcheck"; # work around buggy detection in stdenv
|
2020-02-15 22:30:26 +02:00
|
|
|
|
|
2023-02-22 15:10:07 +02:00
|
|
|
|
separateDebugInfo = !currentStdenv.hostPlatform.isStatic;
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
strictDeps = true;
|
2021-03-23 13:06:43 +02:00
|
|
|
|
|
2022-03-02 04:40:18 +02:00
|
|
|
|
hardeningDisable = lib.optional stdenv.hostPlatform.isStatic "pie";
|
|
|
|
|
|
2023-10-13 18:00:55 +03:00
|
|
|
|
passthru.perl-bindings = final.callPackage ./perl {
|
|
|
|
|
inherit fileset;
|
|
|
|
|
stdenv = currentStdenv;
|
|
|
|
|
};
|
2022-01-25 02:28:44 +02:00
|
|
|
|
|
2022-03-02 04:40:18 +02:00
|
|
|
|
meta.platforms = lib.platforms.unix;
|
2023-10-15 22:08:07 +03:00
|
|
|
|
meta.mainProgram = "nix";
|
2023-02-20 21:27:50 +02:00
|
|
|
|
});
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
lowdown-nix = with final; currentStdenv.mkDerivation rec {
|
|
|
|
|
name = "lowdown-0.9.0";
|
2020-07-22 14:51:11 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
src = lowdown-src;
|
2020-07-22 14:51:11 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
outputs = [ "out" "bin" "dev" ];
|
2020-07-22 14:51:11 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
nativeBuildInputs = [ buildPackages.which ];
|
2020-07-22 14:51:11 +03:00
|
|
|
|
|
2022-01-25 02:28:44 +02:00
|
|
|
|
configurePhase = ''
|
|
|
|
|
${if (currentStdenv.isDarwin && currentStdenv.isAarch64) then "echo \"HAVE_SANDBOX_INIT=false\" > configure.local" else ""}
|
|
|
|
|
./configure \
|
|
|
|
|
PREFIX=${placeholder "dev"} \
|
|
|
|
|
BINDIR=${placeholder "bin"}/bin
|
|
|
|
|
'';
|
|
|
|
|
};
|
2020-07-22 14:51:11 +03:00
|
|
|
|
};
|
2020-03-13 19:31:16 +02:00
|
|
|
|
|
2021-07-08 18:01:51 +03:00
|
|
|
|
in {
|
|
|
|
|
# A Nixpkgs overlay that overrides the 'nix' and
|
|
|
|
|
# 'nix.perl-bindings' packages.
|
2022-02-11 16:05:07 +02:00
|
|
|
|
overlays.default = overlayFor (p: p.stdenv);
|
2021-07-08 18:01:51 +03:00
|
|
|
|
|
2020-03-13 19:31:16 +02:00
|
|
|
|
hydraJobs = {
|
|
|
|
|
|
2019-10-04 11:45:33 +03:00
|
|
|
|
# Binary package for various platforms.
|
2022-03-02 04:40:18 +02:00
|
|
|
|
build = forAllSystems (system: self.packages.${system}.nix);
|
2020-07-30 22:59:57 +03:00
|
|
|
|
|
2022-03-02 04:40:18 +02:00
|
|
|
|
buildStatic = lib.genAttrs linux64BitSystems (system: self.packages.${system}.nix-static);
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-03-02 04:40:18 +02:00
|
|
|
|
buildCross = forAllCrossSystems (crossSystem:
|
|
|
|
|
lib.genAttrs ["x86_64-linux"] (system: self.packages.${system}."nix-${crossSystem}"));
|
2021-02-06 02:07:48 +02:00
|
|
|
|
|
2022-03-02 04:40:18 +02:00
|
|
|
|
buildNoGc = forAllSystems (system: self.packages.${system}.nix.overrideAttrs (a: { configureFlags = (a.configureFlags or []) ++ ["--enable-gc=no"];}));
|
2022-12-13 11:44:07 +02:00
|
|
|
|
|
2023-02-20 21:27:50 +02:00
|
|
|
|
buildNoTests = forAllSystems (system:
|
|
|
|
|
self.packages.${system}.nix.overrideAttrs (a: {
|
|
|
|
|
doCheck =
|
|
|
|
|
assert ! a?dontCheck;
|
|
|
|
|
false;
|
|
|
|
|
})
|
|
|
|
|
);
|
|
|
|
|
|
2019-10-04 11:45:33 +03:00
|
|
|
|
# Perl bindings for various platforms.
|
2022-03-02 04:40:18 +02:00
|
|
|
|
perlBindings = forAllSystems (system: nixpkgsFor.${system}.native.nix.perl-bindings);
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
|
|
|
|
# Binary tarball for various platforms, containing a Nix store
|
|
|
|
|
# with the closure of 'nix' package, and the second half of
|
|
|
|
|
# the installation script.
|
2022-03-02 04:40:18 +02:00
|
|
|
|
binaryTarball = forAllSystems (system: binaryTarball nixpkgsFor.${system}.native.nix nixpkgsFor.${system}.native);
|
|
|
|
|
|
|
|
|
|
binaryTarballCross = lib.genAttrs ["x86_64-linux"] (system:
|
|
|
|
|
forAllCrossSystems (crossSystem:
|
|
|
|
|
binaryTarball
|
|
|
|
|
self.packages.${system}."nix-${crossSystem}"
|
|
|
|
|
nixpkgsFor.${system}.cross.${crossSystem}));
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
|
|
|
|
# The first half of the installation script. This is uploaded
|
|
|
|
|
# to https://nixos.org/nix/install. It downloads the binary
|
|
|
|
|
# tarball for the user's system and calls the second half of the
|
|
|
|
|
# installation script.
|
2021-06-26 08:12:03 +03:00
|
|
|
|
installerScript = installScriptFor [ "x86_64-linux" "i686-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" "armv6l-linux" "armv7l-linux" ];
|
2021-06-26 08:14:54 +03:00
|
|
|
|
installerScriptForGHA = installScriptFor [ "x86_64-linux" "x86_64-darwin" "armv6l-linux" "armv7l-linux"];
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2021-10-31 01:22:35 +03:00
|
|
|
|
# docker image with Nix inside
|
2022-03-02 04:40:18 +02:00
|
|
|
|
dockerImage = lib.genAttrs linux64BitSystems (system: self.packages.${system}.dockerImage);
|
2021-10-31 01:22:35 +03:00
|
|
|
|
|
2019-10-04 11:45:33 +03:00
|
|
|
|
# Line coverage analysis.
|
|
|
|
|
coverage =
|
2022-03-02 04:40:18 +02:00
|
|
|
|
with nixpkgsFor.x86_64-linux.native;
|
2022-07-11 21:56:19 +03:00
|
|
|
|
with commonDeps { inherit pkgs; };
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
|
|
|
|
releaseTools.coverageAnalysis {
|
2020-03-13 19:28:01 +02:00
|
|
|
|
name = "nix-coverage-${version}";
|
|
|
|
|
|
Add positive source filter
Source filtering is a really cool Nix feature that lets us avoid a
lot of rebuilds, which speeds up the iteration cycle a lot in cases
where the relevant source files aren't actually modified.
We used to have a source filter that marked a few files as irrelevant,
but this is the wrong approach, as we have many more files that are
irrelevant. We may call this negative filtering.
This commit switches the source filtering to positive filtering, which
is a lot more robust. Instead of marking which files we don't need
we marked the files that we do need.
It's a superior approach because it is fail safe. Instead of allowing
build performance problems to creep in over time, we require that all
source inputs are declared.
I shouldn't have to explain that declaring inputs is a good practice,
so I'll stop over-explaining here.
I do have to acknowledge that this will cause a build failure when the
filter is incomplete. This is *good*, because it's the only realistic
way we could be reminded of these problems. These events will be
infrequent, so the small cost of extending the filter is worth it,
compared to the hidden cost of longer dev cycles for things like tests,
docker image, etc, etc.
(Also rebuilding Nix for stupid unnecessary reasons makes my blood boil)
2023-08-14 13:24:26 +03:00
|
|
|
|
src = nixSrc;
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2023-02-13 19:37:35 +02:00
|
|
|
|
configureFlags = testConfigureFlags;
|
2023-01-25 02:19:19 +02:00
|
|
|
|
|
2020-01-21 22:18:52 +02:00
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
|
|
2020-07-30 22:59:57 +03:00
|
|
|
|
nativeBuildInputs = nativeBuildDeps;
|
2023-03-08 15:19:43 +02:00
|
|
|
|
buildInputs = buildDeps ++ propagatedDeps ++ awsDeps ++ checkDeps;
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
|
|
|
|
dontInstall = false;
|
|
|
|
|
|
|
|
|
|
doInstallCheck = true;
|
2023-03-08 15:19:43 +02:00
|
|
|
|
installCheckTarget = "installcheck"; # work around buggy detection in stdenv
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2019-11-08 15:29:10 +02:00
|
|
|
|
lcovFilter = [ "*/boost/*" "*-tab.*" ];
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2023-03-08 15:19:43 +02:00
|
|
|
|
hardeningDisable = ["fortify"];
|
2023-09-19 17:04:00 +03:00
|
|
|
|
|
|
|
|
|
NIX_CFLAGS_COMPILE = "-DCOVERAGE=1";
|
2019-10-04 11:45:33 +03:00
|
|
|
|
};
|
|
|
|
|
|
2023-02-13 19:37:35 +02:00
|
|
|
|
# API docs for Nix's unstable internal C++ interfaces.
|
|
|
|
|
internal-api-docs =
|
|
|
|
|
with nixpkgsFor.x86_64-linux.native;
|
|
|
|
|
with commonDeps { inherit pkgs; };
|
|
|
|
|
|
|
|
|
|
stdenv.mkDerivation {
|
|
|
|
|
pname = "nix-internal-api-docs";
|
|
|
|
|
inherit version;
|
|
|
|
|
|
Add positive source filter
Source filtering is a really cool Nix feature that lets us avoid a
lot of rebuilds, which speeds up the iteration cycle a lot in cases
where the relevant source files aren't actually modified.
We used to have a source filter that marked a few files as irrelevant,
but this is the wrong approach, as we have many more files that are
irrelevant. We may call this negative filtering.
This commit switches the source filtering to positive filtering, which
is a lot more robust. Instead of marking which files we don't need
we marked the files that we do need.
It's a superior approach because it is fail safe. Instead of allowing
build performance problems to creep in over time, we require that all
source inputs are declared.
I shouldn't have to explain that declaring inputs is a good practice,
so I'll stop over-explaining here.
I do have to acknowledge that this will cause a build failure when the
filter is incomplete. This is *good*, because it's the only realistic
way we could be reminded of these problems. These events will be
infrequent, so the small cost of extending the filter is worth it,
compared to the hidden cost of longer dev cycles for things like tests,
docker image, etc, etc.
(Also rebuilding Nix for stupid unnecessary reasons makes my blood boil)
2023-08-14 13:24:26 +03:00
|
|
|
|
src = nixSrc;
|
2023-02-13 19:37:35 +02:00
|
|
|
|
|
|
|
|
|
configureFlags = testConfigureFlags ++ internalApiDocsConfigureFlags;
|
|
|
|
|
|
|
|
|
|
nativeBuildInputs = nativeBuildDeps;
|
|
|
|
|
buildInputs = buildDeps ++ propagatedDeps
|
|
|
|
|
++ awsDeps ++ checkDeps ++ internalApiDocsDeps;
|
|
|
|
|
|
|
|
|
|
dontBuild = true;
|
|
|
|
|
|
|
|
|
|
installTargets = [ "internal-api-html" ];
|
|
|
|
|
|
|
|
|
|
postInstall = ''
|
|
|
|
|
mkdir -p $out/nix-support
|
2023-03-20 14:13:57 +02:00
|
|
|
|
echo "doc internal-api-docs $out/share/doc/nix/internal-api/html" >> $out/nix-support/hydra-build-products
|
2023-02-13 19:37:35 +02:00
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2019-10-04 11:45:33 +03:00
|
|
|
|
# System tests.
|
2023-10-06 17:53:01 +03:00
|
|
|
|
tests = import ./tests/nixos { inherit lib nixpkgs nixpkgsFor; } // {
|
2022-02-23 16:58:09 +02:00
|
|
|
|
|
2023-10-06 17:53:01 +03:00
|
|
|
|
# Make sure that nix-env still produces the exact same result
|
|
|
|
|
# on a particular version of Nixpkgs.
|
|
|
|
|
evalNixpkgs =
|
|
|
|
|
with nixpkgsFor.x86_64-linux.native;
|
|
|
|
|
runCommand "eval-nixos" { buildInputs = [ nix ]; }
|
|
|
|
|
''
|
|
|
|
|
type -p nix-env
|
|
|
|
|
# Note: we're filtering out nixos-install-tools because https://github.com/NixOS/nixpkgs/pull/153594#issuecomment-1020530593.
|
|
|
|
|
time nix-env --store dummy:// -f ${nixpkgs-regression} -qaP --drv-path | sort | grep -v nixos-install-tools > packages
|
|
|
|
|
[[ $(sha1sum < packages | cut -c1-40) = ff451c521e61e4fe72bdbe2d0ca5d1809affa733 ]]
|
|
|
|
|
mkdir $out
|
|
|
|
|
'';
|
2022-01-25 01:02:48 +02:00
|
|
|
|
|
2023-10-06 17:53:01 +03:00
|
|
|
|
nixpkgsLibTests =
|
|
|
|
|
forAllSystems (system:
|
|
|
|
|
import (nixpkgs + "/lib/tests/release.nix")
|
|
|
|
|
{ pkgs = nixpkgsFor.${system}.native;
|
|
|
|
|
nixVersions = [ self.packages.${system}.nix ];
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
};
|
2023-01-18 01:17:59 +02:00
|
|
|
|
|
2022-01-25 01:02:48 +02:00
|
|
|
|
metrics.nixpkgs = import "${nixpkgs-regression}/pkgs/top-level/metrics.nix" {
|
2022-03-02 04:40:18 +02:00
|
|
|
|
pkgs = nixpkgsFor.x86_64-linux.native;
|
2022-01-25 01:02:48 +02:00
|
|
|
|
nixpkgs = nixpkgs-regression;
|
|
|
|
|
};
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2021-10-15 13:36:29 +03:00
|
|
|
|
installTests = forAllSystems (system:
|
2022-03-02 04:40:18 +02:00
|
|
|
|
let pkgs = nixpkgsFor.${system}.native; in
|
2021-03-16 14:43:08 +02:00
|
|
|
|
pkgs.runCommand "install-tests" {
|
|
|
|
|
againstSelf = testNixVersions pkgs pkgs.nix pkgs.pkgs.nix;
|
2021-10-06 14:17:39 +03:00
|
|
|
|
againstCurrentUnstable =
|
|
|
|
|
# FIXME: temporarily disable this on macOS because of #3605.
|
|
|
|
|
if system == "x86_64-linux"
|
|
|
|
|
then testNixVersions pkgs pkgs.nix pkgs.nixUnstable
|
|
|
|
|
else null;
|
2021-03-16 14:43:08 +02:00
|
|
|
|
# Disabled because the latest stable version doesn't handle
|
|
|
|
|
# `NIX_DAEMON_SOCKET_PATH` which is required for the tests to work
|
|
|
|
|
# againstLatestStable = testNixVersions pkgs pkgs.nix pkgs.nixStable;
|
2021-10-15 13:36:29 +03:00
|
|
|
|
} "touch $out");
|
|
|
|
|
|
2022-09-14 16:40:43 +03:00
|
|
|
|
installerTests = import ./tests/installer {
|
|
|
|
|
binaryTarballs = self.hydraJobs.binaryTarball;
|
|
|
|
|
inherit nixpkgsFor;
|
|
|
|
|
};
|
|
|
|
|
|
2021-10-15 13:36:29 +03:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
checks = forAllSystems (system: {
|
|
|
|
|
binaryTarball = self.hydraJobs.binaryTarball.${system};
|
|
|
|
|
perlBindings = self.hydraJobs.perlBindings.${system};
|
|
|
|
|
installTests = self.hydraJobs.installTests.${system};
|
2023-01-18 01:17:59 +02:00
|
|
|
|
nixpkgsLibTests = self.hydraJobs.tests.nixpkgsLibTests.${system};
|
2022-03-02 04:40:18 +02:00
|
|
|
|
} // (lib.optionalAttrs (builtins.elem system linux64BitSystems)) {
|
2021-11-24 10:19:29 +02:00
|
|
|
|
dockerImage = self.hydraJobs.dockerImage.${system};
|
2021-12-21 23:42:47 +02:00
|
|
|
|
});
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-02-11 16:05:07 +02:00
|
|
|
|
packages = forAllSystems (system: rec {
|
2022-03-02 04:40:18 +02:00
|
|
|
|
inherit (nixpkgsFor.${system}.native) nix;
|
2022-02-11 16:05:07 +02:00
|
|
|
|
default = nix;
|
2022-03-02 04:40:18 +02:00
|
|
|
|
} // (lib.optionalAttrs (builtins.elem system linux64BitSystems) {
|
|
|
|
|
nix-static = nixpkgsFor.${system}.static.nix;
|
2022-01-26 15:31:23 +02:00
|
|
|
|
dockerImage =
|
|
|
|
|
let
|
2022-03-02 04:40:18 +02:00
|
|
|
|
pkgs = nixpkgsFor.${system}.native;
|
2022-01-26 15:31:23 +02:00
|
|
|
|
image = import ./docker.nix { inherit pkgs; tag = version; };
|
|
|
|
|
in
|
|
|
|
|
pkgs.runCommand
|
|
|
|
|
"docker-image-tarball-${version}"
|
|
|
|
|
{ meta.description = "Docker image with Nix for ${system}"; }
|
|
|
|
|
''
|
|
|
|
|
mkdir -p $out/nix-support
|
|
|
|
|
image=$out/image.tar.gz
|
|
|
|
|
ln -s ${image} $image
|
|
|
|
|
echo "file binary-dist $image" >> $out/nix-support/hydra-build-products
|
|
|
|
|
'';
|
2022-03-02 04:40:18 +02:00
|
|
|
|
} // builtins.listToAttrs (map
|
|
|
|
|
(crossSystem: {
|
|
|
|
|
name = "nix-${crossSystem}";
|
|
|
|
|
value = nixpkgsFor.${system}.cross.${crossSystem}.nix;
|
|
|
|
|
})
|
|
|
|
|
crossSystems)
|
|
|
|
|
// builtins.listToAttrs (map
|
|
|
|
|
(stdenvName: {
|
|
|
|
|
name = "nix-${stdenvName}";
|
|
|
|
|
value = nixpkgsFor.${system}.stdenvs."${stdenvName}Packages".nix;
|
|
|
|
|
})
|
|
|
|
|
stdenvs)));
|
|
|
|
|
|
|
|
|
|
devShells = let
|
|
|
|
|
makeShell = pkgs: stdenv:
|
2023-08-31 06:43:48 +03:00
|
|
|
|
let
|
|
|
|
|
canRunInstalled = stdenv.buildPlatform.canExecute stdenv.hostPlatform;
|
|
|
|
|
in
|
2022-07-11 21:56:19 +03:00
|
|
|
|
with commonDeps { inherit pkgs; };
|
2022-03-02 04:40:18 +02:00
|
|
|
|
stdenv.mkDerivation {
|
2022-02-11 16:05:07 +02:00
|
|
|
|
name = "nix";
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2023-11-14 17:52:57 +02:00
|
|
|
|
outputs = [ "out" "dev" "doc" ]
|
|
|
|
|
++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "check";
|
2020-08-28 19:16:03 +03:00
|
|
|
|
|
2022-11-25 15:47:05 +02:00
|
|
|
|
nativeBuildInputs = nativeBuildDeps
|
2023-08-31 06:27:53 +03:00
|
|
|
|
++ lib.optional stdenv.cc.isClang pkgs.buildPackages.bear
|
|
|
|
|
++ lib.optional
|
|
|
|
|
(stdenv.cc.isClang && stdenv.hostPlatform == stdenv.buildPlatform)
|
|
|
|
|
pkgs.buildPackages.clang-tools
|
2023-11-24 16:48:41 +02:00
|
|
|
|
# We want changelog-d in the shell even if the current build doesn't need it
|
|
|
|
|
++ lib.optional (officialRelease || ! buildUnreleasedNotes) changelog-d
|
2023-08-31 06:27:53 +03:00
|
|
|
|
;
|
2022-03-02 04:40:18 +02:00
|
|
|
|
|
2023-02-13 19:37:35 +02:00
|
|
|
|
buildInputs = buildDeps ++ propagatedDeps
|
|
|
|
|
++ awsDeps ++ checkDeps ++ internalApiDocsDeps;
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2023-02-13 19:37:35 +02:00
|
|
|
|
configureFlags = configureFlags
|
2023-08-31 06:43:48 +03:00
|
|
|
|
++ testConfigureFlags ++ internalApiDocsConfigureFlags
|
|
|
|
|
++ lib.optional (!canRunInstalled) "--disable-doc-gen";
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-02-11 16:05:07 +02:00
|
|
|
|
enableParallelBuilding = true;
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-02-11 16:05:07 +02:00
|
|
|
|
installFlags = "sysconfdir=$(out)/etc";
|
2019-10-04 11:45:33 +03:00
|
|
|
|
|
2022-02-11 16:05:07 +02:00
|
|
|
|
shellHook =
|
|
|
|
|
''
|
|
|
|
|
PATH=$prefix/bin:$PATH
|
|
|
|
|
unset PYTHONPATH
|
|
|
|
|
export MANPATH=$out/share/man:$MANPATH
|
2021-12-22 14:21:45 +02:00
|
|
|
|
|
2022-02-11 16:05:07 +02:00
|
|
|
|
# Make bash completion work.
|
|
|
|
|
XDG_DATA_DIRS+=:$out/share
|
|
|
|
|
'';
|
2022-03-02 04:40:18 +02:00
|
|
|
|
};
|
|
|
|
|
in
|
|
|
|
|
forAllSystems (system:
|
|
|
|
|
let
|
|
|
|
|
makeShells = prefix: pkgs:
|
|
|
|
|
lib.mapAttrs'
|
|
|
|
|
(k: v: lib.nameValuePair "${prefix}-${k}" v)
|
|
|
|
|
(forAllStdenvs (stdenvName: makeShell pkgs pkgs.${stdenvName}));
|
|
|
|
|
in
|
|
|
|
|
(makeShells "native" nixpkgsFor.${system}.native) //
|
|
|
|
|
(makeShells "static" nixpkgsFor.${system}.static) //
|
|
|
|
|
(forAllCrossSystems (crossSystem: let pkgs = nixpkgsFor.${system}.cross.${crossSystem}; in makeShell pkgs pkgs.stdenv)) //
|
|
|
|
|
{
|
|
|
|
|
default = self.devShells.${system}.native-stdenvPackages;
|
|
|
|
|
}
|
|
|
|
|
);
|
2019-04-08 18:28:05 +03:00
|
|
|
|
};
|
|
|
|
|
}
|