From dad9e7d14e5afe57ec820c528aedf16a106339d7 Mon Sep 17 00:00:00 2001 From: Daniel Date: Sun, 3 May 2026 16:39:21 +1000 Subject: [PATCH 1/6] Remove dependency update command from workflow Removed the command to update dependencies in the RDE template. --- .github/workflows/update.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/update.yml b/.github/workflows/update.yml index a42ac30..96cb868 100644 --- a/.github/workflows/update.yml +++ b/.github/workflows/update.yml @@ -22,7 +22,6 @@ jobs: name: rde authToken: '${{ secrets.CACHIX_AUTH_TOKEN }}' extraPullNames: rstats-on-nix, nix-community - - run: cd templates/rde/ && nix develop -c p-updateDeps - name: Update ed flake.lock uses: DeterminateSystems/update-flake-lock@v28 with: From c1c92ec37c2d7183be4a0ba575e3d26d74400273 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" Date: Sun, 3 May 2026 06:40:30 +0000 Subject: [PATCH 2/6] flake.lock: Update MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Flake lock file updates: • Updated input 'nixpkgs': 'github:NixOS/nixpkgs/0726a0ecb6d4e08f6adced58726b95db924cef57?narHash=sha256-EHq1/OX139R1RvBzOJ0aMRT3xnWyqtHBRUBuO1gFzjI%3D' (2026-04-22) → 'github:NixOS/nixpkgs/15f4ee454b1dce334612fa6843b3e05cf546efab?narHash=sha256-Ad49moKWeXtKBJNy2ebiTQUEgdLyvGmTeykAQ9xM%2BZ4%3D' (2026-04-30) • Updated input 'nvimConfig': 'github:dwinkler1/nvimConfig/2617face3b1be40534d2cae7f0a374a062b3710d?narHash=sha256-pU3u7T4MqpjUWxflNvd4i47FURp756L7nMRL8MV%2BQEw%3D' (2026-04-17) → 'github:dwinkler1/nvimConfig/e9c99811d4b8684814608c7bff89dd5bb4d20cda?narHash=sha256-PY%2BhOXV5%2BW0rpWtnUI9QO3tFyyzlpDG8rVjPbaBoHxo%3D' (2026-05-03) --- templates/ed/flake.lock | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/templates/ed/flake.lock b/templates/ed/flake.lock index 8da8614..3457e77 100644 --- a/templates/ed/flake.lock +++ b/templates/ed/flake.lock @@ -22,11 +22,11 @@ }, "nixpkgs": { "locked": { - "lastModified": 1776877367, - "narHash": "sha256-EHq1/OX139R1RvBzOJ0aMRT3xnWyqtHBRUBuO1gFzjI=", + "lastModified": 1777578337, + "narHash": "sha256-Ad49moKWeXtKBJNy2ebiTQUEgdLyvGmTeykAQ9xM+Z4=", "owner": "NixOS", "repo": "nixpkgs", - "rev": "0726a0ecb6d4e08f6adced58726b95db924cef57", + "rev": "15f4ee454b1dce334612fa6843b3e05cf546efab", "type": "github" }, "original": { @@ -54,11 +54,11 @@ "wrappers": "wrappers" }, "locked": { - "lastModified": 1776413627, - "narHash": "sha256-pU3u7T4MqpjUWxflNvd4i47FURp756L7nMRL8MV+QEw=", + "lastModified": 1777790156, + "narHash": "sha256-PY+hOXV5+W0rpWtnUI9QO3tFyyzlpDG8rVjPbaBoHxo=", "owner": "dwinkler1", "repo": "nvimConfig", - "rev": "2617face3b1be40534d2cae7f0a374a062b3710d", + "rev": "e9c99811d4b8684814608c7bff89dd5bb4d20cda", "type": "github" }, "original": { From 24175e36c3540693f918ee629ac79fbb609342cc Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" Date: Thu, 7 May 2026 08:40:44 +0000 Subject: [PATCH 3/6] flake.lock: Update MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Flake lock file updates: • Updated input 'nixpkgs': 'github:NixOS/nixpkgs/15f4ee454b1dce334612fa6843b3e05cf546efab?narHash=sha256-Ad49moKWeXtKBJNy2ebiTQUEgdLyvGmTeykAQ9xM%2BZ4%3D' (2026-04-30) → 'github:NixOS/nixpkgs/549bd84d6279f9852cae6225e372cc67fb91a4c1?narHash=sha256-hGdgeU2Nk87RAuZyYjyDjFL6LK7dAZN5RE9%2BhrDTkDU%3D' (2026-05-05) • Updated input 'nvimConfig': 'github:dwinkler1/nvimConfig/e9c99811d4b8684814608c7bff89dd5bb4d20cda?narHash=sha256-PY%2BhOXV5%2BW0rpWtnUI9QO3tFyyzlpDG8rVjPbaBoHxo%3D' (2026-05-03) → 'github:dwinkler1/nvimConfig/4884bf685f157da4f4d60f8e40febeac0b9bf0e9?narHash=sha256-FB8M8D8YzfSe/oL4l6XGJxErq6nRjWSAeJzNXpk2g0E%3D' (2026-05-07) • Updated input 'nvimConfig/wrappers': 'github:BirdeeHub/nix-wrapper-modules/f11469ca69068bac13d9e163b2bd268cc06dff57?narHash=sha256-/SSAR77Brr9fbapsh1cb2K47JXCbvwS1GjM4yyDxle8%3D' (2026-04-16) → 'github:BirdeeHub/nix-wrapper-modules/dc5184095ad488e937ec308b52c9c0b218959d8b?narHash=sha256-0DS24OW9d9iz%2Bw0LCz6KpS2IpE2z2gHxeBdMZg9xpDY%3D' (2026-05-05) • Updated input 'rixpkgs': 'github:dwinkler1/rixpkgs/af2dd3f7b4b172077747c0869d4e30702fb71b0e?narHash=sha256-tgveHozOJ2D/mi3LxVy/FcmLFDlM5XKZxsNB2XpvzaM%3D' (2026-02-17) → 'github:dwinkler1/rixpkgs/028af91e9161008fce750f3e249afe471a302037?narHash=sha256-K%2BRz%2BpghAmynE83%2Be9svnNYsDgPnbEohrcPb6duG5wM%3D' (2026-05-07) --- templates/ed/flake.lock | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/templates/ed/flake.lock b/templates/ed/flake.lock index 3457e77..572e58d 100644 --- a/templates/ed/flake.lock +++ b/templates/ed/flake.lock @@ -22,11 +22,11 @@ }, "nixpkgs": { "locked": { - "lastModified": 1777578337, - "narHash": "sha256-Ad49moKWeXtKBJNy2ebiTQUEgdLyvGmTeykAQ9xM+Z4=", + "lastModified": 1777954456, + "narHash": "sha256-hGdgeU2Nk87RAuZyYjyDjFL6LK7dAZN5RE9+hrDTkDU=", "owner": "NixOS", "repo": "nixpkgs", - "rev": "15f4ee454b1dce334612fa6843b3e05cf546efab", + "rev": "549bd84d6279f9852cae6225e372cc67fb91a4c1", "type": "github" }, "original": { @@ -54,11 +54,11 @@ "wrappers": "wrappers" }, "locked": { - "lastModified": 1777790156, - "narHash": "sha256-PY+hOXV5+W0rpWtnUI9QO3tFyyzlpDG8rVjPbaBoHxo=", + "lastModified": 1778114917, + "narHash": "sha256-FB8M8D8YzfSe/oL4l6XGJxErq6nRjWSAeJzNXpk2g0E=", "owner": "dwinkler1", "repo": "nvimConfig", - "rev": "e9c99811d4b8684814608c7bff89dd5bb4d20cda", + "rev": "4884bf685f157da4f4d60f8e40febeac0b9bf0e9", "type": "github" }, "original": { @@ -102,11 +102,11 @@ }, "rixpkgs": { "locked": { - "lastModified": 1771303851, - "narHash": "sha256-tgveHozOJ2D/mi3LxVy/FcmLFDlM5XKZxsNB2XpvzaM=", + "lastModified": 1778115084, + "narHash": "sha256-K+Rz+pghAmynE83+e9svnNYsDgPnbEohrcPb6duG5wM=", "owner": "dwinkler1", "repo": "rixpkgs", - "rev": "af2dd3f7b4b172077747c0869d4e30702fb71b0e", + "rev": "028af91e9161008fce750f3e249afe471a302037", "type": "github" }, "original": { @@ -133,11 +133,11 @@ ] }, "locked": { - "lastModified": 1776375800, - "narHash": "sha256-/SSAR77Brr9fbapsh1cb2K47JXCbvwS1GjM4yyDxle8=", + "lastModified": 1777991014, + "narHash": "sha256-0DS24OW9d9iz+w0LCz6KpS2IpE2z2gHxeBdMZg9xpDY=", "owner": "BirdeeHub", "repo": "nix-wrapper-modules", - "rev": "f11469ca69068bac13d9e163b2bd268cc06dff57", + "rev": "dc5184095ad488e937ec308b52c9c0b218959d8b", "type": "github" }, "original": { From 5c851aecbaf44287d7d9f7de9510d85be439920b Mon Sep 17 00:00:00 2001 From: Daniel Winkler Date: Thu, 21 May 2026 20:38:02 +1000 Subject: [PATCH 4/6] temp --- templates/ed/flake.nix | 26 ++++++++++++-------------- 1 file changed, 12 insertions(+), 14 deletions(-) diff --git a/templates/ed/flake.nix b/templates/ed/flake.nix index 08a618d..7ac16f6 100644 --- a/templates/ed/flake.nix +++ b/templates/ed/flake.nix @@ -17,7 +17,7 @@ nix = true; optional = false; python = false; - r = false; + r = true; }; settings = let @@ -69,7 +69,6 @@ env = { IS_PROJECT_EDITOR = "1"; - R_LIBS_USER = "./.nvimcom"; }; extraPackages = with pkgs; [ @@ -93,14 +92,18 @@ forAllSystems = nixpkgs.lib.genAttrs systems; overlays = [inputs.nvimConfig.overlays.dependencies]; in { + formatter = forAllSystems (system: nixpkgs.legacyPackages.${system}.nixfmt-rfc-style); + packages = forAllSystems (system: let pkgs = import nixpkgs {inherit system overlays;}; - baseNvim = nvimConfig.packages.${system}.default; - - nvim = (baseNvim.eval (projectSettings {inherit pkgs;})).config.wrapper; - default = nvim; + evalResult = nvimConfig.inputs.wrappers.lib.evalModules { + modules = [ + nvimConfig.wrapperModules.default + projectSettings + ]; + }; in { - default = nvim; + default = evalResult.config.wrap { inherit pkgs; }; }); devShells = forAllSystems (system: let @@ -108,14 +111,14 @@ nv = self.packages.${system}.default; in { default = pkgs.mkShell { - packages = [nv pkgs.updateR]; + packages = [nv]; }; }); }; inputs = { nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; - rixpkgs.url = "github:dwinkler1/rixpkgs/nixpkgs"; + rixpkgs.url = "github:dwinkler1/rixpkgs/af2dd3f7b4b172077747c0869d4e30702fb71b0e"; fran = { url = "github:dwinkler1/fran"; inputs = { @@ -128,12 +131,7 @@ rixpkgs.follows = "rixpkgs"; nixpkgs.follows = "nixpkgs"; fran.follows = "fran"; - "plugins-r".follows = "plugins-r"; }; }; - "plugins-r" = { - url = "github:R-nvim/R.nvim/v0.99.3"; - flake = false; - }; }; } From e814d2c04c36a5542c11caadbcae5148aaf05594 Mon Sep 17 00:00:00 2001 From: Daniel Winkler Date: Thu, 21 May 2026 21:43:04 +1000 Subject: [PATCH 5/6] simplified --- templates/ed/README.md | 73 +++++++++++++ templates/ed/flake.lock | 65 ++++++++---- templates/ed/flake.nix | 223 +++++++++++++++++++++++++--------------- 3 files changed, 256 insertions(+), 105 deletions(-) create mode 100644 templates/ed/README.md diff --git a/templates/ed/README.md b/templates/ed/README.md new file mode 100644 index 0000000..272d827 --- /dev/null +++ b/templates/ed/README.md @@ -0,0 +1,73 @@ +# Project Editor + +A per-project Neovim wrapper built with [nix-wrapper-modules](https://birdeehub.github.io/nix-wrapper-modules/) and [nvimConfig](https://github.com/dwinkler1/nvimConfig). + +## Setup + +The flake provides two entry points: + +| Command | What you get | +|---|---| +| `direnv allow` / `nix develop` | **(Recommended)** A shell with `nv` and all enabled language toolchains (R, Python, Julia, Quarto) on `PATH`. | +| `nix run` | Launches only the `nv` editor. Language toolchains (R, Python, etc.) are **not** on `PATH`. | + +### With direnv (recommended) + +```bash +direnv allow # enter the devShell automatically +nv # launch the pre-configured Neovim +R # R REPL is available (if enabled in flake.nix) +``` + +### Without direnv + +```bash +nix develop # enter the devShell manually +nv # launch Neovim +R # R REPL is available (if enabled in flake.nix) +``` + +> **Why `nix run` only gives the editor:** The flake's `packages.default` is the wrapped Neovim binary. Language toolchains (R, radian, quarto, etc.) live in `devShells.default`. Use `nix develop` (or `direnv allow`) to get the full environment. + +## Configuration + +The `flake.nix` is the single source of truth. Key knobs: + +| Option | What it controls | +|---|---| +| `cats` | Toggle language support (nix, r, python, julia, etc.) | +| `settings.lang_packages.` | Language-specific packages installed in the wrapper | +| `settings.colorscheme` | Neovim colorscheme | +| `settings.background` | `"dark"` or `"light"` | +| `settings.wrapRc` | When `true`, init.lua is embedded (rebuild to change); when `false`, init.lua is external (reload without rebuild) | +| `binName` | The wrapper binary name (`nv` by default) | +| `env` | Environment variables set in the wrapper | +| `extraPackages` | Extra system packages available in the wrapper's PATH | +| `specs.extraLua` | Inject lazy.nvim plugin specs | + +### Adding packages without editing flake.nix + +Create any of these optional files in the project root to add dependencies without modifying `flake.nix`: + +- **`python-packages.nix`** — receives `python3Packages`, return a list of packages: + ```nix + p: with p; [ numpy scipy ] + ``` + +- **`r-packages.nix`** — receives `rpkgs` (includes `rPackages`), return a list: + ```nix + p: with p.rPackages; [ ggplot2 data.table ] + ``` + +- **`julia-packages.nix`** — no arguments, return a list of package name strings: + ```nix + [ "DataFrames" "Plots" ] + ``` + +## Formatting + +```bash +nix fmt +``` + +Uses `nixfmt-rfc-style` pinned via the flake's `formatter` output. diff --git a/templates/ed/flake.lock b/templates/ed/flake.lock index 572e58d..19c77b2 100644 --- a/templates/ed/flake.lock +++ b/templates/ed/flake.lock @@ -22,11 +22,11 @@ }, "nixpkgs": { "locked": { - "lastModified": 1777954456, - "narHash": "sha256-hGdgeU2Nk87RAuZyYjyDjFL6LK7dAZN5RE9+hrDTkDU=", + "lastModified": 1778869304, + "narHash": "sha256-30sZNZoA1cqF5JNO9fVX+wgiQYjB7HJqqJ4ztCDeBZE=", "owner": "NixOS", "repo": "nixpkgs", - "rev": "549bd84d6279f9852cae6225e372cc67fb91a4c1", + "rev": "d233902339c02a9c334e7e593de68855ad26c4cb", "type": "github" }, "original": { @@ -45,20 +45,19 @@ "nixpkgs" ], "plugins-cmp-pandoc-references": "plugins-cmp-pandoc-references", - "plugins-r": [ - "plugins-r" - ], + "plugins-r": "plugins-r", + "r-nvim-nix": "r-nvim-nix", "rixpkgs": [ "rixpkgs" ], "wrappers": "wrappers" }, "locked": { - "lastModified": 1778114917, - "narHash": "sha256-FB8M8D8YzfSe/oL4l6XGJxErq6nRjWSAeJzNXpk2g0E=", + "lastModified": 1779362150, + "narHash": "sha256-y3JTpxmNgtEYG1m21Ymvdmrul/WvJzOCX45AlV21aak=", "owner": "dwinkler1", "repo": "nvimConfig", - "rev": "4884bf685f157da4f4d60f8e40febeac0b9bf0e9", + "rev": "af6d975129768cce36ac4c46198ab2b3ebaafad3", "type": "github" }, "original": { @@ -86,33 +85,58 @@ "plugins-r": { "flake": false, "locked": { - "lastModified": 1769881528, - "narHash": "sha256-oQSHHu6filJkAyH94yEvyTVuxA+5MU2dMOEAnsIjJKQ=", + "lastModified": 1776905071, + "narHash": "sha256-dXox6qEs1VDE7vPNDoN8bY4g06uj1IEs6uki72w8lpA=", "owner": "R-nvim", "repo": "R.nvim", - "rev": "958b472d763cb258927c7ef69af4fd9945cc5469", + "rev": "582f2af11290ac067e49018db38e12a511325556", "type": "github" }, "original": { "owner": "R-nvim", - "ref": "v0.99.3", + "ref": "v0.99.4", "repo": "R.nvim", "type": "github" } }, + "r-nvim-nix": { + "inputs": { + "nixpkgs": [ + "nvimConfig", + "rixpkgs" + ], + "rnvimsrc": [ + "nvimConfig", + "plugins-r" + ] + }, + "locked": { + "lastModified": 1778684156, + "narHash": "sha256-Z4y1tQfkIsPK4NRxGn668HMDfWxnxNxSJ0CAOOXiIfY=", + "owner": "dwinkler1", + "repo": "r_nvim_nix", + "rev": "2f49dfee27886068e2f49cbd54558ce4cc424c82", + "type": "github" + }, + "original": { + "owner": "dwinkler1", + "repo": "r_nvim_nix", + "type": "github" + } + }, "rixpkgs": { "locked": { - "lastModified": 1778115084, - "narHash": "sha256-K+Rz+pghAmynE83+e9svnNYsDgPnbEohrcPb6duG5wM=", + "lastModified": 1771303851, + "narHash": "sha256-tgveHozOJ2D/mi3LxVy/FcmLFDlM5XKZxsNB2XpvzaM=", "owner": "dwinkler1", "repo": "rixpkgs", - "rev": "028af91e9161008fce750f3e249afe471a302037", + "rev": "af2dd3f7b4b172077747c0869d4e30702fb71b0e", "type": "github" }, "original": { "owner": "dwinkler1", - "ref": "nixpkgs", "repo": "rixpkgs", + "rev": "af2dd3f7b4b172077747c0869d4e30702fb71b0e", "type": "github" } }, @@ -121,7 +145,6 @@ "fran": "fran", "nixpkgs": "nixpkgs", "nvimConfig": "nvimConfig", - "plugins-r": "plugins-r", "rixpkgs": "rixpkgs" } }, @@ -133,11 +156,11 @@ ] }, "locked": { - "lastModified": 1777991014, - "narHash": "sha256-0DS24OW9d9iz+w0LCz6KpS2IpE2z2gHxeBdMZg9xpDY=", + "lastModified": 1779297405, + "narHash": "sha256-VFoBwH7ZjVxCnvZTb5ODRXt70sLtWMxstive0N+RS50=", "owner": "BirdeeHub", "repo": "nix-wrapper-modules", - "rev": "dc5184095ad488e937ec308b52c9c0b218959d8b", + "rev": "e7ed7a1205945befdf2e0d73ba7df91d935e5af1", "type": "github" }, "original": { diff --git a/templates/ed/flake.nix b/templates/ed/flake.nix index 7ac16f6..bc5f7d3 100644 --- a/templates/ed/flake.nix +++ b/templates/ed/flake.nix @@ -7,95 +7,107 @@ nvimConfig, ... } @ inputs: let - projectSettings = {pkgs}: { - cats = { - clickhouse = false; - gitPlugins = false; - julia = false; - lua = false; - markdown = false; - nix = true; - optional = false; - python = false; - r = true; - }; - - settings = let - # With `replace` packages are replaced otherwise they are merged with base packages - replace = pkgs.lib.mkForce; - in { - lang_packages = { - python = replace ( - (with pkgs.python3Packages; [ - duckdb - polars - ]) - ++ ( - if builtins.pathExists ./python-packages.nix - # p: with p; [ ... ] - then import ./python-packages.nix pkgs.python3Packages - else [] - ) - ); - - r = replace ( - (with pkgs.rpkgs.rPackages; [ - fixest - # pkgs.extraRPackages.musicMetadata - ]) - ++ ( - if builtins.pathExists ./r-packages.nix - # p: with p.rPackages; [ ... ] - then import ./r-packages.nix pkgs.rpkgs - else [] - ) - ); - - julia = replace ([ - "StatsBase" - ] - ++ ( - if builtins.pathExists ./julia-packages.nix - # [ ... ] - then import ./julia-packages.nix - else [] - )); - }; - colorscheme = "kanagawa"; - background = "dark"; - wrapRc = true; - }; - binName = "vv"; - - env = { - IS_PROJECT_EDITOR = "1"; - }; - - extraPackages = with pkgs; [ - cowsay - ]; - - specs.extraLua = let - name = builtins.baseNameOf (builtins.toString ./.); - in { - data = pkgs.vimPlugins.mini-notify; - before = ["INIT_MAIN"]; - config = '' - require("mini.notify").setup() - vim.notify = MiniNotify.make_notify() - vim.notify("Welcome to ${name}!") - ''; - }; + # ── Shared language support flags ────────────────────────────── + # Used by both the neovim wrapper module and the devShell + cats = { + clickhouse = false; + gitPlugins = false; + julia = false; + lua = false; + markdown = false; + nix = true; + optional = false; + python = false; + r = false; }; - systems = nixpkgs.lib.systems.flakeExposed; + # ── Language package lists ──────────────────────────────────── + # Shared between wrapper lang_packages and devShell toolchains. + # Accept pkgs so they work inside forAllSystems for each system. + + rPackages = pkgs: + (with pkgs.rpkgs.rPackages; [ + fixest + # pkgs.extraRPackages.musicMetadata + ]) + ++ ( + if builtins.pathExists ./r-packages.nix + # p: with p.rPackages; [ ... ] + then import ./r-packages.nix pkgs.rpkgs + else [] + ); + + pythonPackages = pkgs: + (with pkgs.python3Packages; [ + duckdb + polars + ]) + ++ ( + if builtins.pathExists ./python-packages.nix + # p: with p; [ ... ] + then import ./python-packages.nix pkgs.python3Packages + else [] + ); + + juliaPackages = + ["StatsBase"] + ++ ( + if builtins.pathExists ./julia-packages.nix + # [ ... ] + then import ./julia-packages.nix + else [] + ); + + systems = ["aarch64-darwin" "x86_64-linux" "aarch64-linux"]; forAllSystems = nixpkgs.lib.genAttrs systems; overlays = [inputs.nvimConfig.overlays.dependencies]; in { formatter = forAllSystems (system: nixpkgs.legacyPackages.${system}.nixfmt-rfc-style); packages = forAllSystems (system: let - pkgs = import nixpkgs {inherit system overlays;}; + pkgs = import nixpkgs { + inherit system overlays; + config = {allowUnfree = true;}; + }; + # Plain attrset — pkgs is captured from the surrounding scope, + # so the module system does not need lazy _module.args resolution. + projectSettings = { + inherit cats; + settings = let + # With `replace` packages are replaced otherwise they are merged with base packages + replace = pkgs.lib.mkForce; + in { + lang_packages = { + python = replace (pythonPackages pkgs); + r = replace (rPackages pkgs); + julia = replace juliaPackages; + }; + colorscheme = "kanagawa"; + background = "dark"; + wrapRc = true; + }; + binName = "nv"; + + env = { + IS_PROJECT_EDITOR = "1"; + }; + + runtimePkgs = with pkgs; [ + cowsay + ]; + + specs.extraLua = let + name = builtins.baseNameOf (builtins.toString ./.); + in { + data = pkgs.vimPlugins.mini-notify; + before = ["INIT_MAIN"]; + config = '' + require("mini.notify").setup() + vim.notify = MiniNotify.make_notify() + vim.notify("Welcome to ${name}!") + ''; + }; + }; evalResult = nvimConfig.inputs.wrappers.lib.evalModules { modules = [ nvimConfig.wrapperModules.default @@ -103,15 +115,58 @@ ]; }; in { - default = evalResult.config.wrap { inherit pkgs; }; + default = evalResult.config.wrap {inherit pkgs;}; }); devShells = forAllSystems (system: let - pkgs = import nixpkgs {inherit system overlays;}; + pkgs = import nixpkgs { + inherit system overlays; + config = {allowUnfree = true;}; + }; nv = self.packages.${system}.default; in { default = pkgs.mkShell { - packages = [nv]; + packages = + [nv] + + # ── R toolchain (R REPL, quarto, LSP, formatter) ───── + ++ pkgs.lib.optionals cats.r (let + r_packages = (pkgs.baseRPackages or []) ++ rPackages pkgs; + in [ + (pkgs.rWrapper.override {packages = r_packages;}) + pkgs.radianWrapper + pkgs.air-formatter + pkgs.yaml-language-server + pkgs.nvimcom + pkgs.rnvimserver + ]) + + # ── Python toolchain (interpreter, LSP, formatter) ──── + ++ pkgs.lib.optionals cats.python [ + (pkgs.python3.withPackages (ps: pkgs.basePythonPackages ps ++ pythonPackages pkgs)) + pkgs.nodejs + pkgs.ruff + pkgs.basedpyright + pkgs.uv + ] + + # ── Julia toolchain ─────────────────────────────────── + ++ pkgs.lib.optionals cats.julia [ + pkgs.julia-bin.withPackages juliaPackages + ] + + # ── Markdown toolchain (quarto, zk) ─────────────────── + ++ (let + r_packages = (pkgs.baseRPackages or []) ++ rPackages pkgs; + quarto = + if cats.r + then pkgs.quarto.override {extraRPackages = r_packages;} + else pkgs.quarto; + in pkgs.lib.optionals cats.markdown [ + pkgs.python313Packages.pylatexenc + quarto + pkgs.zk + ]); }; }); }; From 5d8c198afaffc99a119cfc69256f6bdb99632959 Mon Sep 17 00:00:00 2001 From: Daniel Winkler Date: Sat, 23 May 2026 02:27:20 +1000 Subject: [PATCH 6/6] More robust shell setup with nu --- templates/ed/flake.nix | 33 ++++++++++++++++++++++----------- 1 file changed, 22 insertions(+), 11 deletions(-) diff --git a/templates/ed/flake.nix b/templates/ed/flake.nix index bc5f7d3..b674c62 100644 --- a/templates/ed/flake.nix +++ b/templates/ed/flake.nix @@ -126,9 +126,21 @@ nv = self.packages.${system}.default; in { default = pkgs.mkShell { + shellHook = '' + exec nu + alias gst='git status' + alias glol='git log --oneline --graph --decorate' + alias gc='git commit' + alias gl='git pull' + alias gp='git push' + ''; packages = - [nv] - + [ + nv + pkgs.git + pkgs.pre-commit + pkgs.nushell + ] # ── R toolchain (R REPL, quarto, LSP, formatter) ───── ++ pkgs.lib.optionals cats.r (let r_packages = (pkgs.baseRPackages or []) ++ rPackages pkgs; @@ -140,7 +152,6 @@ pkgs.nvimcom pkgs.rnvimserver ]) - # ── Python toolchain (interpreter, LSP, formatter) ──── ++ pkgs.lib.optionals cats.python [ (pkgs.python3.withPackages (ps: pkgs.basePythonPackages ps ++ pythonPackages pkgs)) @@ -149,12 +160,11 @@ pkgs.basedpyright pkgs.uv ] - # ── Julia toolchain ─────────────────────────────────── ++ pkgs.lib.optionals cats.julia [ - pkgs.julia-bin.withPackages juliaPackages + pkgs.julia-bin.withPackages + juliaPackages ] - # ── Markdown toolchain (quarto, zk) ─────────────────── ++ (let r_packages = (pkgs.baseRPackages or []) ++ rPackages pkgs; @@ -162,11 +172,12 @@ if cats.r then pkgs.quarto.override {extraRPackages = r_packages;} else pkgs.quarto; - in pkgs.lib.optionals cats.markdown [ - pkgs.python313Packages.pylatexenc - quarto - pkgs.zk - ]); + in + pkgs.lib.optionals cats.markdown [ + pkgs.python313Packages.pylatexenc + quarto + pkgs.zk + ]); }; }); };