Compare commits

...

3 commits

5 changed files with 74 additions and 33 deletions

View file

@ -39,7 +39,9 @@
"159.69.4.2:443" "159.69.4.2:443"
"[2a01:4f8:1c0c:70d1::1]:443" "[2a01:4f8:1c0c:70d1::1]:443"
]; ];
extraConfig = '' extraConfig =
# lua
''
-- TLS certificate for DoT and DoH -- TLS certificate for DoT and DoH
-- https://knot-resolver.readthedocs.io/en/stable/daemon-bindings-net_tlssrv.html -- https://knot-resolver.readthedocs.io/en/stable/daemon-bindings-net_tlssrv.html
net.tls( net.tls(

View file

@ -50,6 +50,19 @@
frequency = config.nix.gc.dates; frequency = config.nix.gc.dates;
}; };
# Nix uses /tmp/ (tmpfs) during builds by default. This may cause 'No space
# left on device' errors with limited system memory or during big builds. Set
# the Nix daemon to use /var/tmp/ instead. Note that /var/tmp/ should ideally
# be on the same filesystem as /nix/store/ for faster copying of files.
# https://github.com/NixOS/nixpkgs/issues/54707
#
# NOTE: This does not change the directory for builds during `nixos-rebuild`.
# See overlays/nixos-rebuild.nix for workaround.
# https://github.com/NixOS/nixpkgs/issues/293114
systemd.services.nix-daemon = {
environment.TMPDIR = "/var/tmp";
};
# Run unpatched dynamic binaries on NixOS. # Run unpatched dynamic binaries on NixOS.
# https://github.com/Mic92/nix-ld # https://github.com/Mic92/nix-ld
programs.nix-ld.enable = true; programs.nix-ld.enable = true;

View file

@ -1,5 +1,6 @@
{...}: { {...}: {
imports = [ imports = [
./neovim.nix ./neovim.nix
./nixos-rebuild.nix
]; ];
} }

View file

@ -9,10 +9,10 @@
imports = ["${home-manager-unstable}/modules/programs/neovim.nix"]; imports = ["${home-manager-unstable}/modules/programs/neovim.nix"];
}; };
nixpkgs.overlays = [ nixpkgs.overlays = [
(self: super: { (final: prev: {
# Home-manager uses the neovim-unwrapped package for the neovim module # Home-manager uses the neovim-unwrapped package for the neovim module
neovim-unwrapped = nixpkgs-unstable.legacyPackages.${super.system}.neovim-unwrapped; neovim-unwrapped = nixpkgs-unstable.legacyPackages.${prev.system}.neovim-unwrapped;
vimPlugins = nixpkgs-unstable.legacyPackages.${super.system}.vimPlugins; vimPlugins = nixpkgs-unstable.legacyPackages.${prev.system}.vimPlugins;
}) })
]; ];
} }

View file

@ -0,0 +1,25 @@
{...}: {
# The Nix daemon's temporary build directory is changed from /tmp/ to
# /var/tmp in modules/base/nix.nix, but it is only respected by `nix build`,
# not `nixos-rebuild`.
# This overlay wraps `nixos-rebuild` to explicitly set TMPDIR=/var/tmp.
# https://github.com/NixOS/nixpkgs/issues/293114
nixpkgs.overlays = [
(final: prev: {
# `overrideAttrs`, instead of simply overriding the `nixos-rebuild`
# package, to ensure `nixos-rebuild.override`, which is used in NixOS,
# works and is overridden.
# https://wiki.nixos.org/wiki/Nix_Cookbook#Wrapping_packages
# TODO: There must be a better way to do this?
nixos-rebuild = prev.nixos-rebuild.overrideAttrs (oldAttrs: {
nativeBuildInputs = oldAttrs.nativeBuildInputs ++ [prev.makeWrapper];
postInstall =
oldAttrs.postInstall
+ ''
wrapProgram $out/bin/nixos-rebuild \
--set TMPDIR /var/tmp
'';
});
})
];
}