feat: impure symlink
This commit is contained in:
@@ -1,28 +1,29 @@
|
|||||||
|
root := `pwd`
|
||||||
|
NH := "IMPURE_ROOT=" + root + " nh"
|
||||||
|
|
||||||
all: fmt switch
|
all: fmt switch
|
||||||
|
|
||||||
switch:
|
switch:
|
||||||
@echo "Rebuilding NixOS..."
|
@echo "Rebuilding NixOS..."
|
||||||
@nh os switch .
|
@{{NH}} os switch . --impure
|
||||||
|
|
||||||
switch-offline:
|
switch-offline:
|
||||||
@echo "Rebuilding NixOS without net..."
|
@echo "Rebuilding NixOS without net..."
|
||||||
@nh os switch . --no-net
|
@{{NH}} os switch . --impure --no-net
|
||||||
|
|
||||||
offline:
|
alias offline := switch-offline
|
||||||
@echo "Rebuilding NixOS without net..."
|
|
||||||
@nh os switch . --no-net
|
|
||||||
|
|
||||||
boot:
|
boot:
|
||||||
@echo "Rebuilding NixOS..."
|
@echo "Rebuilding NixOS..."
|
||||||
@nh os boot .
|
@{{NH}} os boot . --impure
|
||||||
|
|
||||||
test:
|
test:
|
||||||
@echo "Rebuilding NixOS..."
|
@echo "Rebuilding NixOS..."
|
||||||
@nh os test .
|
@{{NH}} os test . --impure
|
||||||
|
|
||||||
vm:
|
vm:
|
||||||
@echo "Building NixOS VM..."
|
@echo "Building NixOS VM..."
|
||||||
@nh os build-vm .
|
@{{NH}} os build-vm . --impure
|
||||||
|
|
||||||
update:
|
update:
|
||||||
@echo "Updating flakes..."
|
@echo "Updating flakes..."
|
||||||
@@ -47,5 +48,3 @@ gc:
|
|||||||
fmt:
|
fmt:
|
||||||
@echo "Formatting nix files..."
|
@echo "Formatting nix files..."
|
||||||
@nix fmt
|
@nix fmt
|
||||||
|
|
||||||
.PHONY: all switch switch-offline boot test vm update repl cleandry clean gc fmt
|
|
||||||
@@ -1,8 +1,8 @@
|
|||||||
{ lib, inputs }:
|
{ lib, inputs }:
|
||||||
lib.extend (
|
lib.extend (
|
||||||
self: super: {
|
self: super: {
|
||||||
umport = import ./umport.nix { lib = self; };
|
|
||||||
inherit (inputs.home-manager.lib) hm;
|
inherit (inputs.home-manager.lib) hm;
|
||||||
|
umport = import ./umport.nix { lib = self; };
|
||||||
haumea = inputs.haumea.lib;
|
haumea = inputs.haumea.lib;
|
||||||
infuse = (import inputs.infuse { inherit lib; }).v1.infuse;
|
infuse = (import inputs.infuse { inherit lib; }).v1.infuse;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
config,
|
config,
|
||||||
lib,
|
lib,
|
||||||
pkgs,
|
pkgs,
|
||||||
|
impure,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
@@ -14,11 +15,8 @@ in
|
|||||||
|
|
||||||
config = lib.mkIf cfg.enable {
|
config = lib.mkIf cfg.enable {
|
||||||
my.hm = {
|
my.hm = {
|
||||||
xdg.configFile."nvim/init.lua".source = ./nvim/init.lua;
|
xdg.configFile."nvim/init.lua".source = impure.mkImpureLink ./nvim/init.lua;
|
||||||
xdg.configFile."nvim/lua" = {
|
xdg.configFile."nvim/lua".source = impure.mkImpureLink ./nvim/lua;
|
||||||
source = ./nvim/lua;
|
|
||||||
recursive = true;
|
|
||||||
};
|
|
||||||
programs.neovim = {
|
programs.neovim = {
|
||||||
enable = true;
|
enable = true;
|
||||||
defaultEditor = true;
|
defaultEditor = true;
|
||||||
|
|||||||
@@ -15,6 +15,7 @@ in
|
|||||||
config = lib.mkIf cfg.enable {
|
config = lib.mkIf cfg.enable {
|
||||||
my.hm = {
|
my.hm = {
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
|
just
|
||||||
gnumake
|
gnumake
|
||||||
github-cli # gh
|
github-cli # gh
|
||||||
];
|
];
|
||||||
|
|||||||
26
modules/impure.nix
Normal file
26
modules/impure.nix
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
{
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
self,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
relativePath =
|
||||||
|
path:
|
||||||
|
assert lib.types.path.check path;
|
||||||
|
lib.strings.removePrefix (toString self) (toString path);
|
||||||
|
mkImpureLink =
|
||||||
|
path:
|
||||||
|
let
|
||||||
|
relative = relativePath path;
|
||||||
|
in
|
||||||
|
pkgs.runCommandLocal relative { } "ln -s ${lib.escapeShellArg (impureRoot + relative)} $out";
|
||||||
|
impureRoot =
|
||||||
|
let
|
||||||
|
impureRoot = builtins.getEnv "IMPURE_ROOT";
|
||||||
|
in
|
||||||
|
if impureRoot == "" then throw "IMPURE_ROOT is not set" else impureRoot;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
_module.args.impure = { inherit mkImpureLink; };
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user