From 42536537fa5234d7c1b45835b17f4ea0f1c34994 Mon Sep 17 00:00:00 2001 From: DannyDannyDanny Date: Tue, 9 Sep 2025 21:04:42 +0200 Subject: [PATCH 1/2] feat!: adding neovim via homemanager :boom:D --- nixos/flake.lock | 43 ++++++++++++ nixos/flake.nix | 20 +++--- nixos/home/danny/home.nix | 133 ++++++++++++++++++++++++++++++++++++++ nixos/hosts/macos.nix | 1 - 4 files changed, 188 insertions(+), 9 deletions(-) create mode 100644 nixos/home/danny/home.nix diff --git a/nixos/flake.lock b/nixos/flake.lock index db57cf1..ff6de83 100644 --- a/nixos/flake.lock +++ b/nixos/flake.lock @@ -34,6 +34,47 @@ "type": "github" } }, + "home-manager": { + "inputs": { + "nixpkgs": [ + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1757385184, + "narHash": "sha256-LCxtQn9ajvOgGRbQIRUJgfP7clMGGvV1SDW1HcSb0zk=", + "owner": "nix-community", + "repo": "home-manager", + "rev": "26993d87fd0d3b14f7667b74ad82235f120d986e", + "type": "github" + }, + "original": { + "owner": "nix-community", + "repo": "home-manager", + "type": "github" + } + }, + "nix-darwin": { + "inputs": { + "nixpkgs": [ + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1757430124, + "narHash": "sha256-MhDltfXesGH8VkGv3hmJ1QEKl1ChTIj9wmGAFfWj/Wk=", + "owner": "nix-darwin", + "repo": "nix-darwin", + "rev": "830b3f0b50045cf0bcfd4dab65fad05bf882e196", + "type": "github" + }, + "original": { + "owner": "nix-darwin", + "ref": "master", + "repo": "nix-darwin", + "type": "github" + } + }, "nixos-wsl": { "inputs": { "flake-compat": "flake-compat", @@ -102,6 +143,8 @@ }, "root": { "inputs": { + "home-manager": "home-manager", + "nix-darwin": "nix-darwin", "nixos-wsl": "nixos-wsl", "nixpkgs": "nixpkgs_2", "vscode-server": "vscode-server" diff --git a/nixos/flake.nix b/nixos/flake.nix index d21ce2d..c296ad9 100644 --- a/nixos/flake.nix +++ b/nixos/flake.nix @@ -9,9 +9,8 @@ nix-darwin.url = "github:nix-darwin/nix-darwin/master"; nix-darwin.inputs.nixpkgs.follows = "nixpkgs"; - # for later - # home-manager.url = "github:nix-community/home-manager"; - # home-manager.inputs.nixpkgs.follows = "nixpkgs"; + home-manager.url = "github:nix-community/home-manager"; + home-manager.inputs.nixpkgs.follows = "nixpkgs"; }; outputs = { @@ -20,7 +19,7 @@ vscode-server, nix-darwin, self, - # home-manager, + home-manager, ... }: { nixosConfigurations = { @@ -57,11 +56,16 @@ darwinConfigurations."Daniel-Macbook-Air" = nix-darwin.lib.darwinSystem { modules = [ ./hosts/macos.nix - # TODO: nix-darwin lacks tmux options; move to Home Manager.x - # ./tmux.nix - # TODO: add neovim via homemanager, that should work the same for NixOS as Nix-Darwin - # ./neovim.nix # NOTE: Option only exists on NixOS. ./fish.nix + + # Home Manager on macOS + home-manager.darwinModules.home-manager + { + home-manager.useGlobalPkgs = true; + home-manager.useUserPackages = true; + # Point HM to your user config (mac-only for now) + home-manager.users.danny = import ./home/danny/home.nix; + } ]; }; }; diff --git a/nixos/home/danny/home.nix b/nixos/home/danny/home.nix new file mode 100644 index 0000000..5a195ae --- /dev/null +++ b/nixos/home/danny/home.nix @@ -0,0 +1,133 @@ +{ pkgs, ... }: +{ + home.username = "danny"; + home.homeDirectory = "/Users/danny"; + + programs.home-manager.enable = true; + + # Neovim (user-level, works great on macOS) + programs.neovim = { + enable = true; + defaultEditor = true; + # extraLuaConfig is also available; we’ll keep your Vimscript as-is: + extraConfig = '' + set title + set go=a + set mouse=a + set nohlsearch + set number + let mapleader="," + + lua << EOF + local config_file = os.getenv("HOME")..'/.local/share/nvim_color_scheme' + local f = io.open(config_file, "r") + if f ~= nil then + local system_theme = f:read() + io.close(f) + if system_theme == 'dark' then + vim.cmd("set bg=dark") + elseif system_theme == 'light' then + vim.cmd("set bg=light") + else + print('warning: expected value "light" or "dark"') + print(' got:', system_theme) + print(' expected path:', config_file) + end + else + print('warning: nvim color scheme not found') + print(' expected path:', config_file) + end + EOF + + colorscheme catppuccin " catppuccin-latte, catppuccin-frappe, catppuccin-macchiato, catppuccin-mocha + + " netrw (dir listing) settings + let g:netrw_liststyle = 3 + let g:netrw_banner = 0 + let g:netrw_browse_split = 3 + let g:netrw_winsize = 25 " % of page + + set listchars=tab:→\ ,space:·,nbsp:␣,trail:•,eol:¶,precedes:«,extends:» + set clipboard+=unnamedplus + + " Replace-all is aliased to S. + nnoremap S :%s//g + + " save file with ,w + map w :w + + " spellcheck + set spell spelllang=en_us + setlocal spell! spelllang=en_us + ''; + + plugins = with pkgs.vimPlugins; [ + vim-surround + vim-gitgutter + vim-nix + vimtex + fzf-vim + nerdtree + rainbow + catppuccin-nvim + goyo-vim + limelight-vim + ]; + }; + + # tmux (user-level; same config on macOS and NixOS if you reuse this file) + programs.tmux = { + enable = true; + # Keep portable things in extraConfig: + extraConfig = '' + # remap prefix from ^B to Alt-f + unbind C-b + set -g prefix M-f + bind M-f send-prefix + + # nvim 'checkhealth' advice + set -g focus-events on + set -sa terminal-overrides ',xterm-256color:RGB' + set -g default-terminal "screen-256color" + + # indices + set -g base-index 1 + set -g pane-base-index 1 + + # sensible defaults + set -g mouse on + setw -g mode-keys vi + set -g history-limit 100000 + set -g escape-time 20 + + # pane movement shortcuts + bind h select-pane -L + bind j select-pane -D + bind k select-pane -U + bind l select-pane -R + + # window selection + bind -r C-h select-window -t :- + bind -r C-l select-window -t :+ + + # split with dash and vbar + bind | split-window -h -c "#{pane_current_path}" + bind - split-window -v -c "#{pane_current_path}" + ''; + plugins = with pkgs.tmuxPlugins; [ + catppuccin + tmux-fzf + extrakto + ]; + }; + + # Put user-installed binaries here if you want HM to own them (optional) + home.packages = with pkgs; [ + neovim + tmux + ]; + + # First HM version for this user config; bump only if you understand the migration notes. + home.stateVersion = "24.11"; +} + diff --git a/nixos/hosts/macos.nix b/nixos/hosts/macos.nix index f55869c..7294561 100644 --- a/nixos/hosts/macos.nix +++ b/nixos/hosts/macos.nix @@ -64,7 +64,6 @@ fzf cowsay lolcat - neovim ]; # Keep for darwin as well (tracks defaults across upgrades) From ea8fb243c39be137f86bcbf1cd576b68c33c8311 Mon Sep 17 00:00:00 2001 From: DannyDannyDanny Date: Tue, 9 Sep 2025 21:57:04 +0200 Subject: [PATCH 2/2] =?UTF-8?q?fix(darwin+HM):=20align=20nixpkgs=E2=86=94n?= =?UTF-8?q?ix-darwin,=20force=20HM=20home=20path,=20dedupe=20nvim/tmux=20?= =?UTF-8?q?=F0=9F=94=A7?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - track nixpkgs at `github:NixOS/nixpkgs/nixpkgs-unstable` to pair with `nix-darwin/master` - update lockfile inputs: flake-compat, home-manager, NixOS-WSL, nixpkgs, nixos-vscode-server - darwin: wrap HM module in a function to access `lib` and `mkForce` `home.homeDirectory = "/Users/danny"` (and set username) to satisfy HM’s absolute-path requirement under root activation - HM: comment out duplicated `home.username` / `home.homeDirectory` in `home/danny/home.nix` - HM: remove `neovim` and `tmux` from `home.packages` (managed via `programs.*`), fixing conflicting `nvim` subpath error --- nixos/flake.lock | 44 +++++++++++++++++++-------------------- nixos/flake.nix | 20 +++++++++++------- nixos/home/danny/home.nix | 13 ++++++------ 3 files changed, 41 insertions(+), 36 deletions(-) diff --git a/nixos/flake.lock b/nixos/flake.lock index ff6de83..4c670fd 100644 --- a/nixos/flake.lock +++ b/nixos/flake.lock @@ -3,11 +3,11 @@ "flake-compat": { "flake": false, "locked": { - "lastModified": 1733328505, - "narHash": "sha256-NeCCThCEP3eCl2l/+27kNNK7QrwZB1IJCrXfrbv5oqU=", + "lastModified": 1747046372, + "narHash": "sha256-CIVLLkVgvHYbgI2UpXvIIBJ12HWgX+fjA8Xf8PUmqCY=", "owner": "edolstra", "repo": "flake-compat", - "rev": "ff81ac966bb2cae68946d5ed5fc4994f96d0ffec", + "rev": "9100a0f413b0c601e0533d1d94ffd501ce2e7885", "type": "github" }, "original": { @@ -41,11 +41,11 @@ ] }, "locked": { - "lastModified": 1757385184, - "narHash": "sha256-LCxtQn9ajvOgGRbQIRUJgfP7clMGGvV1SDW1HcSb0zk=", + "lastModified": 1757443987, + "narHash": "sha256-T7E4CIsZBUzrUcPRyTG9FA2xd48MtbQ/HpIaaCfwZwc=", "owner": "nix-community", "repo": "home-manager", - "rev": "26993d87fd0d3b14f7667b74ad82235f120d986e", + "rev": "d587e11cef9caa9484ed090eddc55f4c56908342", "type": "github" }, "original": { @@ -81,11 +81,11 @@ "nixpkgs": "nixpkgs" }, "locked": { - "lastModified": 1736095716, - "narHash": "sha256-csysw/Szu98QDiA2lhWk9seYOyCebeVEWL89zh1cduM=", + "lastModified": 1757427959, + "narHash": "sha256-p0i07rLfAMzJWYfsjFOXEtIWeS1EGVxJaCi9gfyCwRE=", "owner": "nix-community", "repo": "NixOS-WSL", - "rev": "63c3b4ed1712a3a0621002cd59bfdc80875ecbb0", + "rev": "785f1b67b6c53de088f640f2a7da50ca4b2d7161", "type": "github" }, "original": { @@ -97,32 +97,32 @@ }, "nixpkgs": { "locked": { - "lastModified": 1733384649, - "narHash": "sha256-K5DJ2LpPqht7K76bsxetI+YHhGGRyVteTPRQaIIKJpw=", + "lastModified": 1757068644, + "narHash": "sha256-NOrUtIhTkIIumj1E/Rsv1J37Yi3xGStISEo8tZm3KW4=", "owner": "NixOS", "repo": "nixpkgs", - "rev": "190c31a89e5eec80dd6604d7f9e5af3802a58a13", + "rev": "8eb28adfa3dc4de28e792e3bf49fcf9007ca8ac9", "type": "github" }, "original": { "owner": "NixOS", - "ref": "nixos-24.05", + "ref": "nixos-unstable", "repo": "nixpkgs", "type": "github" } }, "nixpkgs_2": { "locked": { - "lastModified": 1737062831, - "narHash": "sha256-Tbk1MZbtV2s5aG+iM99U8FqwxU/YNArMcWAv6clcsBc=", - "owner": "nixos", + "lastModified": 1757034884, + "narHash": "sha256-PgLSZDBEWUHpfTRfFyklmiiLBE1i1aGCtz4eRA3POao=", + "owner": "NixOS", "repo": "nixpkgs", - "rev": "5df43628fdf08d642be8ba5b3625a6c70731c19c", + "rev": "ca77296380960cd497a765102eeb1356eb80fed0", "type": "github" }, "original": { - "owner": "nixos", - "ref": "nixos-unstable", + "owner": "NixOS", + "ref": "nixpkgs-unstable", "repo": "nixpkgs", "type": "github" } @@ -171,11 +171,11 @@ "nixpkgs": "nixpkgs_3" }, "locked": { - "lastModified": 1729422940, - "narHash": "sha256-DlvJv33ml5UTKgu4b0HauOfFIoDx6QXtbqUF3vWeRCY=", + "lastModified": 1753541826, + "narHash": "sha256-foGgZu8+bCNIGeuDqQ84jNbmKZpd+JvnrL2WlyU4tuU=", "owner": "nix-community", "repo": "nixos-vscode-server", - "rev": "8b6db451de46ecf9b4ab3d01ef76e59957ff549f", + "rev": "6d5f074e4811d143d44169ba4af09b20ddb6937d", "type": "github" }, "original": { diff --git a/nixos/flake.nix b/nixos/flake.nix index c296ad9..dc6ea8b 100644 --- a/nixos/flake.nix +++ b/nixos/flake.nix @@ -1,11 +1,12 @@ { inputs = { - nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable"; + + + + nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable"; nixos-wsl.url = "github:nix-community/NixOS-WSL/main"; vscode-server.url = "github:nix-community/nixos-vscode-server"; - # nix-darwin for macOS - # (follows nixpkgs so both use the same channel) nix-darwin.url = "github:nix-darwin/nix-darwin/master"; nix-darwin.inputs.nixpkgs.follows = "nixpkgs"; @@ -60,12 +61,17 @@ # Home Manager on macOS home-manager.darwinModules.home-manager - { + ({ lib, ... }: { home-manager.useGlobalPkgs = true; home-manager.useUserPackages = true; - # Point HM to your user config (mac-only for now) - home-manager.users.danny = import ./home/danny/home.nix; - } + home-manager.users.danny = { ... }: { + + # Force an absolute path even if another module sets a bad value. + home.username = "danny"; + home.homeDirectory = lib.mkForce "/Users/danny"; + imports = [ ./home/danny/home.nix ]; + }; + }) ]; }; }; diff --git a/nixos/home/danny/home.nix b/nixos/home/danny/home.nix index 5a195ae..d6f26d1 100644 --- a/nixos/home/danny/home.nix +++ b/nixos/home/danny/home.nix @@ -1,7 +1,8 @@ { pkgs, ... }: { - home.username = "danny"; - home.homeDirectory = "/Users/danny"; + # TODO: remove next two lines from here or from flake.nix + # home.username = "danny"; + # home.homeDirectory = "/Users/danny"; programs.home-manager.enable = true; @@ -121,11 +122,9 @@ ]; }; - # Put user-installed binaries here if you want HM to own them (optional) - home.packages = with pkgs; [ - neovim - tmux - ]; + # TODO: Put user-installed binaries here if you want HM to own them (optional) + # home.packages = with pkgs; [ + # ]; # First HM version for this user config; bump only if you understand the migration notes. home.stateVersion = "24.11";