forked from lix-project/lix
Merge changes If1077a7b,I62da3161,Iebb4667b into main
* changes: flake: fix devShell on i686-linux by disabling ClangBuildAnalyzer on it flake: fix eval of checks & devshell on i686-linux flake: move the pre-commit definition to its own file
This commit is contained in:
commit
8715a0ac4e
3 changed files with 117 additions and 87 deletions
102
flake.nix
102
flake.nix
|
@ -96,6 +96,10 @@
|
||||||
];
|
];
|
||||||
|
|
||||||
forAllSystems = lib.genAttrs systems;
|
forAllSystems = lib.genAttrs systems;
|
||||||
|
# Same as forAllSystems, but removes nulls, in case something is broken
|
||||||
|
# on that system.
|
||||||
|
forAvailableSystems =
|
||||||
|
f: lib.filterAttrs (name: value: value != null && value != { }) (forAllSystems f);
|
||||||
|
|
||||||
forAllCrossSystems = lib.genAttrs crossSystems;
|
forAllCrossSystems = lib.genAttrs crossSystems;
|
||||||
|
|
||||||
|
@ -282,99 +286,21 @@
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
pre-commit = forAllSystems (
|
pre-commit = forAvailableSystems (
|
||||||
system:
|
system:
|
||||||
let
|
let
|
||||||
pkgs = nixpkgsFor.${system}.native;
|
pkgs = nixpkgsFor.${system}.native;
|
||||||
# Import pre-commit bypassing the flake because flakes don't let
|
pre-commit-check = import ./misc/pre-commit.nix { inherit self pkgs pre-commit-hooks; };
|
||||||
# you have overlays. Also their implementation forces an
|
# dotnet-sdk_6, a nativeBuildInputs of pre-commit, is broken on i686-linux.
|
||||||
# unnecessary reimport of nixpkgs for our use cases.
|
available = lib.meta.availableOn { inherit system; } pkgs.dotnet-sdk_6;
|
||||||
tools = import (pre-commit-hooks + "/nix/call-tools.nix") pkgs;
|
|
||||||
pre-commit-run = pkgs.callPackage (pre-commit-hooks + "/nix/run.nix") {
|
|
||||||
inherit tools;
|
|
||||||
isFlakes = true;
|
|
||||||
# unused!
|
|
||||||
gitignore-nix-src = builtins.throw "gitignore-nix-src is unused";
|
|
||||||
};
|
|
||||||
in
|
in
|
||||||
pre-commit-run {
|
lib.optionalAttrs available pre-commit-check
|
||||||
src = self;
|
|
||||||
hooks = {
|
|
||||||
no-commit-to-branch = {
|
|
||||||
enable = true;
|
|
||||||
settings.branch = [ "main" ];
|
|
||||||
};
|
|
||||||
check-case-conflicts.enable = true;
|
|
||||||
check-executables-have-shebangs = {
|
|
||||||
enable = true;
|
|
||||||
stages = [ "commit" ];
|
|
||||||
};
|
|
||||||
check-shebang-scripts-are-executable = {
|
|
||||||
enable = true;
|
|
||||||
stages = [ "commit" ];
|
|
||||||
};
|
|
||||||
check-symlinks = {
|
|
||||||
enable = true;
|
|
||||||
excludes = [ "^tests/functional/lang/symlink-resolution/broken$" ];
|
|
||||||
};
|
|
||||||
check-merge-conflicts.enable = true;
|
|
||||||
end-of-file-fixer = {
|
|
||||||
enable = true;
|
|
||||||
excludes = [
|
|
||||||
"\\.drv$"
|
|
||||||
"^tests/functional/lang/"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
mixed-line-endings = {
|
|
||||||
enable = true;
|
|
||||||
excludes = [ "^tests/functional/lang/" ];
|
|
||||||
};
|
|
||||||
release-notes = {
|
|
||||||
enable = true;
|
|
||||||
package = pkgs.build-release-notes;
|
|
||||||
files = "^doc/manual/rl-next(-dev)?";
|
|
||||||
pass_filenames = false;
|
|
||||||
entry = ''
|
|
||||||
${lib.getExe pkgs.build-release-notes} doc/manual/rl-next doc/manual/rl-next-dev
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
check-headers = {
|
|
||||||
enable = true;
|
|
||||||
package = pkgs.check-headers;
|
|
||||||
files = "^src/";
|
|
||||||
types = [
|
|
||||||
"c++"
|
|
||||||
"file"
|
|
||||||
"header"
|
|
||||||
];
|
|
||||||
# generated files; these will never actually be seen by this
|
|
||||||
# check, and are left here as documentation
|
|
||||||
excludes = [
|
|
||||||
"(parser|lexer)-tab\\.hh$"
|
|
||||||
"\\.gen\\.hh$"
|
|
||||||
];
|
|
||||||
entry = lib.getExe pkgs.check-headers;
|
|
||||||
};
|
|
||||||
# TODO: Once the test suite is nicer, clean up and start
|
|
||||||
# enforcing trailing whitespace on tests that don't explicitly
|
|
||||||
# check for it.
|
|
||||||
trim-trailing-whitespace = {
|
|
||||||
enable = true;
|
|
||||||
stages = [ "commit" ];
|
|
||||||
excludes = [ "^tests/functional/lang/" ];
|
|
||||||
};
|
|
||||||
treefmt = {
|
|
||||||
enable = true;
|
|
||||||
settings.formatters = [ pkgs.nixfmt ];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
# NOTE *do not* add fresh derivations to checks, always add them to
|
# NOTE *do not* add fresh derivations to checks, always add them to
|
||||||
# hydraJobs first (so CI will pick them up) and only link them here
|
# hydraJobs first (so CI will pick them up) and only link them here
|
||||||
checks = forAllSystems (
|
checks = forAvailableSystems (
|
||||||
system:
|
system:
|
||||||
{
|
{
|
||||||
binaryTarball = self.hydraJobs.binaryTarball.${system};
|
binaryTarball = self.hydraJobs.binaryTarball.${system};
|
||||||
|
@ -382,6 +308,7 @@
|
||||||
nixpkgsLibTests = self.hydraJobs.tests.nixpkgsLibTests.${system};
|
nixpkgsLibTests = self.hydraJobs.tests.nixpkgsLibTests.${system};
|
||||||
rl-next = self.hydraJobs.rl-next.${system}.user;
|
rl-next = self.hydraJobs.rl-next.${system}.user;
|
||||||
rl-next-dev = self.hydraJobs.rl-next.${system}.dev;
|
rl-next-dev = self.hydraJobs.rl-next.${system}.dev;
|
||||||
|
# Will be empty attr set on i686-linux, and filtered out by forAvailableSystems.
|
||||||
pre-commit = self.hydraJobs.pre-commit.${system};
|
pre-commit = self.hydraJobs.pre-commit.${system};
|
||||||
}
|
}
|
||||||
// (lib.optionalAttrs (builtins.elem system linux64BitSystems)) {
|
// (lib.optionalAttrs (builtins.elem system linux64BitSystems)) {
|
||||||
|
@ -481,9 +408,10 @@
|
||||||
pkgs.buildPackages.meson
|
pkgs.buildPackages.meson
|
||||||
pkgs.buildPackages.ninja
|
pkgs.buildPackages.ninja
|
||||||
pkgs.buildPackages.cmake
|
pkgs.buildPackages.cmake
|
||||||
|
]
|
||||||
pkgs.buildPackages.clangbuildanalyzer
|
++
|
||||||
];
|
lib.optionals (lib.meta.availableOn pkgs.stdenv.hostPlatform pkgs.buildPackages.clangbuildanalyzer)
|
||||||
|
[ pkgs.buildPackages.clangbuildanalyzer ];
|
||||||
|
|
||||||
src = null;
|
src = null;
|
||||||
|
|
||||||
|
|
|
@ -25,6 +25,9 @@ stdenv.mkDerivation (finalAttrs: {
|
||||||
maintainers = with lib.maintainers; [ lf- ];
|
maintainers = with lib.maintainers; [ lf- ];
|
||||||
license = lib.licenses.unlicense;
|
license = lib.licenses.unlicense;
|
||||||
platforms = lib.platforms.unix;
|
platforms = lib.platforms.unix;
|
||||||
|
# `long long int` != `size_t`
|
||||||
|
# There's no convenient lib.platforms.32bit or anything, but it's easy enough to do ourselves.
|
||||||
|
badPlatforms = lib.filter (plat: (lib.systems.elaborate plat).is32bit) lib.platforms.all;
|
||||||
mainProgram = "ClangBuildAnalyzer";
|
mainProgram = "ClangBuildAnalyzer";
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
|
|
99
misc/pre-commit.nix
Normal file
99
misc/pre-commit.nix
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
Path to Lix's source, normally the flake's "self" argument
|
||||||
|
*/
|
||||||
|
self ? pkgs.lib.cleanSource ./.,
|
||||||
|
/**
|
||||||
|
Already instantiated Nixpkgs
|
||||||
|
*/
|
||||||
|
pkgs,
|
||||||
|
/**
|
||||||
|
pre-commit-hooks source path, normally from the flake input
|
||||||
|
*/
|
||||||
|
pre-commit-hooks,
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
inherit (pkgs) lib;
|
||||||
|
# Import pre-commit bypassing the flake because flakes don't let
|
||||||
|
# you have overlays. Also their implementation forces an
|
||||||
|
# unnecessary reimport of nixpkgs for our use cases.
|
||||||
|
tools = import (pre-commit-hooks + "/nix/call-tools.nix") pkgs;
|
||||||
|
pre-commit-run = pkgs.callPackage (pre-commit-hooks + "/nix/run.nix") {
|
||||||
|
inherit tools;
|
||||||
|
isFlakes = true;
|
||||||
|
# unused!
|
||||||
|
gitignore-nix-src = builtins.throw "gitignore-nix-src is unused";
|
||||||
|
};
|
||||||
|
in
|
||||||
|
pre-commit-run {
|
||||||
|
src = self;
|
||||||
|
hooks = {
|
||||||
|
no-commit-to-branch = {
|
||||||
|
enable = true;
|
||||||
|
settings.branch = [ "main" ];
|
||||||
|
};
|
||||||
|
check-case-conflicts.enable = true;
|
||||||
|
check-executables-have-shebangs = {
|
||||||
|
enable = true;
|
||||||
|
stages = [ "commit" ];
|
||||||
|
};
|
||||||
|
check-shebang-scripts-are-executable = {
|
||||||
|
enable = true;
|
||||||
|
stages = [ "commit" ];
|
||||||
|
};
|
||||||
|
check-symlinks = {
|
||||||
|
enable = true;
|
||||||
|
excludes = [ "^tests/functional/lang/symlink-resolution/broken$" ];
|
||||||
|
};
|
||||||
|
check-merge-conflicts.enable = true;
|
||||||
|
end-of-file-fixer = {
|
||||||
|
enable = true;
|
||||||
|
excludes = [
|
||||||
|
"\\.drv$"
|
||||||
|
"^tests/functional/lang/"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
mixed-line-endings = {
|
||||||
|
enable = true;
|
||||||
|
excludes = [ "^tests/functional/lang/" ];
|
||||||
|
};
|
||||||
|
release-notes = {
|
||||||
|
enable = true;
|
||||||
|
package = pkgs.build-release-notes;
|
||||||
|
files = "^doc/manual/rl-next(-dev)?";
|
||||||
|
pass_filenames = false;
|
||||||
|
entry = ''
|
||||||
|
${lib.getExe pkgs.build-release-notes} doc/manual/rl-next doc/manual/rl-next-dev
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
check-headers = {
|
||||||
|
enable = true;
|
||||||
|
package = pkgs.check-headers;
|
||||||
|
files = "^src/";
|
||||||
|
types = [
|
||||||
|
"c++"
|
||||||
|
"file"
|
||||||
|
"header"
|
||||||
|
];
|
||||||
|
# generated files; these will never actually be seen by this
|
||||||
|
# check, and are left here as documentation
|
||||||
|
excludes = [
|
||||||
|
"(parser|lexer)-tab\\.hh$"
|
||||||
|
"\\.gen\\.hh$"
|
||||||
|
];
|
||||||
|
entry = lib.getExe pkgs.check-headers;
|
||||||
|
};
|
||||||
|
# TODO: Once the test suite is nicer, clean up and start
|
||||||
|
# enforcing trailing whitespace on tests that don't explicitly
|
||||||
|
# check for it.
|
||||||
|
trim-trailing-whitespace = {
|
||||||
|
enable = true;
|
||||||
|
stages = [ "commit" ];
|
||||||
|
excludes = [ "^tests/functional/lang/" ];
|
||||||
|
};
|
||||||
|
treefmt = {
|
||||||
|
enable = true;
|
||||||
|
settings.formatters = [ pkgs.nixfmt ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in a new issue