NullBite 00eb9d49b3
common/nix: chanage nixpkgs flake to github ref
This makes it so flake.lock files produced by `nix flake lock` don't
reference my personal Nix store, but upstream Nixpkgs
2024-02-14 10:41:15 +01:00

66 lines
2.1 KiB
Nix

{ pkgs, lib, config, options, inputs, ... }:
let
cfg = config.nixfiles.common.nix;
in
{
options.nixfiles.common.nix = {
enable = lib.mkEnableOption "common Nix configuration";
registerNixpkgs = lib.mkOption {
type = lib.types.bool;
default = cfg.enable;
example = "true";
description = "Whether to register the Nixpkgs revision used by Nixfiles to the system's flake registry and make it tye system's <nixpkgs> channel";
};
/* # TODO
register = lib.mkOption {
type = lib.types.bool;
default = cfg.enable;
example = "true";
description = "Whether to register Nixfiles to the system's flake registry";
};
*/
};
config = lib.mkMerge [
( lib.mkIf cfg.registerNixpkgs {
# this makes modern nix tools use the system's version of nixpkgs
nix.registry = {
nixpkgs = {
exact = true;
from = {
id = "nixpkgs";
type = "indirect";
};
# used instead of `flake` option so produced flake.lock files are
# portable
to = {
type = "github";
owner = "NixOS";
repo = "nixpkgs";
rev = "${inputs.nixpkgs.rev}";
};
};
};
# this makes comma and legacy nix utils use the flake nixpkgs for ABI
# compatibility becasue once `, vkcube` couldn't find the correct opengl
# driver or something (also it reduces the download size of temporary shell
# closures)
nix.nixPath = [ "nixpkgs=${inputs.nixpkgs}" ] ++ options.nix.nixPath.default;
})
( lib.mkIf cfg.enable {
# direnv is a tool to automatically load shell environments upon entering
# a directory. nix-direnv has an extensionn to keep nix shells in the
# system's gcroots so shells can be used after a gc without rebuilding.
programs.direnv.enable = lib.mkDefault true;
# fallback to building locally if binary cache fails (home-manager should be
# able to handle simple rebuilds offline)
nix.settings.fallback = lib.mkDefault true;
})
];
}