feat(flake): clean up & simplify config

- remove unused wrappers
- improve packages & overlays setup
- simplify createSystem
This commit is contained in:
Felix Schröter 2023-07-22 20:33:36 +02:00
parent d91a8d24d4
commit ec7c430e11
Signed by: felschr
GPG key ID: 671E39E6744C807D
6 changed files with 47 additions and 89 deletions

View file

@ -51,59 +51,20 @@
systems = [ "x86_64-linux" "aarch64-linux" ]; systems = [ "x86_64-linux" "aarch64-linux" ];
imports = [ ]; imports = [ ];
flake = rec { flake = rec {
overlays = {
unstable = final: prev: {
unstable = import nixpkgs-unstable {
inherit (prev) system;
config.allowUnfree = true;
};
};
neovim = final: prev:
let
buildVimPlugin = name: input:
prev.pkgs.vimUtils.buildVimPluginFrom2Nix {
pname = name;
version = input.rev;
versionSuffix = "-git";
src = input;
};
in {
vimPlugins = prev.vimPlugins // {
nvim-kitty-navigator =
buildVimPlugin "nvim-kitty-navigator" nvim-kitty-navigator;
};
};
deconz = final: prev: {
deconz = final.qt5.callPackage ./pkgs/deconz { };
};
wrappers = final: prev: {
genericBinWrapper =
final.callPackage ./pkgs/generic-bin-wrapper { };
mullvadExcludeWrapper =
final.callPackage ./pkgs/mullvad-exclude-wrapper { };
};
};
lib = rec { lib = rec {
systemDefaults = {
modules =
[ nixosModules.flakeDefaults agenix.nixosModules.default ];
overlays = with overlays; [
unstable
nur.overlay
neovim
deconz
wrappers
];
};
createSystem = hostName: createSystem = hostName:
{ hardwareConfig, config }: { hardwareConfig, config }:
({ pkgs, lib, ... }: { ({ pkgs, lib, ... }: {
networking.hostName = hostName; networking.hostName = hostName;
nixpkgs.overlays = systemDefaults.overlays; nixpkgs.overlays = [ nur.overlay self.overlays.default ];
imports = systemDefaults.modules ++ [ hardwareConfig config ]; imports = [
nixosModules.flakeDefaults
agenix.nixosModules.default
hardwareConfig
config
];
environment.systemPackages = environment.systemPackages =
[ agenix.packages.x86_64-linux.default ]; [ agenix.packages.x86_64-linux.default ];
@ -115,6 +76,16 @@
createMediaGroup = _: { users.groups.media.gid = 600; }; createMediaGroup = _: { users.groups.media.gid = 600; };
}; };
overlays.default = final: prev: {
unstable = import nixpkgs-unstable {
inherit (prev) system;
config.allowUnfree = true;
};
inherit (self.packages.${prev.system}) deconz;
vimPlugins = prev.vimPlugins
// final.callPackage ./pkgs/vim-plugins { inherit inputs; };
};
nixosModules = { nixosModules = {
flakeDefaults = import ./modules/flakeDefaults.nix; flakeDefaults = import ./modules/flakeDefaults.nix;
systemdNotify = import ./modules/systemdNotify.nix; systemdNotify = import ./modules/systemdNotify.nix;
@ -207,13 +178,20 @@
}; };
}; };
}; };
perSystem = { system, config, pkgs, ... }: rec { perSystem = { system, config, pkgs, ... }: {
packages = { deconz = pkgs.qt5.callPackage ./pkgs/deconz { }; }; _module.args.pkgs = import nixpkgs {
inherit system;
config.allowUnfree = true;
};
apps = { deconz = flake-utils.lib.mkApp { drv = packages.deconz; }; }; packages = pkgs.callPackage ./pkgs { };
apps = {
deconz = flake-utils.lib.mkApp { drv = config.packages.deconz; };
};
devShells.default = devShells.default =
pkgs.mkShell { inherit (checks.pre-commit) shellHook; }; pkgs.mkShell { inherit (config.checks.pre-commit) shellHook; };
checks = deploy-rs.lib.${system}.deployChecks self.deploy // { checks = deploy-rs.lib.${system}.deployChecks self.deploy // {
pre-commit = pre-commit-hooks.lib.${system}.run { pre-commit = pre-commit-hooks.lib.${system}.run {

5
pkgs/default.nix Normal file
View file

@ -0,0 +1,5 @@
{ pkgs, ... }:
{
deconz = pkgs.callPackage ./deconz { };
}

View file

@ -1,32 +0,0 @@
{ stdenv, callPackage }:
{ package # pkg must contain $out/bin with executables within.
, binPath ?
"bin/${package.meta.mainProgram or package.pname}" # path to look for binary
, wrapper # wrapper must contain @EXECUTABLE@ as a placeholder for the binary to run.
}:
# pass through all arguments to wrapped package to allow overriding
# arguments in wrapped package
callPackage (args:
stdenv.mkDerivation {
name = "${package.name}-wrapped";
inherit (package) version;
src = package.override args;
dontUnpack = true;
# inherit passthru
inherit (package) passthru;
installPhase = ''
local executable=$out/${binPath}
install -D ${wrapper} "$executable"
substituteInPlace "$executable" --subst-var-by EXECUTABLE "$f"
# Symlink the share directory so that .desktop files and such continue to work.
if [[ -d $src/share ]]
then
ln -s $src/share $out/share
fi
'';
}) { }

View file

@ -1,7 +0,0 @@
{ writeShellScript, genericBinWrapper, mullvad-vpn }:
args:
let
wrapper = writeShellScript "mullvad-exclude" ''
${mullvad-vpn}/bin/mullvad-exclude "@EXECUTABLE@" "$@"
'';
in genericBinWrapper (args // { inherit wrapper; })

View file

@ -0,0 +1,6 @@
{ inputs, pkgs, ... }:
{
nvim-kitty-navigator =
pkgs.callPackage ./nvim-kitty-navigator { inherit inputs; };
}

View file

@ -0,0 +1,8 @@
{ inputs, pkgs, ... }:
pkgs.vimUtils.buildVimPluginFrom2Nix {
pname = "nvim-kitty-navigator";
version = inputs.nvim-kitty-navigator.rev;
versionSuffix = "-git";
src = inputs.nvim-kitty-navigator;
}