refact: Move dev-only dependencies into separate lock file
(cherry picked from commit ddf306bb9564a43fb42ab4321b390e766254f1c4)
This commit is contained in:
parent
271cf09450
commit
7918175c24
6 changed files with 188 additions and 153 deletions
83
flake.nix
83
flake.nix
|
|
@ -8,8 +8,6 @@
|
|||
nix-cargo-integration.url = "github:yusdacra/nix-cargo-integration";
|
||||
nix-cargo-integration.inputs.nixpkgs.follows = "nixpkgs";
|
||||
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
||||
pre-commit-hooks-nix.url = "github:cachix/pre-commit-hooks.nix";
|
||||
pre-commit-hooks-nix.inputs.nixpkgs.follows = "nixpkgs";
|
||||
};
|
||||
|
||||
outputs = inputs@{ self, flake-parts, ... }:
|
||||
|
|
@ -17,86 +15,21 @@
|
|||
{ inherit inputs; }
|
||||
({ lib, ... }: {
|
||||
imports = [
|
||||
inputs.pre-commit-hooks-nix.flakeModule
|
||||
inputs.nix-cargo-integration.flakeModule
|
||||
inputs.flake-parts.flakeModules.partitions
|
||||
./rust/nci.nix
|
||||
];
|
||||
systems = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ];
|
||||
perSystem = { config, self', inputs', pkgs, ... }: {
|
||||
|
||||
|
||||
|
||||
packages.nix = inputs'.nix.packages.nix;
|
||||
|
||||
pre-commit.settings.hooks.nixpkgs-fmt.enable = true;
|
||||
# Temporarily disable rustfmt due to configuration issues
|
||||
# pre-commit.settings.hooks.rustfmt.enable = true;
|
||||
# New configuration for rustfmt
|
||||
pre-commit.settings.settings.rust.cargoManifestPath = "./rust/Cargo.toml";
|
||||
|
||||
# Check that we're using ///-style doc comments in Rust code.
|
||||
#
|
||||
# Unfortunately, rustfmt won't do this for us yet - at least not
|
||||
# without nightly, and it might do too much.
|
||||
pre-commit.settings.hooks.rust-doc-comments = {
|
||||
enable = true;
|
||||
files = "\\.rs$";
|
||||
entry = "${pkgs.writeScript "rust-doc-comments" ''
|
||||
#!${pkgs.runtimeShell}
|
||||
set -uxo pipefail
|
||||
grep -n -C3 --color=always -F '/**' "$@"
|
||||
r=$?
|
||||
set -e
|
||||
if [ $r -eq 0 ]; then
|
||||
echo "Please replace /**-style comments by /// style comments in Rust code."
|
||||
exit 1
|
||||
fi
|
||||
''}";
|
||||
};
|
||||
|
||||
devShells.default = pkgs.mkShell {
|
||||
name = "nix-bindings-devshell";
|
||||
strictDeps = true;
|
||||
inputsFrom = [ config.nci.outputs.nix-bindings.devShell ];
|
||||
inherit (config.nci.outputs.nix-bindings.devShell.env)
|
||||
LIBCLANG_PATH
|
||||
BINDGEN_EXTRA_CLANG_ARGS
|
||||
;
|
||||
NIX_DEBUG_INFO_DIRS =
|
||||
let
|
||||
# TODO: add to Nixpkgs lib
|
||||
getDebug = pkg:
|
||||
if pkg?debug then pkg.debug
|
||||
else if pkg?lib then pkg.lib
|
||||
else pkg;
|
||||
in
|
||||
"${getDebug config.packages.nix}/lib/debug";
|
||||
buildInputs = [
|
||||
config.packages.nix
|
||||
];
|
||||
nativeBuildInputs = [
|
||||
pkgs.rust-analyzer
|
||||
pkgs.nixpkgs-fmt
|
||||
pkgs.rustfmt
|
||||
pkgs.pkg-config
|
||||
pkgs.clang-tools # clangd
|
||||
pkgs.valgrind
|
||||
pkgs.gdb
|
||||
# TODO: set up cargo-valgrind in shell and build
|
||||
# currently both this and `cargo install cargo-valgrind`
|
||||
# produce a binary that says ENOENT.
|
||||
# pkgs.cargo-valgrind
|
||||
];
|
||||
shellHook = ''
|
||||
${config.pre-commit.installationScript}
|
||||
echo 1>&2 "Welcome to the development shell!"
|
||||
'';
|
||||
# rust-analyzer needs a NIX_PATH for some reason
|
||||
NIX_PATH = "nixpkgs=${inputs.nixpkgs}";
|
||||
};
|
||||
};
|
||||
flake = {
|
||||
herculesCI.ciSystems = [ "x86_64-linux" ];
|
||||
|
||||
partitionedAttrs.devShells = "dev";
|
||||
partitionedAttrs.checks = "dev";
|
||||
partitionedAttrs.herculesCI = "dev";
|
||||
partitions.dev.extraInputsFlake = ./dev;
|
||||
partitions.dev.module = {
|
||||
imports = [ ./dev/flake-module.nix ];
|
||||
};
|
||||
});
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue