feat(flake): clean up & simplify config
- remove unused wrappers - improve packages & overlays setup - simplify createSystem
This commit is contained in:
parent
d91a8d24d4
commit
ec7c430e11
78
flake.nix
78
flake.nix
|
@ -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
5
pkgs/default.nix
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
{ pkgs, ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
deconz = pkgs.callPackage ./deconz { };
|
||||||
|
}
|
|
@ -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
|
|
||||||
'';
|
|
||||||
}) { }
|
|
|
@ -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; })
|
|
6
pkgs/vim-plugins/default.nix
Normal file
6
pkgs/vim-plugins/default.nix
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
{ inputs, pkgs, ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
nvim-kitty-navigator =
|
||||||
|
pkgs.callPackage ./nvim-kitty-navigator { inherit inputs; };
|
||||||
|
}
|
8
pkgs/vim-plugins/nvim-kitty-navigator/default.nix
Normal file
8
pkgs/vim-plugins/nvim-kitty-navigator/default.nix
Normal 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;
|
||||||
|
}
|
Loading…
Reference in a new issue