From a0a57757a07941c5523e646f0a97176492704bd4 Mon Sep 17 00:00:00 2001 From: NotAShelf Date: Thu, 12 Dec 2024 20:16:27 +0300 Subject: [PATCH 01/39] wrapper/rc: explicitly add `tabstop` & `shiftwidth` to `vim.options` Defaults are taken from Neovim's :help tags for those options to avoid intrusive/confusing behaviour. --- modules/wrapper/rc/options.nix | 48 ++++++++++++++++++++++------------ 1 file changed, 32 insertions(+), 16 deletions(-) diff --git a/modules/wrapper/rc/options.nix b/modules/wrapper/rc/options.nix index ab541419..df3831ec 100644 --- a/modules/wrapper/rc/options.nix +++ b/modules/wrapper/rc/options.nix @@ -126,16 +126,14 @@ in { example = {"some_variable" = 42;}; description = '' - An attribute set containing global variable values - for storing vim variables as early as possible. If - populated, this option will set vim variables in the - built luaConfigRC as the first item. + A freeform attribute set containing global variable values for setting vim + variables as early as possible. If populated, this option will set vim variables + in the built {option}`luaConfigRC` as the first item. ::: {.note} - `{foo = "bar";}` will set `vim.g.foo` to "bar", where - the type of `bar` in the resulting Lua value will be - inferred from the type of the value in the `{name = value;}` - pair passed to the option. + `{foo = "bar";}` will set `vim.g.foo` to "bar", where the type of `bar` in the + resulting Lua value will be inferred from the type of the value in the + `{name = value;}` pair passed to the option. ::: ''; }; @@ -212,21 +210,39 @@ in { default = true; description = "Enable word wrapping."; }; + + tabstop = mkOption { + type = int; + default = 8; # Neovim default + description = '' + Number of spaces that a `` in the file counts for. Also see + the {command}`:retab` command, and the {option}`softtabstop` option. + ''; + }; + + shiftwidth = mkOption { + type = int; + default = 8; # Neovim default + description = '' + Number of spaces to use for each step of (auto)indent. Used for + {option}`cindent`, `>>`, `<<`, etc. + + When zero the {option}`tabstop` value will be used. + ''; + }; }; }; example = {visualbell = true;}; description = '' - An attribute set containing vim options to be set - as early as possible. If populated, this option will - set vim options in the built luaConfigRC after `basic` - and before `pluginConfigs` DAG entries. + A freeform attribute set containing vim options to be set as early as possible. + If populated, this option will set vim options in the built {option}`luaConfigRC` + after `basic` and before `pluginConfigs` DAG entries. ::: {.note} - `{foo = "bar";}` will set `vim.o.foo` to "bar", where - the type of `bar` in the resulting Lua value will be - inferred from the type of the value in the`{name = value;}` - pair passed to the option. + `{foo = "bar";}` will set `vim.o.foo` to "bar", where the type of `bar` in the + resulting Lua value will be inferred from the type of the value in the + `{name = value;}` pair passed to the option. ::: ''; }; From 4f616283992803ba5b3d2dc833b03f947c1573c6 Mon Sep 17 00:00:00 2001 From: NotAShelf Date: Mon, 16 Dec 2024 01:16:56 +0300 Subject: [PATCH 02/39] preview/markdown-preview: convert `mkdp_filetypes` to correct format --- modules/plugins/utility/preview/markdown-preview/config.nix | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/modules/plugins/utility/preview/markdown-preview/config.nix b/modules/plugins/utility/preview/markdown-preview/config.nix index 8349d3fc..50fec81a 100644 --- a/modules/plugins/utility/preview/markdown-preview/config.nix +++ b/modules/plugins/utility/preview/markdown-preview/config.nix @@ -4,8 +4,8 @@ lib, ... }: let - inherit (lib.strings) concatMapStringsSep; inherit (lib.modules) mkIf; + cfg = config.vim.utility.preview.markdownPreview; in { config = mkIf cfg.enable { @@ -15,7 +15,7 @@ in { mkdp_auto_start = cfg.autoStart; mkdp_auto_close = cfg.autoClose; mkdp_refresh_slow = cfg.lazyRefresh; - mkdp_filetypes = [(concatMapStringsSep ", " (x: "'" + x + "'") cfg.filetypes)]; + mkdp_filetypes = cfg.filetypes; mkdp_command_for_global = cfg.alwaysAllowPreview; mkdp_open_to_the_world = cfg.broadcastServer; mkdp_open_ip = cfg.customIP; From e715463257abd42ec6726a10a5cb2177ebda0c00 Mon Sep 17 00:00:00 2001 From: Artur Manuel Date: Fri, 20 Dec 2024 03:50:38 +0000 Subject: [PATCH 03/39] plugins/languages: add haskell support (#499) * plugins/languages: add haskell support Closes #426 * fix docs --------- Co-authored-by: Artur Manuel Co-authored-by: raf --- configuration.nix | 1 + docs/release-notes/rl-0.8.md | 6 ++ flake.lock | 17 +++++ flake.nix | 5 ++ modules/plugins/languages/default.nix | 1 + modules/plugins/languages/haskell.nix | 104 ++++++++++++++++++++++++++ modules/plugins/languages/rust.nix | 4 +- 7 files changed, 136 insertions(+), 2 deletions(-) create mode 100644 modules/plugins/languages/haskell.nix diff --git a/configuration.nix b/configuration.nix index 3802f758..3be1d39b 100644 --- a/configuration.nix +++ b/configuration.nix @@ -79,6 +79,7 @@ isMaximal: { dart.enable = false; ocaml.enable = false; elixir.enable = false; + haskell.enable = false; tailwind.enable = false; svelte.enable = false; diff --git a/docs/release-notes/rl-0.8.md b/docs/release-notes/rl-0.8.md index 52a9ae64..36209ff7 100644 --- a/docs/release-notes/rl-0.8.md +++ b/docs/release-notes/rl-0.8.md @@ -8,3 +8,9 @@ `languages.typst.extensions.typst-preview-nvim`. - Add a search widget to the options page in the nvf manual. + +[amadaluzia](https://github.com/amadaluzia): + +[haskell-tools.nvim]: https://github.com/MrcJkb/haskell-tools.nvim + +- Add Haskell support under `vim.languages.haskell` using [haskell-tools.nvim] diff --git a/flake.lock b/flake.lock index d5532b4b..dc9cd81a 100644 --- a/flake.lock +++ b/flake.lock @@ -684,6 +684,22 @@ "type": "github" } }, + "plugin-haskell-tools-nvim": { + "flake": false, + "locked": { + "lastModified": 1734222260, + "narHash": "sha256-gZVN9ADPO5wFOaf19FydCneb7aKTT9K1vcLoBURPEjk=", + "owner": "mrcjkb", + "repo": "haskell-tools.nvim", + "rev": "943b77b68a79d3991523ba4d373063c9355c6f55", + "type": "github" + }, + "original": { + "owner": "mrcjkb", + "repo": "haskell-tools.nvim", + "type": "github" + } + }, "plugin-highlight-undo": { "flake": false, "locked": { @@ -2091,6 +2107,7 @@ "plugin-gitsigns-nvim": "plugin-gitsigns-nvim", "plugin-glow-nvim": "plugin-glow-nvim", "plugin-gruvbox": "plugin-gruvbox", + "plugin-haskell-tools-nvim": "plugin-haskell-tools-nvim", "plugin-highlight-undo": "plugin-highlight-undo", "plugin-hop-nvim": "plugin-hop-nvim", "plugin-icon-picker-nvim": "plugin-icon-picker-nvim", diff --git a/flake.nix b/flake.nix index 65c802f2..161ba43f 100644 --- a/flake.nix +++ b/flake.nix @@ -720,5 +720,10 @@ url = "github:otavioschwanck/new-file-template.nvim"; flake = false; }; + + plugin-haskell-tools-nvim = { + url = "github:mrcjkb/haskell-tools.nvim"; + flake = false; + }; }; } diff --git a/modules/plugins/languages/default.nix b/modules/plugins/languages/default.nix index a69d3e8d..48945b38 100644 --- a/modules/plugins/languages/default.nix +++ b/modules/plugins/languages/default.nix @@ -14,6 +14,7 @@ in { ./hcl.nix ./kotlin.nix ./html.nix + ./haskell.nix ./java.nix ./lua.nix ./markdown.nix diff --git a/modules/plugins/languages/haskell.nix b/modules/plugins/languages/haskell.nix new file mode 100644 index 00000000..f8e17b75 --- /dev/null +++ b/modules/plugins/languages/haskell.nix @@ -0,0 +1,104 @@ +{ + config, + lib, + pkgs, + ... +}: let + inherit (builtins) isList; + inherit (lib.types) either package listOf str; + inherit (lib.options) mkEnableOption mkOption; + inherit (lib.strings) optionalString; + inherit (lib.modules) mkIf mkMerge; + inherit (lib.nvim.types) mkGrammarOption; + inherit (lib.nvim.dag) entryAfter; + inherit (lib.nvim.lua) expToLua; + inherit (pkgs) haskellPackages; + + cfg = config.vim.languages.haskell; +in { + options.vim.languages.haskell = { + enable = mkEnableOption "Haskell support"; + + treesitter = { + enable = mkEnableOption "Treesitter support for Haskell" // {default = config.vim.languages.enableTreesitter;}; + package = mkGrammarOption pkgs "haskell"; + }; + + lsp = { + enable = mkEnableOption "LSP support for Haskell" // {default = config.vim.languages.enableLSP;}; + package = mkOption { + description = "Haskell LSP package or command to run the Haskell LSP"; + example = ''[ (lib.getExe pkgs.haskellPackages.haskell-language-server) "--debug" ]''; + default = haskellPackages.haskell-language-server; + type = either package (listOf str); + }; + }; + + dap = { + enable = mkEnableOption "DAP support for Haskell" // {default = config.vim.languages.enableDAP;}; + package = mkOption { + description = "Haskell DAP package or command to run the Haskell DAP"; + default = haskellPackages.haskell-debug-adapter; + type = either package (listOf str); + }; + }; + }; + + config = mkIf cfg.enable (mkMerge [ + (mkIf cfg.treesitter.enable { + vim.treesitter = { + enable = true; + grammars = [cfg.treesitter.package]; + }; + }) + + (mkIf (cfg.dap.enable || cfg.lsp.enable) { + vim = { + startPlugins = ["haskell-tools-nvim"]; + luaConfigRC.haskell-tools-nvim = + entryAfter + ["lsp-setup"] + '' + vim.g.haskell_tools = { + ${optionalString cfg.lsp.enable '' + -- LSP + tools = { + hover = { + enable = true, + }, + }, + hls = { + cmd = ${ + if isList cfg.lsp.package + then expToLua cfg.lsp.package + else ''{"${cfg.lsp.package}/bin/haskell-language-server-wrapper"}'' + }, + on_attach = function(client, bufnr, ht) + default_on_attach(client, bufnr, ht) + local opts = { noremap = true, silent = true, buffer = bufnr } + vim.keymap.set('n', 'cl', vim.lsp.codelens.run, opts) + vim.keymap.set('n', 'hs', ht.hoogle.hoogle_signature, opts) + vim.keymap.set('n', 'ea', ht.lsp.buf_eval_all, opts) + vim.keymap.set('n', 'rr', ht.repl.toggle, opts) + vim.keymap.set('n', 'rf', function() + ht.repl.toggle(vim.api.nvim_buf_get_name(0)) + end, opts) + vim.keymap.set('n', 'rq', ht.repl.quit, opts) + end, + }, + ''} + ${optionalString cfg.dap.enable '' + dap = { + cmd = ${ + if isList cfg.dap.package + then expToLua cfg.dap.package + else ''${cfg.dap.package}/bin/haskell-debug-adapter'' + }, + }, + ''} + } + ''; + }; + }) + ]); +} diff --git a/modules/plugins/languages/rust.nix b/modules/plugins/languages/rust.nix index ec1887cb..7e9cb627 100644 --- a/modules/plugins/languages/rust.nix +++ b/modules/plugins/languages/rust.nix @@ -13,7 +13,7 @@ inherit (lib.types) bool package str listOf either enum; inherit (lib.nvim.types) mkGrammarOption; inherit (lib.nvim.lua) expToLua; - inherit (lib.nvim.dag) entryAnywhere; + inherit (lib.nvim.dag) entryAfter entryAnywhere; cfg = config.vim.languages.rust; @@ -127,7 +127,7 @@ in { vim = { startPlugins = ["rustaceanvim"]; - luaConfigRC.rustaceanvim = entryAnywhere '' + pluginRC.rustaceanvim = entryAfter ["lsp-setup"] '' vim.g.rustaceanvim = { ${optionalString cfg.lsp.enable '' -- LSP From 99a4eafa34450fc94e43e3f0ed4df559a40f9b35 Mon Sep 17 00:00:00 2001 From: Yoni Firroloni Date: Fri, 20 Dec 2024 04:11:18 +0000 Subject: [PATCH 04/39] languages/typescript: prevent ts_ls from formatting (#495) * ts_ls: prevent from formatting prevent ts_ls from touching the formating. ts formatting: remove useless indent * fix unnecessary whitespace --------- Co-authored-by: raf --- modules/plugins/languages/ts.nix | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/modules/plugins/languages/ts.nix b/modules/plugins/languages/ts.nix index 8843cc46..2530d352 100644 --- a/modules/plugins/languages/ts.nix +++ b/modules/plugins/languages/ts.nix @@ -23,8 +23,11 @@ package = pkgs.typescript-language-server; lspConfig = '' lspconfig.ts_ls.setup { - capabilities = capabilities; - on_attach = attach_keymaps, + capabilities = capabilities, + on_attach = function(client, bufnr) + attach_keymaps(client, bufnr); + client.server_capabilities.documentFormattingProvider = false; + end, cmd = ${ if isList cfg.lsp.package then expToLua cfg.lsp.package @@ -79,6 +82,7 @@ ls_sources, null_ls.builtins.formatting.prettier.with({ command = "${cfg.format.package}/bin/prettier", + filetypes = { "typescript" }, }) ) ''; From ed69816f68414a91104f7abe9a77a9e1b5630467 Mon Sep 17 00:00:00 2001 From: diniamo Date: Fri, 20 Dec 2024 10:43:36 +0100 Subject: [PATCH 05/39] wrapper/lazy: add beforeSetup option Useful for avoiding a million require calls in setupOpts. --- modules/wrapper/lazy/config.nix | 1 + modules/wrapper/lazy/lazy.nix | 9 +++++++++ 2 files changed, 10 insertions(+) diff --git a/modules/wrapper/lazy/config.nix b/modules/wrapper/lazy/config.nix index 6a9a6ea2..3468d5ec 100644 --- a/modules/wrapper/lazy/config.nix +++ b/modules/wrapper/lazy/config.nix @@ -76,6 +76,7 @@ else mkLuaInline '' function() + ${optionalString (spec.beforeSetup != null) spec.beforeSetup} ${ optionalString (spec.setupModule != null) "require(${toJSON spec.setupModule}).setup(${toLuaObject spec.setupOpts})" diff --git a/modules/wrapper/lazy/lazy.nix b/modules/wrapper/lazy/lazy.nix index e0dbea85..730bf267 100644 --- a/modules/wrapper/lazy/lazy.nix +++ b/modules/wrapper/lazy/lazy.nix @@ -74,6 +74,15 @@ ''; }; + beforeSetup = mkOption { + type = nullOr lines; + default = null; + description = '' + Lua code to run after the plugin is loaded, but before the setup + function is called. + ''; + }; + setupModule = mkOption { type = nullOr str; default = null; From 5d898da816dbfe117167fce3179f7757cbccb696 Mon Sep 17 00:00:00 2001 From: diniamo Date: Fri, 20 Dec 2024 16:27:44 +0100 Subject: [PATCH 06/39] nvim-notify: fix some stuff --- .../ui/notifications/nvim-notify/config.nix | 14 +++----------- .../ui/notifications/nvim-notify/nvim-notify.nix | 4 ++-- 2 files changed, 5 insertions(+), 13 deletions(-) diff --git a/modules/plugins/ui/notifications/nvim-notify/config.nix b/modules/plugins/ui/notifications/nvim-notify/config.nix index 0ee23017..50972176 100644 --- a/modules/plugins/ui/notifications/nvim-notify/config.nix +++ b/modules/plugins/ui/notifications/nvim-notify/config.nix @@ -14,17 +14,9 @@ in { startPlugins = ["nvim-notify"]; pluginRC.nvim-notify = entryAnywhere '' - require('notify').setup(${toLuaObject cfg.setupOpts}) - - -- required to fix offset_encoding errors - local notify = vim.notify - vim.notify = function(msg, ...) - if msg:match("warning: multiple different client offset_encodings") then - return - end - - notify(msg, ...) - end + local notify = require("notify") + notify.setup(${toLuaObject cfg.setupOpts}) + vim.notify = notify ''; }; }; diff --git a/modules/plugins/ui/notifications/nvim-notify/nvim-notify.nix b/modules/plugins/ui/notifications/nvim-notify/nvim-notify.nix index f30d19cd..b09100da 100644 --- a/modules/plugins/ui/notifications/nvim-notify/nvim-notify.nix +++ b/modules/plugins/ui/notifications/nvim-notify/nvim-notify.nix @@ -28,7 +28,7 @@ in { }; stages = mkOption { - type = enum ["fade_in_slide_out" "fade_in" "slide_out" "none"]; + type = enum ["fade_in_slide_out" "fade" "slide" "static"]; default = "fade_in_slide_out"; description = "The stages of the notification"; }; @@ -41,7 +41,7 @@ in { background_colour = mkOption { type = str; - default = "#000000"; + default = "NotifyBackground"; description = "The background colour of the notification"; }; From 7eb8d07bcf91672a723c8ecf1df1e4e5df917f24 Mon Sep 17 00:00:00 2001 From: diniamo Date: Sat, 21 Dec 2024 01:14:52 +0100 Subject: [PATCH 07/39] surround: cleanup --- modules/plugins/utility/surround/config.nix | 48 +++++++-------------- 1 file changed, 15 insertions(+), 33 deletions(-) diff --git a/modules/plugins/utility/surround/config.nix b/modules/plugins/utility/surround/config.nix index 7161cf6b..31b4033d 100644 --- a/modules/plugins/utility/surround/config.nix +++ b/modules/plugins/utility/surround/config.nix @@ -4,51 +4,33 @@ ... }: let inherit (lib.modules) mkIf; - inherit (lib.nvim.dag) entryAnywhere; - inherit (lib.nvim.lua) toLuaObject; cfg = config.vim.utility.surround; mkLznKey = mode: key: { - inherit key mode; + inherit mode key; }; in { config = mkIf cfg.enable { vim = { - startPlugins = ["nvim-surround"]; - pluginRC.surround = entryAnywhere "require('nvim-surround').setup(${toLuaObject cfg.setupOpts})"; - lazy.plugins.nvim-surround = { package = "nvim-surround"; + setupModule = "nvim-surround"; inherit (cfg) setupOpts; - keys = - [ - (mkLznKey ["i"] cfg.setupOpts.keymaps.insert) - (mkLznKey ["i"] cfg.setupOpts.keymaps.insert_line) - (mkLznKey ["x"] cfg.setupOpts.keymaps.visual) - (mkLznKey ["x"] cfg.setupOpts.keymaps.visual_line) - (mkLznKey ["n"] cfg.setupOpts.keymaps.normal) - (mkLznKey ["n"] cfg.setupOpts.keymaps.normal_cur) - (mkLznKey ["n"] cfg.setupOpts.keymaps.normal_line) - (mkLznKey ["n"] cfg.setupOpts.keymaps.normal_cur_line) - (mkLznKey ["n"] cfg.setupOpts.keymaps.delete) - (mkLznKey ["n"] cfg.setupOpts.keymaps.change) - (mkLznKey ["n"] cfg.setupOpts.keymaps.change_line) - ] - ++ map (mkLznKey ["n" "i" "v"]) [ - "(nvim-surround-insert)" - "(nvim-surround-insert-line)" - "(nvim-surround-normal)" - "(nvim-surround-normal-cur)" - "(nvim-surround-normal-line)" - "(nvim-surround-normal-cur-line)" - "(nvim-surround-visual)" - "(nvim-surround-visual-line)" - "(nvim-surround-delete)" - "(nvim-surround-change)" - "(nvim-surround-change-line)" - ]; + keys = [ + (mkLznKey "i" cfg.setupOpts.keymaps.insert) + (mkLznKey "i" cfg.setupOpts.keymaps.insert_line) + (mkLznKey "x" cfg.setupOpts.keymaps.visual) + (mkLznKey "x" cfg.setupOpts.keymaps.visual_line) + (mkLznKey "n" cfg.setupOpts.keymaps.normal) + (mkLznKey "n" cfg.setupOpts.keymaps.normal_cur) + (mkLznKey "n" cfg.setupOpts.keymaps.normal_line) + (mkLznKey "n" cfg.setupOpts.keymaps.normal_cur_line) + (mkLznKey "n" cfg.setupOpts.keymaps.delete) + (mkLznKey "n" cfg.setupOpts.keymaps.change) + (mkLznKey "n" cfg.setupOpts.keymaps.change_line) + ]; }; }; }; From 0946d439210b19eee5fb57d8ec0ae563de5deb49 Mon Sep 17 00:00:00 2001 From: Artur Manuel Date: Sat, 21 Dec 2024 00:51:41 +0000 Subject: [PATCH 08/39] languages/haskell: fix DAP command definition --- modules/plugins/languages/haskell.nix | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/plugins/languages/haskell.nix b/modules/plugins/languages/haskell.nix index f8e17b75..62f4cd41 100644 --- a/modules/plugins/languages/haskell.nix +++ b/modules/plugins/languages/haskell.nix @@ -92,7 +92,7 @@ in { cmd = ${ if isList cfg.dap.package then expToLua cfg.dap.package - else ''${cfg.dap.package}/bin/haskell-debug-adapter'' + else ''{"${cfg.dap.package}/bin/haskell-debug-adapter"}'' }, }, ''} From 90a5a42742850dc95e8cab2c3de936718d9055cc Mon Sep 17 00:00:00 2001 From: diniamo Date: Sat, 21 Dec 2024 01:15:10 +0100 Subject: [PATCH 09/39] languages/odin: init --- docs/release-notes/rl-0.8.md | 6 ++- modules/plugins/languages/default.nix | 1 + modules/plugins/languages/odin.nix | 71 +++++++++++++++++++++++++++ modules/plugins/languages/zig.nix | 1 + 4 files changed, 78 insertions(+), 1 deletion(-) create mode 100644 modules/plugins/languages/odin.nix diff --git a/docs/release-notes/rl-0.8.md b/docs/release-notes/rl-0.8.md index 36209ff7..03d4d010 100644 --- a/docs/release-notes/rl-0.8.md +++ b/docs/release-notes/rl-0.8.md @@ -13,4 +13,8 @@ [haskell-tools.nvim]: https://github.com/MrcJkb/haskell-tools.nvim -- Add Haskell support under `vim.languages.haskell` using [haskell-tools.nvim] +- Add Haskell support under `vim.languages.haskell` using [haskell-tools.nvim]. + +[diniamo](https://github.com/diniamo): + +- Add Odin support under `vim.languages.odin`. diff --git a/modules/plugins/languages/default.nix b/modules/plugins/languages/default.nix index 48945b38..ee9f55e1 100644 --- a/modules/plugins/languages/default.nix +++ b/modules/plugins/languages/default.nix @@ -37,6 +37,7 @@ in { ./csharp.nix ./julia.nix ./nu.nix + ./odin.nix ]; options.vim.languages = { diff --git a/modules/plugins/languages/odin.nix b/modules/plugins/languages/odin.nix new file mode 100644 index 00000000..7a32db93 --- /dev/null +++ b/modules/plugins/languages/odin.nix @@ -0,0 +1,71 @@ +{ + config, + pkgs, + lib, + ... +}: let + inherit (builtins) attrNames; + inherit (lib.options) mkEnableOption mkOption; + inherit (lib.modules) mkIf mkMerge; + inherit (lib.lists) isList; + inherit (lib.types) either listOf package str enum; + inherit (lib.nvim.lua) expToLua; + inherit (lib.nvim.types) mkGrammarOption; + + defaultServer = "ols"; + servers = { + ols = { + package = pkgs.ols; + lspConfig = '' + lspconfig.ols.setup { + capabilities = capabilities, + on_attach = default_on_attach, + cmd = ${ + if isList cfg.lsp.package + then expToLua cfg.lsp.package + else "{'${cfg.lsp.package}/bin/ols'}" + } + } + ''; + }; + }; + + cfg = config.vim.languages.odin; +in { + options.vim.languages.odin = { + enable = mkEnableOption "Odin language support"; + + treesitter = { + enable = mkEnableOption "Odin treesitter" // {default = config.vim.languages.enableTreesitter;}; + package = mkGrammarOption pkgs "odin"; + }; + + lsp = { + enable = mkEnableOption "Odin LSP support" // {default = config.vim.languages.enableLSP;}; + + server = mkOption { + type = enum (attrNames servers); + default = defaultServer; + description = "Odin LSP server to use"; + }; + + package = mkOption { + description = "Ols package, or the command to run as a list of strings"; + type = either package (listOf str); + default = pkgs.ols; + }; + }; + }; + + config = mkIf cfg.enable (mkMerge [ + (mkIf cfg.treesitter.enable { + vim.treesitter.enable = true; + vim.treesitter.grammars = [cfg.treesitter.package]; + }) + + (mkIf cfg.lsp.enable { + vim.lsp.lspconfig.enable = true; + vim.lsp.lspconfig.sources.odin-lsp = servers.${cfg.lsp.server}.lspConfig; + }) + ]); +} diff --git a/modules/plugins/languages/zig.nix b/modules/plugins/languages/zig.nix index 7ae8a5c2..3618d6d8 100644 --- a/modules/plugins/languages/zig.nix +++ b/modules/plugins/languages/zig.nix @@ -57,6 +57,7 @@ in { }; }; }; + config = mkIf cfg.enable (mkMerge [ (mkIf cfg.treesitter.enable { vim.treesitter.enable = true; From 9aad80d5e6d61cc6f5c256eed1fb13dd6d0d8473 Mon Sep 17 00:00:00 2001 From: diniamo Date: Sat, 21 Dec 2024 20:38:31 +0100 Subject: [PATCH 10/39] flake: update run.nvim --- flake.lock | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/flake.lock b/flake.lock index dc9cd81a..97ff6754 100644 --- a/flake.lock +++ b/flake.lock @@ -1729,11 +1729,11 @@ "plugin-run-nvim": { "flake": false, "locked": { - "lastModified": 1732918526, - "narHash": "sha256-kiszNmZZDXG8tAPMQKuGJDCkqCMzsWT7BkCvkVsH2lA=", + "lastModified": 1734816675, + "narHash": "sha256-Wuk5HG+vHXAbifzp5YB5V/FxBhBRNWLeypkRczpXbvQ=", "owner": "diniamo", "repo": "run.nvim", - "rev": "d867466e01b8fa4e54a589b9ef446cf43fb966de", + "rev": "6cd971afdce6443d7a070dcc23af51da1cc932f9", "type": "github" }, "original": { From 3a2edd1b75928c805700d369895bc1486dacb650 Mon Sep 17 00:00:00 2001 From: DamitusThyYeetus123 <108782125+DamitusThyYeetus123@users.noreply.github.com> Date: Mon, 23 Dec 2024 19:56:19 +1100 Subject: [PATCH 11/39] filetree/nvim-tree: Open on directory (#462) * nvim-tree: Add directory opening * formatting * Fix formatting * format Co-authored-by: raf --------- Co-authored-by: Ching Pei Yang <59727193+horriblename@users.noreply.github.com> Co-authored-by: raf --- modules/plugins/filetree/nvimtree/config.nix | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/modules/plugins/filetree/nvimtree/config.nix b/modules/plugins/filetree/nvimtree/config.nix index e20a1458..11fa9fed 100644 --- a/modules/plugins/filetree/nvimtree/config.nix +++ b/modules/plugins/filetree/nvimtree/config.nix @@ -77,6 +77,9 @@ in { -- buffer is a real file on the disk local real_file = vim.fn.filereadable(data.file) == 1 + -- buffer is a directory + local directory = vim.fn.isdirectory(data.file) == 1 + -- buffer is a [No Name] local no_name = data.file == "" and vim.bo[data.buf].buftype == "" @@ -84,7 +87,7 @@ in { local filetype = vim.bo[data.buf].ft -- only files please - if not real_file and not no_name then + if not real_file and not directory and not no_name then return end @@ -93,6 +96,10 @@ in { return end + -- cd if buffer is a directory + if directory then + vim.cmd.cd(data.file) + end -- open the tree but don't focus it require("nvim-tree.api").tree.toggle({ focus = false }) end From f6a8cd968edee9798204ee904df01cded47eb8e3 Mon Sep 17 00:00:00 2001 From: diniamo Date: Tue, 24 Dec 2024 11:43:13 +0100 Subject: [PATCH 12/39] nvim-notify: use explicit function for vim.notify --- modules/plugins/ui/notifications/nvim-notify/config.nix | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/plugins/ui/notifications/nvim-notify/config.nix b/modules/plugins/ui/notifications/nvim-notify/config.nix index 50972176..00f947ca 100644 --- a/modules/plugins/ui/notifications/nvim-notify/config.nix +++ b/modules/plugins/ui/notifications/nvim-notify/config.nix @@ -16,7 +16,7 @@ in { pluginRC.nvim-notify = entryAnywhere '' local notify = require("notify") notify.setup(${toLuaObject cfg.setupOpts}) - vim.notify = notify + vim.notify = notify.notify ''; }; }; From a34d104e3f51ef4859a68a424786f588d29124ca Mon Sep 17 00:00:00 2001 From: diniamo <55629891+diniamo@users.noreply.github.com> Date: Tue, 24 Dec 2024 12:19:08 +0100 Subject: [PATCH 13/39] languages/zig: disable lsp autosave (#511) --- docs/release-notes/rl-0.8.md | 3 +++ modules/plugins/languages/zig.nix | 19 ++++++++++++++----- 2 files changed, 17 insertions(+), 5 deletions(-) diff --git a/docs/release-notes/rl-0.8.md b/docs/release-notes/rl-0.8.md index 03d4d010..567e4e6e 100644 --- a/docs/release-notes/rl-0.8.md +++ b/docs/release-notes/rl-0.8.md @@ -18,3 +18,6 @@ [diniamo](https://github.com/diniamo): - Add Odin support under `vim.languages.odin`. + +- Disable the built-in format-on-save feature of zls. Use `vim.lsp.formatOnSave` + instead. diff --git a/modules/plugins/languages/zig.nix b/modules/plugins/languages/zig.nix index 3618d6d8..1b9a588b 100644 --- a/modules/plugins/languages/zig.nix +++ b/modules/plugins/languages/zig.nix @@ -6,7 +6,7 @@ }: let inherit (builtins) attrNames; inherit (lib.options) mkEnableOption mkOption; - inherit (lib.modules) mkIf mkMerge; + inherit (lib.modules) mkIf mkMerge mkDefault; inherit (lib.lists) isList; inherit (lib.types) either listOf package str enum; inherit (lib.nvim.lua) expToLua; @@ -60,13 +60,22 @@ in { config = mkIf cfg.enable (mkMerge [ (mkIf cfg.treesitter.enable { - vim.treesitter.enable = true; - vim.treesitter.grammars = [cfg.treesitter.package]; + vim.treesitter = { + enable = true; + grammars = [cfg.treesitter.package]; + }; }) (mkIf cfg.lsp.enable { - vim.lsp.lspconfig.enable = true; - vim.lsp.lspconfig.sources.zig-lsp = servers.${cfg.lsp.server}.lspConfig; + vim = { + lsp.lspconfig = { + enable = true; + sources.zig-lsp = servers.${cfg.lsp.server}.lspConfig; + }; + + # nvf handles autosaving already + globals.zig_fmt_autosave = mkDefault 0; + }; }) ]); } From 672630f680a92bb1b3a84bab73639a72de69c360 Mon Sep 17 00:00:00 2001 From: diniamo Date: Wed, 25 Dec 2024 13:37:04 +0100 Subject: [PATCH 14/39] flake: update run.nvim --- flake.lock | 6 +++--- modules/plugins/runner/run-nvim/config.nix | 14 +++----------- 2 files changed, 6 insertions(+), 14 deletions(-) diff --git a/flake.lock b/flake.lock index 97ff6754..3275a12f 100644 --- a/flake.lock +++ b/flake.lock @@ -1729,11 +1729,11 @@ "plugin-run-nvim": { "flake": false, "locked": { - "lastModified": 1734816675, - "narHash": "sha256-Wuk5HG+vHXAbifzp5YB5V/FxBhBRNWLeypkRczpXbvQ=", + "lastModified": 1735130195, + "narHash": "sha256-OaOSYyXSNCl9kJJVKhy0L4M06CQFc0NtZ8+AIgKBPik=", "owner": "diniamo", "repo": "run.nvim", - "rev": "6cd971afdce6443d7a070dcc23af51da1cc932f9", + "rev": "5888f31c5faf4776e598c0665470f5445510c59e", "type": "github" }, "original": { diff --git a/modules/plugins/runner/run-nvim/config.nix b/modules/plugins/runner/run-nvim/config.nix index 7667f5d0..60989a1d 100644 --- a/modules/plugins/runner/run-nvim/config.nix +++ b/modules/plugins/runner/run-nvim/config.nix @@ -20,17 +20,9 @@ in { cmd = "Run"; keys = [ - (mkKeymap "n" cfg.mappings.run "Run" {desc = mappings.run.description;}) - (mkKeymap "n" cfg.mappings.runOverride "Run!" {desc = mappings.runOverride.description;}) - (mkKeymap "n" cfg.mappings.runCommand '' - function() - local input = vim.fn.input("Run command: ") - if input ~= "" then require("run").run(input, false) end - end - '' { - desc = mappings.run.description; - lua = true; - }) + (mkKeymap "n" cfg.mappings.run "Run" {desc = mappings.run.description;}) + (mkKeymap "n" cfg.mappings.runOverride "Run!" {desc = mappings.runOverride.description;}) + (mkKeymap "n" cfg.mappings.runCommand "RunPrompt" {desc = mappings.run.description;}) ]; }; From 74e48b519d19d44b9694609f6e0de205d350a3f5 Mon Sep 17 00:00:00 2001 From: diniamo Date: Thu, 26 Dec 2024 08:06:13 +0100 Subject: [PATCH 15/39] flake: update mnw --- flake.lock | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/flake.lock b/flake.lock index 3275a12f..e25c7d80 100644 --- a/flake.lock +++ b/flake.lock @@ -38,11 +38,11 @@ }, "mnw": { "locked": { - "lastModified": 1731821965, - "narHash": "sha256-QiGi/HBQRnIRGY4gQPuH7T3hr7NznOpEO7qNpF5ldmE=", + "lastModified": 1735150973, + "narHash": "sha256-OJhcCAoaMMXeD6o4qI/hxBCNELJp4dN8D5LJZc8w8XA=", "owner": "Gerg-L", "repo": "mnw", - "rev": "5fe5c41975ed0af55f55dc37cd28ba906a5d015e", + "rev": "40cd0b006cc48dffd0f8698ad7f54cf1d56779a6", "type": "github" }, "original": { From c3b51df4a6ff5a3c53eaff36dd85fe6ae7ac84be Mon Sep 17 00:00:00 2001 From: diniamo Date: Mon, 30 Dec 2024 09:49:33 +0100 Subject: [PATCH 16/39] flake: update run.nvim --- flake.lock | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/flake.lock b/flake.lock index e25c7d80..3282f58b 100644 --- a/flake.lock +++ b/flake.lock @@ -1729,11 +1729,11 @@ "plugin-run-nvim": { "flake": false, "locked": { - "lastModified": 1735130195, - "narHash": "sha256-OaOSYyXSNCl9kJJVKhy0L4M06CQFc0NtZ8+AIgKBPik=", + "lastModified": 1735501787, + "narHash": "sha256-CFOyOARCLQiMOhFPeqz8n2ULyaaRxRZrOk0FCibjuIM=", "owner": "diniamo", "repo": "run.nvim", - "rev": "5888f31c5faf4776e598c0665470f5445510c59e", + "rev": "9015c9cece816ccf10a185b420f6e345fd990802", "type": "github" }, "original": { From 2a89fd409374ee14ca08d5d710bb05f3bedc77b8 Mon Sep 17 00:00:00 2001 From: NotAShelf Date: Mon, 30 Dec 2024 19:18:08 +0300 Subject: [PATCH 17/39] flake: bump all inputs --- flake.lock | 320 ++++++++++++++++++++++++++--------------------------- 1 file changed, 160 insertions(+), 160 deletions(-) diff --git a/flake.lock b/flake.lock index 3282f58b..fd404df6 100644 --- a/flake.lock +++ b/flake.lock @@ -5,11 +5,11 @@ "nixpkgs-lib": "nixpkgs-lib" }, "locked": { - "lastModified": 1730504689, - "narHash": "sha256-hgmguH29K2fvs9szpq2r3pz2/8cJd2LPS+b4tfNFCwE=", + "lastModified": 1733312601, + "narHash": "sha256-4pDvzqnegAfRkPwO3wmwBhVi/Sye1mzps0zHWYnP88c=", "owner": "hercules-ci", "repo": "flake-parts", - "rev": "506278e768c2a08bec68eb62932193e341f55c90", + "rev": "205b12d8b7cd4802fbcb8e8ef6a0f1408781a4f9", "type": "github" }, "original": { @@ -98,11 +98,11 @@ }, "nixpkgs": { "locked": { - "lastModified": 1733024928, - "narHash": "sha256-n/DOfpKH1vkukuBnach91QBQId2dr5tkE7/7UrkV2zw=", + "lastModified": 1735523292, + "narHash": "sha256-opBsbR/nrGxiiF6XzlVluiHYb6yN/hEwv+lBWTy9xoM=", "owner": "nixos", "repo": "nixpkgs", - "rev": "2c27ab2e60502d1ebb7cf38909de38663f762a79", + "rev": "6d97d419e5a9b36e6293887a89a078cf85f5a61b", "type": "github" }, "original": { @@ -114,14 +114,14 @@ }, "nixpkgs-lib": { "locked": { - "lastModified": 1730504152, - "narHash": "sha256-lXvH/vOfb4aGYyvFmZK/HlsNsr/0CVWlwYvo2rxJk3s=", + "lastModified": 1733096140, + "narHash": "sha256-1qRH7uAUsyQI7R1Uwl4T+XvdNv778H0Nb5njNrqvylY=", "type": "tarball", - "url": "https://github.com/NixOS/nixpkgs/archive/cc2f28000298e1269cea6612cd06ec9979dd5d7f.tar.gz" + "url": "https://github.com/NixOS/nixpkgs/archive/5487e69da40cbd611ab2cadee0b4637225f7cfae.tar.gz" }, "original": { "type": "tarball", - "url": "https://github.com/NixOS/nixpkgs/archive/cc2f28000298e1269cea6612cd06ec9979dd5d7f.tar.gz" + "url": "https://github.com/NixOS/nixpkgs/archive/5487e69da40cbd611ab2cadee0b4637225f7cfae.tar.gz" } }, "nixpkgs_2": { @@ -207,11 +207,11 @@ "plugin-catppuccin": { "flake": false, "locked": { - "lastModified": 1732428187, - "narHash": "sha256-Oogw5wmYkx/zsMlPE/r6Kt3cy5sC92rwVzf0P9rzqyw=", + "lastModified": 1735299190, + "narHash": "sha256-lwQLmqm01FihJdad4QRMK23MTrouyOokyuX/3enWjzs=", "owner": "catppuccin", "repo": "nvim", - "rev": "faf15ab0201b564b6368ffa47b56feefc92ce3f4", + "rev": "f67b886d65a029f12ffa298701fb8f1efd89295d", "type": "github" }, "original": { @@ -335,11 +335,11 @@ "plugin-cmp-nvim-lsp": { "flake": false, "locked": { - "lastModified": 1715931395, - "narHash": "sha256-CT1+Z4XJBVsl/RqvJeGmyitD6x7So0ylXvvef5jh7I8=", + "lastModified": 1733823748, + "narHash": "sha256-iaihXNCF5bB5MdeoosD/kc3QtpA/QaIDZVLiLIurBSM=", "owner": "hrsh7th", "repo": "cmp-nvim-lsp", - "rev": "39e2eda76828d88b773cc27a3f61d2ad782c922d", + "rev": "99290b3ec1322070bcfb9e846450a46f6efa50f0", "type": "github" }, "original": { @@ -415,11 +415,11 @@ "plugin-copilot-cmp": { "flake": false, "locked": { - "lastModified": 1718601710, - "narHash": "sha256-8w9go2SBkI+BrXNadWM8ZxDDfrAnZZJx6RbVHAK4+Pg=", + "lastModified": 1733947099, + "narHash": "sha256-erRL8bY/zuwuCZfttw+avTrFV7pjv2H6v73NzY2bymM=", "owner": "zbirenbaum", "repo": "copilot-cmp", - "rev": "b6e5286b3d74b04256d0a7e3bd2908eabec34b44", + "rev": "15fc12af3d0109fa76b60b5cffa1373697e261d1", "type": "github" }, "original": { @@ -431,11 +431,11 @@ "plugin-copilot-lua": { "flake": false, "locked": { - "lastModified": 1729295476, - "narHash": "sha256-UY6N2Q+egh+Cn4REZXrSGH9ElWQBedl0n8tWJvGe7vs=", + "lastModified": 1734926641, + "narHash": "sha256-c2UE0dLBtoYMvMxg+jXzfsD+wN9sZLvftJq4gGmooZU=", "owner": "zbirenbaum", "repo": "copilot.lua", - "rev": "f8d8d872bb319f640d5177dad5fbf01f7a16d7d0", + "rev": "886ee73b6d464b2b3e3e6a7ff55ce87feac423a9", "type": "github" }, "original": { @@ -463,11 +463,11 @@ "plugin-csharpls-extended": { "flake": false, "locked": { - "lastModified": 1732674428, - "narHash": "sha256-d7ll3OlOLx/7E+6+uga26L/FAqd8pZ4XquMakxMsFwU=", + "lastModified": 1734491815, + "narHash": "sha256-jO/vuNgP8JAOIturzPFvxMLL5y+6YTYsUxjWwX6Nyso=", "owner": "Decodetalkers", "repo": "csharpls-extended-lsp.nvim", - "rev": "c788fed627827238de348195c3f318cd090e8e77", + "rev": "4f56c06215d10c4fcfee8a7f04ba766c114aece0", "type": "github" }, "original": { @@ -511,11 +511,11 @@ "plugin-dracula": { "flake": false, "locked": { - "lastModified": 1731308832, - "narHash": "sha256-3Tlk+utoF4QUjTIPszbyMDh5vUyNiBmq4bRW/leMjaU=", + "lastModified": 1734597715, + "narHash": "sha256-9iRI5NW3mcVzduitY4sr679dRWAWVbZuCAEfgM1OIOs=", "owner": "Mofiqul", "repo": "dracula.nvim", - "rev": "e6128ec3923b92bb2b16e81b4a0f04ed0308038e", + "rev": "515acae4fd294fcefa5b15237a333c2606e958d1", "type": "github" }, "original": { @@ -527,11 +527,11 @@ "plugin-dressing-nvim": { "flake": false, "locked": { - "lastModified": 1731521499, - "narHash": "sha256-O0sdxU+ZQnclnnC5IfBpgqlMxjsJKlmPYQYPP+S3cn8=", + "lastModified": 1734804193, + "narHash": "sha256-N4hB5wDgoqXrXxSfzDCrqmdDtdVvq+PtOS7FBPH7qXE=", "owner": "stevearc", "repo": "dressing.nvim", - "rev": "fc78a3ca96f4db9f8893bb7e2fd9823e0780451b", + "rev": "3a45525bb182730fe462325c99395529308f431e", "type": "github" }, "original": { @@ -543,11 +543,11 @@ "plugin-elixir-tools": { "flake": false, "locked": { - "lastModified": 1727872243, - "narHash": "sha256-7gIvoV6myqbkjLnIhHuyNPix1DFkKEeeND2o6VDxDWc=", + "lastModified": 1735076861, + "narHash": "sha256-CoGTVSKifjqshk8hYaQfFYTYgEGsIb1hKdz6fIS81iU=", "owner": "elixir-tools", "repo": "elixir-tools.nvim", - "rev": "b465f6aff50257fa466de3886fc3e7de2dcff0de", + "rev": "803fa69dbb457305cff98e3997bed2c4b51aea7c", "type": "github" }, "original": { @@ -559,11 +559,11 @@ "plugin-fastaction-nvim": { "flake": false, "locked": { - "lastModified": 1732135971, - "narHash": "sha256-Q+FX7XiX8LyTC4OZ43Q2pXIdSViDn65P9pkDp8jvbnA=", + "lastModified": 1734546047, + "narHash": "sha256-1GSxTyXqufjkRtNK3drWlCn/mGJ9mM9bHMR6ZwWT6X8=", "owner": "Chaitanyabsprip", "repo": "fastaction.nvim", - "rev": "24255a74e0d35f1e1807aa78997f5c31ae419dbc", + "rev": "886e22d85e13115808e81ca367d5aaba02d9a25b", "type": "github" }, "original": { @@ -575,11 +575,11 @@ "plugin-fidget-nvim": { "flake": false, "locked": { - "lastModified": 1730221432, - "narHash": "sha256-fQBrkHV54TaOeLYQJ1DE+lr7SFDPN1yqSlzhFm26NAY=", + "lastModified": 1734334336, + "narHash": "sha256-o0za2NxFtzHZa7PRIm9U/P1/fwJrxS1G79ukdGLhJ4Q=", "owner": "j-hui", "repo": "fidget.nvim", - "rev": "e2a175c2abe2d4f65357da1c98c59a5cfb2b543f", + "rev": "9238947645ce17d96f30842e61ba81147185b657", "type": "github" }, "original": { @@ -591,11 +591,11 @@ "plugin-flutter-tools": { "flake": false, "locked": { - "lastModified": 1732910301, - "narHash": "sha256-iU0aTq3F5U2z8iKdUMxkvQ8ZopmWIGdx1I8ir0q7n0U=", + "lastModified": 1735420417, + "narHash": "sha256-xfSdPhrSUwBYdE9ZA8GgwFvR70nOp+snbNrFHeIfwOM=", "owner": "akinsho", "repo": "flutter-tools.nvim", - "rev": "40f974b15f82f9af498adda8d93aabd637f3ab58", + "rev": "a526c30f1941a7472509aaedda13758f943c968e", "type": "github" }, "original": { @@ -607,11 +607,11 @@ "plugin-friendly-snippets": { "flake": false, "locked": { - "lastModified": 1728273759, - "narHash": "sha256-H94Ryad0ZsSg/gioUgW+7sowij7GgtEUMNFi1IOZAys=", + "lastModified": 1733106470, + "narHash": "sha256-I8SRZxnoNC6SOWW+scoA77Jwyxcb4eUczppLdyOiZe0=", "owner": "rafamadriz", "repo": "friendly-snippets", - "rev": "de8fce94985873666bd9712ea3e49ee17aadb1ed", + "rev": "efff286dd74c22f731cdec26a70b46e5b203c619", "type": "github" }, "original": { @@ -751,11 +751,11 @@ "plugin-image-nvim": { "flake": false, "locked": { - "lastModified": 1732136347, - "narHash": "sha256-Az/jiHW/DtvHNlV+Wzw6U+p8b2Ic9pNJRQ6YGerL81c=", + "lastModified": 1735173549, + "narHash": "sha256-Sjbmf4BmjkjAorT3tojbC7JivJagFamAVgzwcCipa8k=", "owner": "3rd", "repo": "image.nvim", - "rev": "5f8fceca2d1be96a45b81de21c2f98bf6084fb34", + "rev": "b991fc7f845bc6ab40c6ec00b39750dcd5190010", "type": "github" }, "original": { @@ -767,11 +767,11 @@ "plugin-indent-blankline": { "flake": false, "locked": { - "lastModified": 1731320409, - "narHash": "sha256-WVDNi/woG0ohPEYzM83mmXDCRNYnQbqooSDVUtBsJbY=", + "lastModified": 1733296464, + "narHash": "sha256-H3lUQZDvgj3a2STYeMUDiOYPe7rfsy08tJ4SlDd+LuE=", "owner": "lukas-reineke", "repo": "indent-blankline.nvim", - "rev": "7871a88056f7144defca9c931e311a3134c5d509", + "rev": "259357fa4097e232730341fa60988087d189193a", "type": "github" }, "original": { @@ -799,11 +799,11 @@ "plugin-lsp-lines": { "flake": false, "locked": { - "lastModified": 1716108775, - "narHash": "sha256-QsvmPOer7JgO7Y+N/iaNJD7Kmy69gnlV4CeyaQesNvA=", + "lastModified": 1734793049, + "narHash": "sha256-jHiIZemneQACTDYZXBJqX2/PRTBoxq403ILvt1Ej1ZM=", "owner": "~whynothugo", "repo": "lsp_lines.nvim", - "rev": "7d9e2748b61bff6ebba6e30adbc7173ccf21c055", + "rev": "a92c755f182b89ea91bd8a6a2227208026f27b4d", "type": "sourcehut" }, "original": { @@ -831,11 +831,11 @@ "plugin-lspkind": { "flake": false, "locked": { - "lastModified": 1729872608, - "narHash": "sha256-/ifgjqqCQw67l3+gUs00tt860pa92M1WYdjdZ0lhxak=", + "lastModified": 1733408701, + "narHash": "sha256-OCvKUBGuzwy8OWOL1x3Z3fo+0+GyBMI9TX41xSveqvE=", "owner": "onsails", "repo": "lspkind-nvim", - "rev": "a700f1436d4a938b1a1a93c9962dc796afbaef4d", + "rev": "d79a1c3299ad0ef94e255d045bed9fa26025dab6", "type": "github" }, "original": { @@ -895,11 +895,11 @@ "plugin-luasnip": { "flake": false, "locked": { - "lastModified": 1732967555, - "narHash": "sha256-iWivJ6dIOEqT3uLQA5KzvCHkDcjC62OlNWagEW680qc=", + "lastModified": 1733162004, + "narHash": "sha256-efDe3RXncnNVkj37AmIv8oj0DKurB50Dziao5FGTLP4=", "owner": "L3MON4D3", "repo": "LuaSnip", - "rev": "2592b91577136dbb355a4708be1e60619456b7f6", + "rev": "33b06d72d220aa56a7ce80a0dd6f06c70cd82b9d", "type": "github" }, "original": { @@ -911,11 +911,11 @@ "plugin-lz-n": { "flake": false, "locked": { - "lastModified": 1733019070, - "narHash": "sha256-Go9FBjF3EBFy+/53lpC5AdKYpJBK+uFzInTk6lODxdQ=", + "lastModified": 1735437369, + "narHash": "sha256-6NIXqwmX7RgwiZVEzmTnkJgmrPqFNx12ayIcRgNIaEs=", "owner": "nvim-neorocks", "repo": "lz.n", - "rev": "f308fa4dd81355fb5fddf3ca209847d679af6917", + "rev": "32be28a221b9c98e56841458e4b20c150a4169c4", "type": "github" }, "original": { @@ -976,11 +976,11 @@ "plugin-modes-nvim": { "flake": false, "locked": { - "lastModified": 1717693302, - "narHash": "sha256-z1XD0O+gG2/+g/skdWGC64Zv4dXvvhWesaK/8DcPF/E=", + "lastModified": 1734414076, + "narHash": "sha256-ShIK8ROowT1yFHgSIVHUFnnQOEMr3YPIqw4ixzR8w8M=", "owner": "mvllow", "repo": "modes.nvim", - "rev": "326cff3282419b3bcc745061978c1e592cae055d", + "rev": "c7a4b1b383606832aab150902719bd5eb5cdb2b0", "type": "github" }, "original": { @@ -992,11 +992,11 @@ "plugin-neo-tree-nvim": { "flake": false, "locked": { - "lastModified": 1732465535, - "narHash": "sha256-3wRojpFbdjcRQPv62/mHqQgyfytTqaBcsX1X0zCNgC8=", + "lastModified": 1735302061, + "narHash": "sha256-tZMneZsEbB5bgZgYq4ZWwK25B3vcnn80Q7diKcRoEv4=", "owner": "nvim-neo-tree", "repo": "neo-tree.nvim", - "rev": "42caaf5c3b7ca346ab278201151bb878006a6031", + "rev": "a9f8943b4c31f8460d25c71e0f463d65e9775f1c", "type": "github" }, "original": { @@ -1008,11 +1008,11 @@ "plugin-neocord": { "flake": false, "locked": { - "lastModified": 1729369963, - "narHash": "sha256-4dVaxigJ8eOXpgiqcxUYIF4SoC1CPFvNHYKT0zxIYo0=", + "lastModified": 1733429637, + "narHash": "sha256-g/pq6hFo7duonIl1wWoxbJUTh/IRTH3hHEoQUdoiqKE=", "owner": "IogaMaster", "repo": "neocord", - "rev": "587e03390a355e9c364d48638e0e0db2a8431d73", + "rev": "4d55d8dab2d5f2f272192add7a2c21982039c699", "type": "github" }, "original": { @@ -1040,11 +1040,11 @@ "plugin-neorg": { "flake": false, "locked": { - "lastModified": 1732289702, - "narHash": "sha256-8RQ+PFnIcjPoNJQB/qz+zv1fjVjFEwPhuAh+JL7GPL4=", + "lastModified": 1734188232, + "narHash": "sha256-xH87caxEebrWLwY/v3xyyOy6PTG/ZqX2OfCdwg/RqDY=", "owner": "nvim-neorg", "repo": "neorg", - "rev": "7a893a176a7d9c074a5371865b53c6aa4e223991", + "rev": "6b945909d84b5aeadc875f9b3f529ec44b9bc60f", "type": "github" }, "original": { @@ -1088,11 +1088,11 @@ "plugin-noice-nvim": { "flake": false, "locked": { - "lastModified": 1732649160, - "narHash": "sha256-0RLMkThaE6AxYvUKx056Ac63Oc2NTJxvgyRnZJ5/D2g=", + "lastModified": 1734026622, + "narHash": "sha256-OpwgNTGunmy6Y7D/k0T+DFK/WJ8MeVTGWwjiPTQlvEY=", "owner": "folke", "repo": "noice.nvim", - "rev": "c6f6fb178ebe9b4fd90383de743c3399f8c3a37c", + "rev": "eaed6cc9c06aa2013b5255349e4f26a6b17ab70f", "type": "github" }, "original": { @@ -1121,11 +1121,11 @@ "plugin-nui-nvim": { "flake": false, "locked": { - "lastModified": 1726376728, - "narHash": "sha256-90Wq+vT361mTaGU/SvAezqJkX9HHmZ2GI2fKBDxPn04=", + "lastModified": 1733856815, + "narHash": "sha256-6U7E/i5FuNXQy+sF4C5DVxuTPqNKD5wxUgFohpOjm9Q=", "owner": "MunifTanjim", "repo": "nui.nvim", - "rev": "b58e2bfda5cea347c9d58b7f11cf3012c7b3953f", + "rev": "53e907ffe5eedebdca1cd503b00aa8692068ca46", "type": "github" }, "original": { @@ -1169,11 +1169,11 @@ "plugin-nvim-cmp": { "flake": false, "locked": { - "lastModified": 1732948484, - "narHash": "sha256-+0nflL0WCaxPuJgUviELhbXASNYYl/SKZ+nz70sEAXU=", + "lastModified": 1734672427, + "narHash": "sha256-Z/Qy2ErbCa7dbjZVuJUkMmb4d24amNunNgRcbCGPfOg=", "owner": "hrsh7th", "repo": "nvim-cmp", - "rev": "ca4d3330d386e76967e53b85953c170658255ecb", + "rev": "b555203ce4bd7ff6192e759af3362f9d217e8c89", "type": "github" }, "original": { @@ -1185,11 +1185,11 @@ "plugin-nvim-colorizer-lua": { "flake": false, "locked": { - "lastModified": 1732386340, - "narHash": "sha256-lAWeljYC17bmEs1Ss80o6eJYrJ9fsFlKvyJWu9e44XU=", + "lastModified": 1735384185, + "narHash": "sha256-quqs3666vQc/4ticc/Z5BHzGxV6UUVE9jVGT07MEMQQ=", "owner": "NvChad", "repo": "nvim-colorizer.lua", - "rev": "4acf88d31b3a7a1a7f31e9c30bf2b23c6313abdb", + "rev": "8a65c448122fc8fac9c67b2e857b6e830a4afd0b", "type": "github" }, "original": { @@ -1217,11 +1217,11 @@ "plugin-nvim-dap": { "flake": false, "locked": { - "lastModified": 1732901614, - "narHash": "sha256-atsgMdPyAAbh4dIxZOAE3hHLLb/664112lHdXHcXtZQ=", + "lastModified": 1735568902, + "narHash": "sha256-5iaXim9bDvSAI6jUXgu2OEk/KivfAsMTRry+UTHs2Gk=", "owner": "mfussenegger", "repo": "nvim-dap", - "rev": "0a0daa796a5919a51e5e5019ffa91219c94c4fef", + "rev": "ffb077e65259f13be096ea6d603e3575a76b214a", "type": "github" }, "original": { @@ -1249,11 +1249,11 @@ "plugin-nvim-dap-ui": { "flake": false, "locked": { - "lastModified": 1727897692, - "narHash": "sha256-kg7lyVBeuBqPCVzvt3pBoonQupgf1nGh3EvCF/astf4=", + "lastModified": 1735324898, + "narHash": "sha256-psIBQpx3tV2UWm5hZTMPBANcXHPAX24dIuDq8Qcscxs=", "owner": "rcarriga", "repo": "nvim-dap-ui", - "rev": "ffa89839f97bad360e78428d5c740fdad9a0ff02", + "rev": "e94d98649dccb6a3884b66aabc2e07beb279e535", "type": "github" }, "original": { @@ -1265,11 +1265,11 @@ "plugin-nvim-docs-view": { "flake": false, "locked": { - "lastModified": 1723781320, - "narHash": "sha256-6kd3IWsD72eYe+q1w78gcFcK9LalCQHCqtSwwqQR3Ew=", + "lastModified": 1733658747, + "narHash": "sha256-b5aH8Tj+tMk0BjNCgdeCEeR26oQ9NCobj98P7IDgIPY=", "owner": "amrbashir", "repo": "nvim-docs-view", - "rev": "365593534e0acd762bfddce6e8313315ffa4fa36", + "rev": "1b97f8f954d74c46061bf289b6cea9232484c12c", "type": "github" }, "original": { @@ -1281,11 +1281,11 @@ "plugin-nvim-lightbulb": { "flake": false, "locked": { - "lastModified": 1729134062, - "narHash": "sha256-JfXSuOBwyxgH/PzzcBQ7OqoXHkLGZSCYutYHLocbTto=", + "lastModified": 1734997673, + "narHash": "sha256-byvgRJvvt5rhiUVWdreY2jELXoPVld5EKQlOXwjNgWE=", "owner": "kosayoda", "repo": "nvim-lightbulb", - "rev": "33d4c95e0e853956bc9468b70b3064c87d5abaca", + "rev": "3ac0791be37ba9cc7939f1ad90ebc5e75abf4eea", "type": "github" }, "original": { @@ -1297,11 +1297,11 @@ "plugin-nvim-lspconfig": { "flake": false, "locked": { - "lastModified": 1733062298, - "narHash": "sha256-tLZYWbKSQxiRU1tQqRXAUSTfCS7a1tHNSIMbt0aOamU=", + "lastModified": 1735439232, + "narHash": "sha256-6a1HjpLYdZ+ZmWM1B0tv631A3EHHstPrjaV15UnVtoY=", "owner": "neovim", "repo": "nvim-lspconfig", - "rev": "90c1c6cc822b1836209514c096069b9bbeab63d9", + "rev": "8b15a1a597a59f4f5306fad9adfe99454feab743", "type": "github" }, "original": { @@ -1313,11 +1313,11 @@ "plugin-nvim-metals": { "flake": false, "locked": { - "lastModified": 1728295172, - "narHash": "sha256-ja/+MNxZ3H9io9jDwm5rhE6iKNi86a22eCOY75g19O8=", + "lastModified": 1735386491, + "narHash": "sha256-G9V7fX65uW4z7kiuiP8mLtEjLoTJ1mkltj51OlN5/oM=", "owner": "scalameta", "repo": "nvim-metals", - "rev": "f861db9fda55939797ac1b05238c49b0dcdc3bdb", + "rev": "e6b02c99161b43c67cfe1d6e5f9a9b9a0bb4701c", "type": "github" }, "original": { @@ -1361,11 +1361,11 @@ "plugin-nvim-neoclip": { "flake": false, "locked": { - "lastModified": 1725927226, - "narHash": "sha256-GHkTIGPgX5j1wUS9EW/fGOp3NSRjfVaz+6o1Aehy2Xw=", + "lastModified": 1734898459, + "narHash": "sha256-RCMZi1DM9JFrXWQ5w2wOjFzpANkiukn+RvHB9swMtbk=", "owner": "AckslD", "repo": "nvim-neoclip.lua", - "rev": "32e05f2d23dc5b6a284a688c0535a83d1bfc633f", + "rev": "5e5e010251281f4aea69cfc1d4976ffe6065cf0f", "type": "github" }, "original": { @@ -1393,11 +1393,11 @@ "plugin-nvim-notify": { "flake": false, "locked": { - "lastModified": 1727022370, - "narHash": "sha256-Sd7IR5roXHOKRCxhqtYMhWfEltyRJMDEMDO/ecSKenE=", + "lastModified": 1735562588, + "narHash": "sha256-9jDpoLLto9WgTsV399WeE2XGrTJXWTYbcJ+zOFWldAA=", "owner": "rcarriga", "repo": "nvim-notify", - "rev": "fbef5d32be8466dd76544a257d3f3dce20082a07", + "rev": "c3797193536711b5d8983975791c4b11dc35ab3a", "type": "github" }, "original": { @@ -1457,11 +1457,11 @@ "plugin-nvim-tree-lua": { "flake": false, "locked": { - "lastModified": 1732428058, - "narHash": "sha256-HHgC7aH2m3gv2FtOK1jhjBgJOGWrdc+FQOEpMiEWe74=", + "lastModified": 1734820548, + "narHash": "sha256-4PmP31vYPH9xw4AjV5rDSKvcvZGTnIaPfR4Bwc0lAiA=", "owner": "nvim-tree", "repo": "nvim-tree.lua", - "rev": "ca7c4c33cac2ad66ec69d45e465379716ef0cc97", + "rev": "68fc4c20f5803444277022c681785c5edd11916d", "type": "github" }, "original": { @@ -1473,11 +1473,11 @@ "plugin-nvim-treesitter-context": { "flake": false, "locked": { - "lastModified": 1733041360, - "narHash": "sha256-wcz3F0vDrgMXJjB0Zz7naoVQ8YvHdd55gG4NHqQMYQY=", + "lastModified": 1734710732, + "narHash": "sha256-TIFMPKzD2ero1eK9aVfY1iKEvf/Sw8SL/9mk9omCQ3c=", "owner": "nvim-treesitter", "repo": "nvim-treesitter-context", - "rev": "920999bf53daa63ddf12efdeb5137a7cea1cc201", + "rev": "2bcf700b59bc92850ca83a1c02e86ba832e0fae0", "type": "github" }, "original": { @@ -1489,11 +1489,11 @@ "plugin-nvim-ts-autotag": { "flake": false, "locked": { - "lastModified": 1732998473, - "narHash": "sha256-HtF0arW9cuE4yQN+1ccRaonqiH6fcoTpyuSecLPKtKc=", + "lastModified": 1733164313, + "narHash": "sha256-v2NTFBIzKTYizUPWB3uhpnTGVZWaelhE3MT5+BDA6Do=", "owner": "windwp", "repo": "nvim-ts-autotag", - "rev": "f2d24aca1bcbbd2c0306fd93d52e3697027b77ff", + "rev": "1cca23c9da708047922d3895a71032bc0449c52d", "type": "github" }, "original": { @@ -1505,11 +1505,11 @@ "plugin-nvim-web-devicons": { "flake": false, "locked": { - "lastModified": 1732925137, - "narHash": "sha256-Sh+r54pTI60j5tOmSyEkTVS6MzMIt52nqjNdtMp8kpI=", + "lastModified": 1735569123, + "narHash": "sha256-h9rY6F+2sBlG9PFN34/0ZTkY66oCeCIPe/HEadM03K4=", "owner": "nvim-tree", "repo": "nvim-web-devicons", - "rev": "203da76ecfbb4b192cf830665b03eb651b635c94", + "rev": "4adeeaa7a32d46cf3b5833341358c797304f950a", "type": "github" }, "original": { @@ -1569,11 +1569,11 @@ "plugin-orgmode-nvim": { "flake": false, "locked": { - "lastModified": 1731656059, - "narHash": "sha256-uKJuJsxQhdh3NxZx1Uu72poQVFN7KEyyMFEHPUr7UgQ=", + "lastModified": 1734770880, + "narHash": "sha256-E1YJeTay1tX2PgiXwV/DRgrlYHIGUe9/uTA+6ORIhBw=", "owner": "nvim-orgmode", "repo": "orgmode", - "rev": "1d8c9b9417f8c8e9fb146d4f54fb1e90a4f7e534", + "rev": "bf657742f7cb56211f99946ff64f5f87d7d7f0d0", "type": "github" }, "original": { @@ -1585,11 +1585,11 @@ "plugin-otter-nvim": { "flake": false, "locked": { - "lastModified": 1724585935, - "narHash": "sha256-euHwoK2WHLF/hrjLY2P4yGrIbYyBN38FL3q4CKNZmLY=", + "lastModified": 1735130975, + "narHash": "sha256-NPBGcLi1lEmpGGbGs58Xzw1IriOyKTMQdwIdVFsbVDM=", "owner": "jmbuhr", "repo": "otter.nvim", - "rev": "ca9ce67d0399380b659923381b58d174344c9ee7", + "rev": "e8c662e1aefa8b483cfba6e00729a39a363dcecc", "type": "github" }, "original": { @@ -1697,11 +1697,11 @@ "plugin-rose-pine": { "flake": false, "locked": { - "lastModified": 1729724348, - "narHash": "sha256-/a4pwuVJ5odm3Iio2MeoqAm8GlWIPI91mM4cVnSy/gE=", + "lastModified": 1733845819, + "narHash": "sha256-ejh9UXQbLc8Ie6wF7zszzL1gaJzr16gcu0dUWqTo8AM=", "owner": "rose-pine", "repo": "neovim", - "rev": "07a887a7bef4aacea8c7caebaf8cbf808cdc7a8e", + "rev": "91548dca53b36dbb9d36c10f114385f759731be1", "type": "github" }, "original": { @@ -1745,11 +1745,11 @@ "plugin-rustaceanvim": { "flake": false, "locked": { - "lastModified": 1732919014, - "narHash": "sha256-7UZ54b3IPS1cPyu+JCM/dHhJLHuqa16suaC2XlSw5Og=", + "lastModified": 1735431742, + "narHash": "sha256-ucZXGbxHtbSKf5n11lL3vb6rD2BxJacIDOgcx32PLzA=", "owner": "mrcjkb", "repo": "rustaceanvim", - "rev": "4ac7a3c6cca9e393229651cc90733afbdc7c6395", + "rev": "51c097ebfb65d83baa71f48000b1e5c0a8dcc4fb", "type": "github" }, "original": { @@ -1761,11 +1761,11 @@ "plugin-smartcolumn": { "flake": false, "locked": { - "lastModified": 1710067624, - "narHash": "sha256-DHIeDNUF9n9s14GVeojIwc5QUPwJMYYl3gRvhvO/rdE=", + "lastModified": 1734696989, + "narHash": "sha256-6RodA5BQnL6tB3RCE5G2RiXqBvM3VP3HYZ+T3AxIF7Q=", "owner": "m4xshen", "repo": "smartcolumn.nvim", - "rev": "cefb17be095ad5526030a21bb2a80553cae09127", + "rev": "f14fbea6f86cd29df5042897ca9e3ba10ba4d27f", "type": "github" }, "original": { @@ -1777,11 +1777,11 @@ "plugin-sqls-nvim": { "flake": false, "locked": { - "lastModified": 1733003065, - "narHash": "sha256-VKN4ggWogAr+hwr/gtIDgY5j3afL9R7dZ2oJ4+qpEtE=", + "lastModified": 1733090837, + "narHash": "sha256-o5uD6shPkweuE+k/goBX42W3I2oojXVijfJC7L50sGU=", "owner": "nanotee", "repo": "sqls.nvim", - "rev": "8d7b6010d276fdda494ede23df511eba120886b9", + "rev": "a514379f5f89bf72955ed3bf5c1c31a40b8a1472", "type": "github" }, "original": { @@ -1825,11 +1825,11 @@ "plugin-tiny-devicons-auto-colors": { "flake": false, "locked": { - "lastModified": 1724403745, - "narHash": "sha256-Ndkbvxn/x7+fxEYD7JIygqUiItuhoY+4+DaL/pJGKdc=", + "lastModified": 1733445616, + "narHash": "sha256-klUZKvdYhwO3sq4Su4sBFDcNSAYXh53O72vg4+ZOrhI=", "owner": "rachartier", "repo": "tiny-devicons-auto-colors.nvim", - "rev": "a39fa4c92268832f6034306793b8acbfec2a7549", + "rev": "c8f63933ee013c1e0a26091d58131e060546f01f", "type": "github" }, "original": { @@ -1857,11 +1857,11 @@ "plugin-toggleterm-nvim": { "flake": false, "locked": { - "lastModified": 1731162901, - "narHash": "sha256-g1FwgCc3a8Fak0Nb0gQQ+SI44uyAGaH1tIk1qpaAPEY=", + "lastModified": 1735340326, + "narHash": "sha256-oeNIb+QHa/9yGZz/2u9LYIdKluel0bcQkaIqOuQUkis=", "owner": "akinsho", "repo": "toggleterm.nvim", - "rev": "87b2d6a3cab8e2bd9a0255427074285f0365398d", + "rev": "344fc1810292785b3d962ddac2de57669e1a7ff9", "type": "github" }, "original": { @@ -1873,11 +1873,11 @@ "plugin-tokyonight": { "flake": false, "locked": { - "lastModified": 1732026921, - "narHash": "sha256-vKXlFHzga9DihzDn+v+j3pMNDfvhYHcCT8GpPs0Uxgg=", + "lastModified": 1734211493, + "narHash": "sha256-TJ/a6N6Cc1T0wdMxMopma1NtwL7rMYbZ6F0zFI1zaIA=", "owner": "folke", "repo": "tokyonight.nvim", - "rev": "c2725eb6d086c8c9624456d734bd365194660017", + "rev": "45d22cf0e1b93476d3b6d362d720412b3d34465c", "type": "github" }, "original": { @@ -1921,11 +1921,11 @@ "plugin-typst-preview-nvim": { "flake": false, "locked": { - "lastModified": 1733120663, - "narHash": "sha256-uYMZ2PONiiI3UDvCgNvyy4+jhzmUDbAyxX0phKxELXw=", + "lastModified": 1734839452, + "narHash": "sha256-d6Tv7xZRghYYDfABk/p2e9qTm4qnWHM+ejKDCcR0TfY=", "owner": "chomosuke", "repo": "typst-preview.nvim", - "rev": "0cb5f5627312f50ce089f785ec42b55a85f30ce7", + "rev": "c1100e8788baabe8ca8f8cd7fd63d3d479e49e36", "type": "github" }, "original": { @@ -1953,11 +1953,11 @@ "plugin-vim-fugitive": { "flake": false, "locked": { - "lastModified": 1732036604, - "narHash": "sha256-RGS2T6tHuFPZROU0W4Z6j6wMEiJmd8xuKv3qqM3XHPI=", + "lastModified": 1735457366, + "narHash": "sha256-45zsqKavWoclA67MC54bAel1nE8CLHtSdullHByiRS8=", "owner": "tpope", "repo": "vim-fugitive", - "rev": "320b18fba2a4f2fe3c8225c778c687e0d2620384", + "rev": "174230d6a7f2df94705a7ffd8d5413e27ec10a80", "type": "github" }, "original": { @@ -2033,11 +2033,11 @@ "plugin-which-key": { "flake": false, "locked": { - "lastModified": 1732804356, - "narHash": "sha256-55RmbdN0rNG8946eIMFd5BlN82eY1GKqmHdUiC7BP+U=", + "lastModified": 1734253151, + "narHash": "sha256-f/+sYMDEguB5ZDiYiQAsDvdF/2cVcWnLBU+9qwigk4s=", "owner": "folke", "repo": "which-key.nvim", - "rev": "9b365a6428a9633e3eeb34dbef1b791511c54f70", + "rev": "8ab96b38a2530eacba5be717f52e04601eb59326", "type": "github" }, "original": { From 8febf44422f4404dcc1838ee55972733e092866c Mon Sep 17 00:00:00 2001 From: raf Date: Tue, 31 Dec 2024 07:02:13 +0300 Subject: [PATCH 18/39] languages/markdown: add `render-markdown.nvim` as an extension (#517) --- docs/release-notes/rl-0.8.md | 4 +++ flake.lock | 17 +++++++++++ flake.nix | 5 ++++ modules/plugins/languages/markdown.nix | 40 +++++++++++++++++++++++--- 4 files changed, 62 insertions(+), 4 deletions(-) diff --git a/docs/release-notes/rl-0.8.md b/docs/release-notes/rl-0.8.md index 567e4e6e..e41911ba 100644 --- a/docs/release-notes/rl-0.8.md +++ b/docs/release-notes/rl-0.8.md @@ -3,12 +3,16 @@ [NotAShelf](https://github.com/notashelf): [typst-preview.nvim]: https://github.com/chomosuke/typst-preview.nvim +[render-markdown.nvim]: https://github.com/MeanderingProgrammer/render-markdown.nvim - Add [typst-preview.nvim] under `languages.typst.extensions.typst-preview-nvim`. - Add a search widget to the options page in the nvf manual. +- Add [render-markdown.nvim] under + `languages.markdown.extensions.render-markdown-nvim` + [amadaluzia](https://github.com/amadaluzia): [haskell-tools.nvim]: https://github.com/MrcJkb/haskell-tools.nvim diff --git a/flake.lock b/flake.lock index fd404df6..0a7ee1a5 100644 --- a/flake.lock +++ b/flake.lock @@ -1694,6 +1694,22 @@ "type": "github" } }, + "plugin-render-markdown-nvim": { + "flake": false, + "locked": { + "lastModified": 1735525479, + "narHash": "sha256-ncFqBv0JITX3pTsLON+HctLUaKXhLRMBUrRWmI8KOSA=", + "owner": "MeanderingProgrammer", + "repo": "render-markdown.nvim", + "rev": "6fbd1491abc104409f119685de5353c35c97c005", + "type": "github" + }, + "original": { + "owner": "MeanderingProgrammer", + "repo": "render-markdown.nvim", + "type": "github" + } + }, "plugin-rose-pine": { "flake": false, "locked": { @@ -2170,6 +2186,7 @@ "plugin-precognition-nvim": "plugin-precognition-nvim", "plugin-project-nvim": "plugin-project-nvim", "plugin-registers": "plugin-registers", + "plugin-render-markdown-nvim": "plugin-render-markdown-nvim", "plugin-rose-pine": "plugin-rose-pine", "plugin-rtp-nvim": "plugin-rtp-nvim", "plugin-run-nvim": "plugin-run-nvim", diff --git a/flake.nix b/flake.nix index 161ba43f..0fd3cc8c 100644 --- a/flake.nix +++ b/flake.nix @@ -488,6 +488,11 @@ flake = false; }; + plugin-render-markdown-nvim = { + url = "github:MeanderingProgrammer/render-markdown.nvim"; + flake = false; + }; + # Minimap plugin-minimap-vim = { url = "github:wfxr/minimap.vim"; diff --git a/modules/plugins/languages/markdown.nix b/modules/plugins/languages/markdown.nix index e0164771..ab184835 100644 --- a/modules/plugins/languages/markdown.nix +++ b/modules/plugins/languages/markdown.nix @@ -4,13 +4,14 @@ lib, ... }: let - inherit (builtins) attrNames concatLists; + inherit (builtins) attrNames; inherit (lib.modules) mkIf mkMerge; inherit (lib.options) mkEnableOption mkOption; - inherit (lib.lists) isList; + inherit (lib.lists) isList concatLists; inherit (lib.types) bool enum either package listOf str; - inherit (lib.nvim.lua) expToLua; - inherit (lib.nvim.types) mkGrammarOption; + inherit (lib.nvim.lua) expToLua toLuaObject; + inherit (lib.nvim.types) mkGrammarOption mkPluginSetupOption; + inherit (lib.nvim.dag) entryAnywhere; cfg = config.vim.languages.markdown; defaultServer = "marksman"; @@ -98,6 +99,29 @@ in { description = "Extra filetypes to format with the Markdown formatter"; }; }; + + extensions = { + render-markdown-nvim = { + enable = + mkEnableOption "" + // { + description = '' + [render-markdown.nvim]: https://github.com/MeanderingProgrammer/render-markdown.nvim + + Inline Markdown rendering with [render-markdown.nvim] + + ''; + }; + + setupOpts = mkPluginSetupOption "render-markdown" { + auto_override_publish_diagnostics = mkOption { + description = "Automatically override the publish_diagnostics handler"; + type = bool; + default = true; + }; + }; + }; + }; }; config = mkIf cfg.enable (mkMerge [ @@ -115,5 +139,13 @@ in { vim.lsp.null-ls.enable = true; vim.lsp.null-ls.sources.markdown-format = formats.${cfg.format.type}.nullConfig; }) + + # Extensions + (mkIf cfg.extensions.render-markdown-nvim.enable { + vim.startPlugins = ["render-markdown-nvim"]; + vim.pluginRC.render-markdown-nvim = entryAnywhere '' + require("render-markdown").setup(${toLuaObject cfg.extensions.render-markdown-nvim.setupOpts}) + ''; + }) ]); } From f9d1684b5fdd33fbf03069d25105d5147f1b65e1 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Sun, 22 Dec 2024 21:46:17 +0100 Subject: [PATCH 19/39] wrapper: rename build dir to environemnt --- modules/modules.nix | 2 +- modules/wrapper/{build => environment}/config.nix | 0 modules/wrapper/{build => environment}/default.nix | 0 modules/wrapper/{build => environment}/options.nix | 0 4 files changed, 1 insertion(+), 1 deletion(-) rename modules/wrapper/{build => environment}/config.nix (100%) rename modules/wrapper/{build => environment}/default.nix (100%) rename modules/wrapper/{build => environment}/options.nix (100%) diff --git a/modules/modules.nix b/modules/modules.nix index bc441e96..ee37a0e7 100644 --- a/modules/modules.nix +++ b/modules/modules.nix @@ -48,7 +48,7 @@ # The neovim wrapper, used to build a wrapped neovim package # using the configuration passed in `neovim` and `plugins` modules. wrapper = map (p: ./wrapper + "/${p}") [ - "build" + "environment" "rc" "warnings" "lazy" diff --git a/modules/wrapper/build/config.nix b/modules/wrapper/environment/config.nix similarity index 100% rename from modules/wrapper/build/config.nix rename to modules/wrapper/environment/config.nix diff --git a/modules/wrapper/build/default.nix b/modules/wrapper/environment/default.nix similarity index 100% rename from modules/wrapper/build/default.nix rename to modules/wrapper/environment/default.nix diff --git a/modules/wrapper/build/options.nix b/modules/wrapper/environment/options.nix similarity index 100% rename from modules/wrapper/build/options.nix rename to modules/wrapper/environment/options.nix From 26398b6b14bfdf9de261300fde56111ce9c0edcb Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Sun, 22 Dec 2024 21:49:11 +0100 Subject: [PATCH 20/39] wrapper: add built package as option --- modules/modules.nix | 1 + modules/wrapper/build/config.nix | 111 ++++++++++++++++++ modules/wrapper/build/default.nix | 6 + modules/wrapper/build/options.nix | 12 ++ .../build/patches}/flutter-tools.patch | 0 5 files changed, 130 insertions(+) create mode 100644 modules/wrapper/build/config.nix create mode 100644 modules/wrapper/build/default.nix create mode 100644 modules/wrapper/build/options.nix rename {patches => modules/wrapper/build/patches}/flutter-tools.patch (100%) diff --git a/modules/modules.nix b/modules/modules.nix index ee37a0e7..6e05c592 100644 --- a/modules/modules.nix +++ b/modules/modules.nix @@ -48,6 +48,7 @@ # The neovim wrapper, used to build a wrapped neovim package # using the configuration passed in `neovim` and `plugins` modules. wrapper = map (p: ./wrapper + "/${p}") [ + "build" "environment" "rc" "warnings" diff --git a/modules/wrapper/build/config.nix b/modules/wrapper/build/config.nix new file mode 100644 index 00000000..1faa2ccc --- /dev/null +++ b/modules/wrapper/build/config.nix @@ -0,0 +1,111 @@ +{ + inputs, + lib, + config, + pkgs, + ... +} +: let + inherit (pkgs) vimPlugins; + inherit (lib.strings) isString; + inherit (lib.lists) filter map; + + # alias to the internal configuration + vimOptions = config.vim; + + noBuildPlug = {pname, ...} @ attrs: let + src = inputs."plugin-${attrs.pname}"; + in + { + version = src.shortRev or src.shortDirtyRev or "dirty"; + outPath = src; + passthru.vimPlugin = false; + } + // attrs; + + # build a vim plugin with the given name and arguments + # if the plugin is nvim-treesitter, warn the user to use buildTreesitterPlug + # instead + buildPlug = attrs: let + src = inputs."plugin-${attrs.pname}"; + in + pkgs.vimUtils.buildVimPlugin ( + { + version = src.shortRev or src.shortDirtyRev or "dirty"; + inherit src; + } + // attrs + ); + + buildTreesitterPlug = grammars: vimPlugins.nvim-treesitter.withPlugins (_: grammars); + + pluginBuilders = { + nvim-treesitter = buildTreesitterPlug vimOptions.treesitter.grammars; + flutter-tools-patched = buildPlug { + pname = "flutter-tools"; + patches = [./patches/flutter-tools.patch]; + }; + }; + + buildConfigPlugins = plugins: + map ( + plug: + if (isString plug) + then pluginBuilders.${plug} or (noBuildPlug {pname = plug;}) + else plug + ) (filter (f: f != null) plugins); + + # built (or "normalized") plugins that are modified + builtStartPlugins = buildConfigPlugins vimOptions.startPlugins; + builtOptPlugins = map (package: package // {optional = true;}) (buildConfigPlugins vimOptions.optPlugins); + + # additional Lua and Python3 packages, mapped to their respective functions + # to conform to the format mnw expects. end user should + # only ever need to pass a list of packages, which are modified + # here + extraLuaPackages = ps: map (x: ps.${x}) vimOptions.luaPackages; + extraPython3Packages = ps: map (x: ps.${x}) vimOptions.python3Packages; + + # Wrap the user's desired (unwrapped) Neovim package with arguments that'll be used to + # generate a wrapped Neovim package. + neovim-wrapped = inputs.mnw.lib.wrap pkgs { + neovim = vimOptions.package; + plugins = builtStartPlugins ++ builtOptPlugins; + appName = "nvf"; + extraBinPath = vimOptions.extraPackages; + initLua = vimOptions.builtLuaConfigRC; + luaFiles = vimOptions.extraLuaFiles; + + inherit (vimOptions) viAlias vimAlias withRuby withNodeJs withPython3; + inherit extraLuaPackages extraPython3Packages; + }; + + dummyInit = pkgs.writeText "nvf-init.lua" vimOptions.builtLuaConfigRC; + # Additional helper scripts for printing and displaying nvf configuration + # in your commandline. + printConfig = pkgs.writers.writeDashBin "nvf-print-config" "cat ${dummyInit}"; + printConfigPath = pkgs.writers.writeDashBin "nvf-print-config-path" "echo -n ${dummyInit}"; + + # Expose wrapped neovim-package for userspace + # or module consumption. + neovim = pkgs.symlinkJoin { + name = "nvf-with-helpers"; + paths = [neovim-wrapped printConfig printConfigPath]; + postBuild = "echo Helpers added"; + + # Allow evaluating vimOptions, i.e., config.vim from the packages' passthru + # attribute. For example, packages.x86_64-linux.neovim.passthru.neovimConfig + # will return the configuration in full. + passthru.neovimConfig = vimOptions; + + meta = + neovim-wrapped.meta + // { + description = "Wrapped Neovim package with helper scripts to print the config (path)"; + }; + }; +in { + config.vim.build = { + finalPackage = neovim; + }; +} diff --git a/modules/wrapper/build/default.nix b/modules/wrapper/build/default.nix new file mode 100644 index 00000000..0ebefe45 --- /dev/null +++ b/modules/wrapper/build/default.nix @@ -0,0 +1,6 @@ +{ + imports = [ + ./options.nix + ./config.nix + ]; +} diff --git a/modules/wrapper/build/options.nix b/modules/wrapper/build/options.nix new file mode 100644 index 00000000..fa1db61e --- /dev/null +++ b/modules/wrapper/build/options.nix @@ -0,0 +1,12 @@ +{lib, ...}: let + inherit (lib.types) package; + inherit (lib.options) mkOption; +in { + options.vim.build = { + finalPackage = mkOption { + type = package; + readOnly = true; + description = "final output package"; + }; + }; +} diff --git a/patches/flutter-tools.patch b/modules/wrapper/build/patches/flutter-tools.patch similarity index 100% rename from patches/flutter-tools.patch rename to modules/wrapper/build/patches/flutter-tools.patch From 7d043e5f14cb6e2639f6266adbb9381cdc6cf6bf Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Sun, 22 Dec 2024 21:50:13 +0100 Subject: [PATCH 21/39] home-manager: use proper submodule type for settings --- flake.nix | 2 +- flake/modules/home-manager.nix | 22 +++++++++++++--------- 2 files changed, 14 insertions(+), 10 deletions(-) diff --git a/flake.nix b/flake.nix index 0fd3cc8c..7cbcfeeb 100644 --- a/flake.nix +++ b/flake.nix @@ -31,7 +31,7 @@ }; homeManagerModules = { - nvf = import ./flake/modules/home-manager.nix self.packages lib; + nvf = import ./flake/modules/home-manager.nix self.packages lib inputs; default = self.homeManagerModules.nvf; neovim-flake = lib.warn '' diff --git a/flake/modules/home-manager.nix b/flake/modules/home-manager.nix index 77b8448c..d1e85368 100644 --- a/flake/modules/home-manager.nix +++ b/flake/modules/home-manager.nix @@ -1,5 +1,5 @@ # Home Manager module -packages: lib: { +packages: lib: inputs: { config, pkgs, ... @@ -8,15 +8,19 @@ packages: lib: { inherit (lib.modules) mkIf mkAliasOptionModule; inherit (lib.lists) optional; inherit (lib.options) mkOption mkEnableOption literalExpression; - inherit (lib.types) attrsOf anything bool; - inherit (lib.nvim) neovimConfiguration; - inherit (lib.nvim.types) anythingConcatLists; + inherit (lib.types) anything bool submoduleWith; cfg = config.programs.nvf; - neovimConfigured = neovimConfiguration { - inherit pkgs; - modules = [cfg.settings]; + nvfModule = submoduleWith { + description = "Nvf module"; + class = "nvf"; + specialArgs = { + inherit pkgs lib inputs; + }; + modules = [ + {imports = import ../../modules/modules.nix {inherit pkgs lib;};} + ]; }; in { imports = [ @@ -55,7 +59,7 @@ in { }; settings = mkOption { - type = attrsOf anythingConcatLists; + type = nvfModule; default = {}; description = "Attribute set of nvf preferences."; example = literalExpression '' @@ -78,7 +82,7 @@ in { }; config = mkIf cfg.enable { - programs.nvf.finalPackage = neovimConfigured.neovim; + programs.nvf.finalPackage = cfg.settings.vim.build.finalPackage; home = { sessionVariables = mkIf cfg.defaultEditor {EDITOR = "nvim";}; From 8c1352502a3cb7a30c8cc015fb65f3b6c884a28d Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Sun, 22 Dec 2024 21:59:24 +0100 Subject: [PATCH 22/39] module: remove redundant code the bulk of the build step is moved to modules/wrapper/build --- modules/default.nix | 105 ++++---------------------------------------- 1 file changed, 9 insertions(+), 96 deletions(-) diff --git a/modules/default.nix b/modules/default.nix index a2f8730d..a207e0d1 100644 --- a/modules/default.nix +++ b/modules/default.nix @@ -9,9 +9,8 @@ extraModules ? [], configuration ? {}, }: let - inherit (pkgs) vimPlugins; - inherit (lib.strings) isString toString; - inherit (lib.lists) filter map concatLists; + inherit (lib.strings) toString; + inherit (lib.lists) concatLists; # import modules.nix with `check`, `pkgs` and `lib` as arguments # check can be disabled while calling this file is called @@ -21,7 +20,12 @@ # evaluate the extended library with the modules # optionally with any additional modules passed by the user module = lib.evalModules { - specialArgs = extraSpecialArgs // {modulesPath = toString ./.;}; + specialArgs = + extraSpecialArgs + // { + inherit inputs; + modulesPath = toString ./.; + }; modules = concatLists [ nvimModules modules @@ -36,102 +40,11 @@ extraModules)) ]; }; - - # alias to the internal configuration - vimOptions = module.config.vim; - - noBuildPlug = {pname, ...} @ attrs: let - src = inputs."plugin-${attrs.pname}"; - in - { - version = src.shortRev or src.shortDirtyRev or "dirty"; - outPath = src; - passthru.vimPlugin = false; - } - // attrs; - - # build a vim plugin with the given name and arguments - # if the plugin is nvim-treesitter, warn the user to use buildTreesitterPlug - # instead - buildPlug = attrs: let - src = inputs."plugin-${attrs.pname}"; - in - pkgs.vimUtils.buildVimPlugin ( - { - version = src.shortRev or src.shortDirtyRev or "dirty"; - inherit src; - } - // attrs - ); - - buildTreesitterPlug = grammars: vimPlugins.nvim-treesitter.withPlugins (_: grammars); - - pluginBuilders = { - nvim-treesitter = buildTreesitterPlug vimOptions.treesitter.grammars; - flutter-tools-patched = buildPlug { - pname = "flutter-tools"; - patches = [../patches/flutter-tools.patch]; - }; - }; - - buildConfigPlugins = plugins: - map ( - plug: - if (isString plug) - then pluginBuilders.${plug} or (noBuildPlug {pname = plug;}) - else plug - ) (filter (f: f != null) plugins); - - # built (or "normalized") plugins that are modified - builtStartPlugins = buildConfigPlugins vimOptions.startPlugins; - builtOptPlugins = map (package: package // {optional = true;}) (buildConfigPlugins vimOptions.optPlugins); - - # additional Lua and Python3 packages, mapped to their respective functions - # to conform to the format mnw expects. end user should - # only ever need to pass a list of packages, which are modified - # here - extraLuaPackages = ps: map (x: ps.${x}) vimOptions.luaPackages; - extraPython3Packages = ps: map (x: ps.${x}) vimOptions.python3Packages; - - # Wrap the user's desired (unwrapped) Neovim package with arguments that'll be used to - # generate a wrapped Neovim package. - neovim-wrapped = inputs.mnw.lib.wrap pkgs { - neovim = vimOptions.package; - plugins = builtStartPlugins ++ builtOptPlugins; - appName = "nvf"; - extraBinPath = vimOptions.extraPackages; - initLua = vimOptions.builtLuaConfigRC; - luaFiles = vimOptions.extraLuaFiles; - - inherit (vimOptions) viAlias vimAlias withRuby withNodeJs withPython3; - inherit extraLuaPackages extraPython3Packages; - }; - - dummyInit = pkgs.writeText "nvf-init.lua" vimOptions.builtLuaConfigRC; - # Additional helper scripts for printing and displaying nvf configuration - # in your commandline. - printConfig = pkgs.writers.writeDashBin "nvf-print-config" "cat ${dummyInit}"; - printConfigPath = pkgs.writers.writeDashBin "nvf-print-config-path" "echo -n ${dummyInit}"; in { inherit (module) options config; inherit (module._module.args) pkgs; # Expose wrapped neovim-package for userspace # or module consumption. - neovim = pkgs.symlinkJoin { - name = "nvf-with-helpers"; - paths = [neovim-wrapped printConfig printConfigPath]; - postBuild = "echo Helpers added"; - - # Allow evaluating vimOptions, i.e., config.vim from the packages' passthru - # attribute. For example, packages.x86_64-linux.neovim.passthru.neovimConfig - # will return the configuration in full. - passthru.neovimConfig = vimOptions; - - meta = - neovim-wrapped.meta - // { - description = "Wrapped Neovim package with helper scripts to print the config (path)"; - }; - }; + neovim = module.config.vim.build.finalPackage; } From 98b36e08f0311a9c95076cd28cd483ed398ddb1e Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Sun, 22 Dec 2024 23:05:06 +0100 Subject: [PATCH 23/39] nixos: use proper submodule type for settings --- flake.nix | 2 +- flake/modules/nixos.nix | 22 +++++++++++++--------- 2 files changed, 14 insertions(+), 10 deletions(-) diff --git a/flake.nix b/flake.nix index 7cbcfeeb..36929113 100644 --- a/flake.nix +++ b/flake.nix @@ -42,7 +42,7 @@ }; nixosModules = { - nvf = import ./flake/modules/nixos.nix self.packages lib; + nvf = import ./flake/modules/nixos.nix self.packages lib inputs; default = self.nixosModules.nvf; neovim-flake = lib.warn '' diff --git a/flake/modules/nixos.nix b/flake/modules/nixos.nix index 022b3d94..b4957700 100644 --- a/flake/modules/nixos.nix +++ b/flake/modules/nixos.nix @@ -1,5 +1,5 @@ # NixOS module -packages: lib: { +packages: lib: inputs: { config, pkgs, ... @@ -8,15 +8,19 @@ packages: lib: { inherit (lib.modules) mkIf mkOverride mkAliasOptionModule; inherit (lib.lists) optional; inherit (lib.options) mkOption mkEnableOption literalExpression; - inherit (lib.types) attrsOf anything bool; - inherit (lib.nvim) neovimConfiguration; - inherit (lib.nvim.types) anythingConcatLists; + inherit (lib.types) anything bool submoduleWith; cfg = config.programs.nvf; - neovimConfigured = neovimConfiguration { - inherit pkgs; - modules = [cfg.settings]; + nvfModule = submoduleWith { + description = "Nvf module"; + class = "nvf"; + specialArgs = { + inherit pkgs lib inputs; + }; + modules = [ + {imports = import ../../modules/modules.nix {inherit pkgs lib;};} + ]; }; in { imports = [ @@ -55,7 +59,7 @@ in { }; settings = mkOption { - type = attrsOf anythingConcatLists; + type = nvfModule; default = {}; description = "Attribute set of nvf preferences."; example = literalExpression '' @@ -78,7 +82,7 @@ in { }; config = mkIf cfg.enable { - programs.nvf.finalPackage = neovimConfigured.neovim; + programs.nvf.finalPackage = cfg.settings.vim.build.finalPackage; environment = { variables.EDITOR = mkIf cfg.defaultEditor (mkOverride 900 "nvim"); From 411e641eab7634ec20c2328b004879acd3d0539e Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Sun, 22 Dec 2024 23:00:26 +0100 Subject: [PATCH 24/39] lib: remove anythingConcatLists --- lib/types/custom.nix | 55 +++---------------------------------------- lib/types/default.nix | 2 +- 2 files changed, 4 insertions(+), 53 deletions(-) diff --git a/lib/types/custom.nix b/lib/types/custom.nix index 3d4a2bcb..c42cd2ce 100644 --- a/lib/types/custom.nix +++ b/lib/types/custom.nix @@ -1,57 +1,8 @@ {lib}: let - inherit (lib.options) showOption showFiles getFiles mergeOneOption mergeEqualOption; - inherit (lib.strings) isString isStringLike; - inherit (lib.types) anything attrsOf listOf mkOptionType; - inherit (lib.nvim.types) anythingConcatLists; - inherit (builtins) typeOf isAttrs any head concatLists stringLength match; + inherit (lib.options) mergeEqualOption; + inherit (lib.strings) isString stringLength match; + inherit (lib.types) listOf mkOptionType; in { - # HACK: Does this break anything in our case? - # A modified version of the nixpkgs anything type that concatenates lists - # This isn't the default because the order in which the lists are concatenated depends on the order in which the modules are imported, - # which makes it non-deterministic - anythingConcatLists = - anything - // { - merge = loc: defs: let - getType = value: - if isAttrs value && isStringLike value - then "stringCoercibleSet" - else typeOf value; - - # Throw an error if not all defs have the same type - checkType = getType (head defs).value; - commonType = - if any (def: getType def.value != checkType) defs - then throw "The option `${showOption loc}' has conflicting option types in ${showFiles (getFiles defs)}" - else checkType; - - mergeFunctions = { - # Recursively merge attribute sets - set = (attrsOf anythingConcatLists).merge; - - # Overridden behavior for lists, that concatenates lists - list = _: defs: concatLists (map (e: e.value) defs); - - # This means it's a package, only accept a single definition - stringCoercibleSet = mergeOneOption; - - # This works by passing the argument to the functions, - # and merging their returns values instead - lambda = loc: defs: arg: - anythingConcatLists.merge - (loc ++ [""]) - (map (def: { - inherit (def) file; - value = def.value arg; - }) - defs); - }; - in - # Merge the defs with the correct function from above, if available - # otherwise only allow equal values - (mergeFunctions.${commonType} or mergeEqualOption) loc defs; - }; - mergelessListOf = elemType: let super = listOf elemType; in diff --git a/lib/types/default.nix b/lib/types/default.nix index 73b35956..c1c16715 100644 --- a/lib/types/default.nix +++ b/lib/types/default.nix @@ -11,5 +11,5 @@ in { inherit (typesDag) dagOf; inherit (typesPlugin) pluginsOpt extraPluginType mkPluginSetupOption luaInline pluginType borderType; inherit (typesLanguage) diagnostics mkGrammarOption; - inherit (customTypes) anythingConcatLists char hexColor mergelessListOf; + inherit (customTypes) char hexColor mergelessListOf; } From 9ccd0bfd4eda390415b8664f4155f148e4bbf13c Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Sun, 29 Dec 2024 18:20:51 +0100 Subject: [PATCH 25/39] home-manager: remove redundant import module --- flake/modules/home-manager.nix | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/flake/modules/home-manager.nix b/flake/modules/home-manager.nix index d1e85368..c109e774 100644 --- a/flake/modules/home-manager.nix +++ b/flake/modules/home-manager.nix @@ -18,9 +18,7 @@ packages: lib: inputs: { specialArgs = { inherit pkgs lib inputs; }; - modules = [ - {imports = import ../../modules/modules.nix {inherit pkgs lib;};} - ]; + modules = import ../../modules/modules.nix {inherit pkgs lib;}; }; in { imports = [ From 59bf01bbe09d4f85543c106dc47da0cde45d22c1 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Sun, 29 Dec 2024 18:25:20 +0100 Subject: [PATCH 26/39] nixos: remove redundant import module --- flake/modules/nixos.nix | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/flake/modules/nixos.nix b/flake/modules/nixos.nix index b4957700..b53d4fc9 100644 --- a/flake/modules/nixos.nix +++ b/flake/modules/nixos.nix @@ -18,9 +18,7 @@ packages: lib: inputs: { specialArgs = { inherit pkgs lib inputs; }; - modules = [ - {imports = import ../../modules/modules.nix {inherit pkgs lib;};} - ]; + modules = import ../../modules/modules.nix {inherit pkgs lib;}; }; in { imports = [ From fcbc49e2e56b701bc42e6e02459e321be1f64faf Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Sun, 29 Dec 2024 18:46:55 +0100 Subject: [PATCH 27/39] home-manager: use attr for long function args --- flake.nix | 2 +- flake/modules/home-manager.nix | 6 +++++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/flake.nix b/flake.nix index 36929113..53e592aa 100644 --- a/flake.nix +++ b/flake.nix @@ -31,7 +31,7 @@ }; homeManagerModules = { - nvf = import ./flake/modules/home-manager.nix self.packages lib inputs; + nvf = import ./flake/modules/home-manager.nix {inherit lib self;}; default = self.homeManagerModules.nvf; neovim-flake = lib.warn '' diff --git a/flake/modules/home-manager.nix b/flake/modules/home-manager.nix index c109e774..715f7537 100644 --- a/flake/modules/home-manager.nix +++ b/flake/modules/home-manager.nix @@ -1,9 +1,13 @@ # Home Manager module -packages: lib: inputs: { +{ + self, + lib, +}: { config, pkgs, ... }: let + inherit (self) packages inputs; inherit (lib) maintainers; inherit (lib.modules) mkIf mkAliasOptionModule; inherit (lib.lists) optional; From ecc9b60a2d1555ef04490fe25444636b0907cde2 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Sun, 29 Dec 2024 18:47:22 +0100 Subject: [PATCH 28/39] nixos: use attrset for long function args --- flake.nix | 2 +- flake/modules/nixos.nix | 6 +++++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/flake.nix b/flake.nix index 53e592aa..d5a7b709 100644 --- a/flake.nix +++ b/flake.nix @@ -42,7 +42,7 @@ }; nixosModules = { - nvf = import ./flake/modules/nixos.nix self.packages lib inputs; + nvf = import ./flake/modules/nixos.nix {inherit lib self;}; default = self.nixosModules.nvf; neovim-flake = lib.warn '' diff --git a/flake/modules/nixos.nix b/flake/modules/nixos.nix index b53d4fc9..ecc173a1 100644 --- a/flake/modules/nixos.nix +++ b/flake/modules/nixos.nix @@ -1,9 +1,13 @@ # NixOS module -packages: lib: inputs: { +{ + self, + lib, +}: { config, pkgs, ... }: let + inherit (self) inputs packages; inherit (lib) maintainers; inherit (lib.modules) mkIf mkOverride mkAliasOptionModule; inherit (lib.lists) optional; From af0eed84e06784b6c86abe78be5ed454ac2a5ea0 Mon Sep 17 00:00:00 2001 From: diniamo Date: Wed, 1 Jan 2025 12:59:13 +0100 Subject: [PATCH 29/39] wrapper/build: improve noBuildPlug --- modules/wrapper/build/config.nix | 31 ++++++++++++++++++------------- 1 file changed, 18 insertions(+), 13 deletions(-) diff --git a/modules/wrapper/build/config.nix b/modules/wrapper/build/config.nix index 1faa2ccc..ee5b4fda 100644 --- a/modules/wrapper/build/config.nix +++ b/modules/wrapper/build/config.nix @@ -9,30 +9,35 @@ inherit (pkgs) vimPlugins; inherit (lib.strings) isString; inherit (lib.lists) filter map; + inherit (builtins) path; # alias to the internal configuration vimOptions = config.vim; - noBuildPlug = {pname, ...} @ attrs: let - src = inputs."plugin-${attrs.pname}"; - in - { - version = src.shortRev or src.shortDirtyRev or "dirty"; - outPath = src; - passthru.vimPlugin = false; - } - // attrs; + noBuildPlug = pname: let + input = inputs."plugin-${pname}"; + version = input.shortRev or input.shortDirtyRev or "dirty"; + in { + # vim.lazy.plugins relies on pname, so we only set that here + # version isn't needed for anything, but inherit it anyway for correctness + inherit pname version; + outPath = path { + name = "${pname}-0-unstable-${version}"; + path = input.outPath; + }; + passthru.vimPlugin = false; + }; # build a vim plugin with the given name and arguments # if the plugin is nvim-treesitter, warn the user to use buildTreesitterPlug # instead buildPlug = attrs: let - src = inputs."plugin-${attrs.pname}"; + input = inputs."plugin-${attrs.pname}"; in pkgs.vimUtils.buildVimPlugin ( { - version = src.shortRev or src.shortDirtyRev or "dirty"; - inherit src; + version = input.shortRev or input.shortDirtyRev or "dirty"; + src = input.outPath; } // attrs ); @@ -51,7 +56,7 @@ map ( plug: if (isString plug) - then pluginBuilders.${plug} or (noBuildPlug {pname = plug;}) + then pluginBuilders.${plug} or (noBuildPlug plug) else plug ) (filter (f: f != null) plugins); From fcc6aa485cca678c063cca1b85bafe78af8d1e49 Mon Sep 17 00:00:00 2001 From: NotAShelf Date: Sat, 4 Jan 2025 15:29:11 +0300 Subject: [PATCH 30/39] utility/wakatime: move plugin options to `vim.globals`; cleanup --- modules/plugins/utility/wakatime/config.nix | 14 +++++++++----- modules/plugins/utility/wakatime/default.nix | 2 +- modules/plugins/utility/wakatime/vim-wakatime.nix | 14 ++++++++++---- 3 files changed, 20 insertions(+), 10 deletions(-) diff --git a/modules/plugins/utility/wakatime/config.nix b/modules/plugins/utility/wakatime/config.nix index a1892e7b..675f0034 100644 --- a/modules/plugins/utility/wakatime/config.nix +++ b/modules/plugins/utility/wakatime/config.nix @@ -1,18 +1,22 @@ { config, - lib, pkgs, + lib, ... }: let inherit (lib.modules) mkIf; + inherit (lib.meta) getExe; cfg = config.vim.utility.vim-wakatime; in { config = mkIf cfg.enable { - vim.startPlugins = [pkgs.vimPlugins.vim-wakatime]; + vim = { + startPlugins = [pkgs.vimPlugins.vim-wakatime]; - vim.pluginRC.vim-wakatime = mkIf (cfg.cli-package != null) '' - vim.g.wakatime_CLIPath = "${cfg.cli-package}" - ''; + # Wakatime configuration is stored as vim globals. + globals = { + "wakatime_CLIPath" = mkIf (cfg.cli-package != null) "${getExe cfg.cli-package}"; + }; + }; }; } diff --git a/modules/plugins/utility/wakatime/default.nix b/modules/plugins/utility/wakatime/default.nix index d6d67d57..c72189d5 100644 --- a/modules/plugins/utility/wakatime/default.nix +++ b/modules/plugins/utility/wakatime/default.nix @@ -1,4 +1,4 @@ -_: { +{ imports = [ ./config.nix ./vim-wakatime.nix diff --git a/modules/plugins/utility/wakatime/vim-wakatime.nix b/modules/plugins/utility/wakatime/vim-wakatime.nix index 6b853821..04f27868 100644 --- a/modules/plugins/utility/wakatime/vim-wakatime.nix +++ b/modules/plugins/utility/wakatime/vim-wakatime.nix @@ -1,18 +1,24 @@ { - lib, pkgs, + lib, ... }: let inherit (lib.options) mkEnableOption mkOption; inherit (lib.types) nullOr package; in { options.vim.utility.vim-wakatime = { - enable = mkEnableOption "vim-wakatime: live code statistics"; + enable = mkEnableOption '' + automatic time tracking and metrics generated from your programming activity [vim-wakatime] + ''; cli-package = mkOption { type = nullOr package; - default = pkgs.wakatime; - description = "The package that should be used for wakatime-cli. Set as null to use the default path in `$XDG_DATA_HOME`"; + default = pkgs.wakatime-cli; + example = null; + description = '' + The package that should be used for wakatime-cli. + Set as null to use the default path in {env}`$XDG_DATA_HOME` + ''; }; }; } From eb6e8b17b7beffd3792d898e30b0e9cd80de06ae Mon Sep 17 00:00:00 2001 From: NotAShelf Date: Sat, 4 Jan 2025 15:35:55 +0300 Subject: [PATCH 31/39] docs: clean up module installation chapters --- docs/manual/installation/modules/home-manager.md | 9 ++++++--- docs/manual/installation/modules/nixos.md | 7 +++---- 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/docs/manual/installation/modules/home-manager.md b/docs/manual/installation/modules/home-manager.md index a2170159..cf56acc3 100644 --- a/docs/manual/installation/modules/home-manager.md +++ b/docs/manual/installation/modules/home-manager.md @@ -44,12 +44,15 @@ Followed by importing the home-manager module somewhere in your configuration. }; outputs = { nixpkgs, home-manager, nvf, ... }: let - system = "x86_64-linux"; in { + system = "x86_64-linux"; + pkgs = nixpkgs.legacyPackages.${system}; + in { # ↓ this is your home output in the flake schema, expected by home-manager - "your-username@your-hostname" = home-manager.lib.homeManagerConfiguration + "your-username@your-hostname" = home-manager.lib.homeManagerConfiguration { + inherit pkgs; modules = [ nvf.homeManagerModules.default # <- this imports the home-manager module that provides the options - ./home.nix # <- your home entrypoint + ./home.nix # <- your home entrypoint, `programs.nvf.*` may be defined here ]; }; }; diff --git a/docs/manual/installation/modules/nixos.md b/docs/manual/installation/modules/nixos.md index d8be2035..ae5ce939 100644 --- a/docs/manual/installation/modules/nixos.md +++ b/docs/manual/installation/modules/nixos.md @@ -42,13 +42,12 @@ Followed by importing the NixOS module somewhere in your configuration. nvf.url = "github:notashelf/nvf"; }; - outputs = { nixpkgs, nvf, ... }: let - system = "x86_64-linux"; in { + outputs = { nixpkgs, nvf, ... }: { # ↓ this is your host output in the flake schema - nixosConfigurations."yourUsername»" = nixpkgs.lib.nixosSystem { + nixosConfigurations."your-hostname" = nixpkgs.lib.nixosSystem { modules = [ nvf.nixosModules.default # <- this imports the NixOS module that provides the options - ./configuration.nix # <- your host entrypoint + ./configuration.nix # <- your host entrypoint, `programs.nvf.*` may be defined here ]; }; }; From 9584fe25e29fe7c6540f4cac55381e9ba25cf43d Mon Sep 17 00:00:00 2001 From: raf Date: Sun, 5 Jan 2025 11:35:09 +0300 Subject: [PATCH 32/39] docs: add helpful tips section (#520) --- docs/manual/manual.md | 1 + docs/manual/tips.md | 6 ++++++ docs/manual/tips/debugging-nvf.md | 19 +++++++++++++++++++ docs/manual/tips/offline-docs.md | 11 +++++++++++ 4 files changed, 37 insertions(+) create mode 100644 docs/manual/tips.md create mode 100644 docs/manual/tips/debugging-nvf.md create mode 100644 docs/manual/tips/offline-docs.md diff --git a/docs/manual/manual.md b/docs/manual/manual.md index fd7ddcd9..fd225766 100644 --- a/docs/manual/manual.md +++ b/docs/manual/manual.md @@ -11,6 +11,7 @@ try-it-out.md default-configs.md installation.md configuring.md +tips.md ``` ```{=include=} chapters diff --git a/docs/manual/tips.md b/docs/manual/tips.md new file mode 100644 index 00000000..0d2637f1 --- /dev/null +++ b/docs/manual/tips.md @@ -0,0 +1,6 @@ +# Helpful Tips {#ch-helpful-tips} + +```{=include=} chapters +tips/debugging-nvf.md +tips/offline-docs.md +``` diff --git a/docs/manual/tips/debugging-nvf.md b/docs/manual/tips/debugging-nvf.md new file mode 100644 index 00000000..a642b0a7 --- /dev/null +++ b/docs/manual/tips/debugging-nvf.md @@ -0,0 +1,19 @@ +# Debugging nvf {#sec-debugging-nvf} + +There may be instances where the your Nix configuration evaluates to invalid +Lua, or times when you will be asked to provide your built Lua configuration for +easier debugging by nvf maintainers. nvf provides two helpful utilities out of +the box. + +**nvf-print-config** and **nvf-print-config-path** will be bundled with nvf as +lightweight utilities to help you view or share your built configuration when +necessary. + +To view your configuration with syntax highlighting, you may use the +[bat pager](https://github.com/sharkdp/bat). + +```bash +nvf-print-config | bat --language=lua +``` + +Alternatively, `cat` or `less` may also be used. diff --git a/docs/manual/tips/offline-docs.md b/docs/manual/tips/offline-docs.md new file mode 100644 index 00000000..ed11d965 --- /dev/null +++ b/docs/manual/tips/offline-docs.md @@ -0,0 +1,11 @@ +# Offline Documentation {#sec-offline-documentation} + +[https://notashelf.github.io/nvf/options.html]: https://notashelf.github.io/nvf/options.html + +The manpages provided by nvf contains an offline version of the option search +normally available at [https://notashelf.github.io/nvf/options.html]. You may +use the `man 5 nvf` command to view option documentation from the comfort of +your terminal. + +Note that this is only available for NixOS and Home-Manager module +installations. From b7bea89d9ab669c8ead928c5e087dedcfbb32202 Mon Sep 17 00:00:00 2001 From: NotAShelf Date: Sun, 5 Jan 2025 11:36:01 +0300 Subject: [PATCH 33/39] docs: update contributors section; add maintainers --- .github/README.md | 36 ++++++++++++++++++++++-------------- 1 file changed, 22 insertions(+), 14 deletions(-) diff --git a/.github/README.md b/.github/README.md index 5d10c73f..0c2036d2 100644 --- a/.github/README.md +++ b/.github/README.md @@ -206,6 +206,16 @@ features. ## Credits +### Co-Maintainers + +Alongside myself, nvf is developed by those talented folk: + +- [**@horriblename**](https://github.com/horriblename) - For actively + implementing planned features and quality of life updates. +- [**@Diniamo**](https://github.com/Diniamo) + ([Liberapay](https://en.liberapay.com/diniamo/)) - For actively submitting + pull requests, issues and assistance with maintenance of nvf. + ### Contributors [mnw]: https://github.com/gerg-l/mnw @@ -213,21 +223,19 @@ features. nvf would not be what it is today without the awesome people below. Special, heart-felt thanks to -- [@fufexan](https://github.com/fufexan) - For the transition to flake-parts and - invaluable Nix assistance. -- [@FlafyDev](https://github.com/FlafyDev) - For getting home-manager module to - work and Nix assistance. -- [@n3oney](https://github.com/n3oney) - For making custom keybinds finally +- [**@fufexan**](https://github.com/fufexan) - For the transition to flake-parts + and invaluable Nix assistance. +- [**@FlafyDev**](https://github.com/FlafyDev) - For getting Home-Manager module + to work and Nix assistance. +- [**@n3oney**](https://github.com/n3oney) - For making custom keybinds finally possible, and other module additions. -- [@horriblename](https://github.com/horriblename) - For actively implementing - planned features and quality of life updates. -- [@Yavko](https://github.com/Yavko) - For the amazing **nvf** logo -- [@FrothyMarrow](https://github.com/FrothyMarrow) - For seeing mistakes that I - could not. -- [@Diniamo](https://github.com/Diniamo) - For actively submitting pull - requests, issues and assistance with maintenance of nvf. -- [@Gerg-l](https://github.com/gerg-l) - For the modern Neovim wrapper, [mnw], - and occasional code improvements. +- [**@Yavko**](https://github.com/Yavko) - For the amazing **nvf** logo +- [**@FrothyMarrow**](https://github.com/FrothyMarrow) - For seeing mistakes + that I could not. +- [**@Gerg-l**](https://github.com/gerg-l) 🐸 - For the modern Neovim wrapper, + [mnw], and occasional code improvements. +- [**@Soliprem**](https://github.com/soliprem) - Rigorously implementing missing + features and excellent work on new language modules. and everyone who has submitted issues or pull requests! From 9888a277adc8a34aa13e9f6bb75c9c86b4f2919a Mon Sep 17 00:00:00 2001 From: raf Date: Mon, 6 Jan 2025 03:54:38 +0300 Subject: [PATCH 34/39] git/gitsigns: migrate to `setupOpts` (#524) * git/gitsigns: add `setupOpts` module option for user-specified setup table * docs: update v0.8 release notes --- docs/release-notes/rl-0.8.md | 3 +++ modules/plugins/git/gitsigns/config.nix | 3 ++- modules/plugins/git/gitsigns/gitsigns.nix | 2 ++ 3 files changed, 7 insertions(+), 1 deletion(-) diff --git a/docs/release-notes/rl-0.8.md b/docs/release-notes/rl-0.8.md index e41911ba..16ec2863 100644 --- a/docs/release-notes/rl-0.8.md +++ b/docs/release-notes/rl-0.8.md @@ -13,6 +13,9 @@ - Add [render-markdown.nvim] under `languages.markdown.extensions.render-markdown-nvim` +- Implement [](#opt-vim.git.gitsigns.setupOpts) for user-specified setup table + in gitsigns configuration. + [amadaluzia](https://github.com/amadaluzia): [haskell-tools.nvim]: https://github.com/MrcJkb/haskell-tools.nvim diff --git a/modules/plugins/git/gitsigns/config.nix b/modules/plugins/git/gitsigns/config.nix index 039ab635..9aee73b7 100644 --- a/modules/plugins/git/gitsigns/config.nix +++ b/modules/plugins/git/gitsigns/config.nix @@ -7,6 +7,7 @@ inherit (lib.modules) mkIf mkMerge; inherit (lib.nvim.binds) addDescriptionsToMappings mkSetExprBinding mkSetLuaBinding pushDownDefault; inherit (lib.nvim.dag) entryAnywhere; + inherit (lib.nvim.lua) toLuaObject; cfg = config.vim.git.gitsigns; @@ -70,7 +71,7 @@ in { }; pluginRC.gitsigns = entryAnywhere '' - require('gitsigns').setup{} + require('gitsigns').setup(${toLuaObject cfg.setupOpts}) ''; }; } diff --git a/modules/plugins/git/gitsigns/gitsigns.nix b/modules/plugins/git/gitsigns/gitsigns.nix index ef880bce..9c2375d8 100644 --- a/modules/plugins/git/gitsigns/gitsigns.nix +++ b/modules/plugins/git/gitsigns/gitsigns.nix @@ -6,6 +6,7 @@ inherit (lib.options) mkEnableOption; inherit (lib.modules) mkRenamedOptionModule; inherit (lib.nvim.binds) mkMappingOption; + inherit (lib.nvim.types) mkPluginSetupOption; in { imports = [ (mkRenamedOptionModule ["vim" "git" "gitsigns" "codeActions" "vim" "gitsigns" "codeActions"] ["vim" "git" "gitsigns" "codeActions" "enable"]) @@ -13,6 +14,7 @@ in { options.vim.git.gitsigns = { enable = mkEnableOption "gitsigns" // {default = config.vim.git.enable;}; + setupOpts = mkPluginSetupOption "gitsigns" {}; codeActions.enable = mkEnableOption "gitsigns codeactions through null-ls"; From ee4c072ba326b1e7765e500b2aac3281ffb0019f Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 6 Jan 2025 11:44:38 +0100 Subject: [PATCH 35/39] flake: add aerial.nvim --- flake.lock | 17 +++++++++++++++++ flake.nix | 5 +++++ 2 files changed, 22 insertions(+) diff --git a/flake.lock b/flake.lock index 0a7ee1a5..4b56f7fa 100644 --- a/flake.lock +++ b/flake.lock @@ -156,6 +156,22 @@ "type": "sourcehut" } }, + "plugin-aerial-nvim": { + "flake": false, + "locked": { + "lastModified": 1736064692, + "narHash": "sha256-7YQtkUTACTMfAGoqoFDPmRrqtw+ypxDbeLCTB3sy4Us=", + "owner": "stevearc", + "repo": "aerial.nvim", + "rev": "b3ec25ca8c347fafa976484a6cace162239112e1", + "type": "github" + }, + "original": { + "owner": "stevearc", + "repo": "aerial.nvim", + "type": "github" + } + }, "plugin-alpha-nvim": { "flake": false, "locked": { @@ -2090,6 +2106,7 @@ "nil": "nil", "nixpkgs": "nixpkgs", "nmd": "nmd", + "plugin-aerial-nvim": "plugin-aerial-nvim", "plugin-alpha-nvim": "plugin-alpha-nvim", "plugin-base16": "plugin-base16", "plugin-bufdelete-nvim": "plugin-bufdelete-nvim", diff --git a/flake.nix b/flake.nix index d5a7b709..f5014afe 100644 --- a/flake.nix +++ b/flake.nix @@ -730,5 +730,10 @@ url = "github:mrcjkb/haskell-tools.nvim"; flake = false; }; + + plugin-aerial-nvim = { + url = "github:stevearc/aerial.nvim"; + flake = false; + }; }; } From 92e38fbfae40ce5aee381f5034a603ad05616be0 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 6 Jan 2025 11:44:48 +0100 Subject: [PATCH 36/39] aerial: init --- modules/plugins/utility/default.nix | 1 + .../outline/aerial-nvim/aerial-nvim.nix | 14 +++++++ .../utility/outline/aerial-nvim/config.nix | 42 +++++++++++++++++++ .../utility/outline/aerial-nvim/default.nix | 6 +++ modules/plugins/utility/outline/default.nix | 5 +++ 5 files changed, 68 insertions(+) create mode 100644 modules/plugins/utility/outline/aerial-nvim/aerial-nvim.nix create mode 100644 modules/plugins/utility/outline/aerial-nvim/config.nix create mode 100644 modules/plugins/utility/outline/aerial-nvim/default.nix create mode 100644 modules/plugins/utility/outline/default.nix diff --git a/modules/plugins/utility/default.nix b/modules/plugins/utility/default.nix index 835ebf6e..686295e2 100644 --- a/modules/plugins/utility/default.nix +++ b/modules/plugins/utility/default.nix @@ -1,5 +1,6 @@ { imports = [ + ./outline ./binds ./ccc ./gestures diff --git a/modules/plugins/utility/outline/aerial-nvim/aerial-nvim.nix b/modules/plugins/utility/outline/aerial-nvim/aerial-nvim.nix new file mode 100644 index 00000000..beede428 --- /dev/null +++ b/modules/plugins/utility/outline/aerial-nvim/aerial-nvim.nix @@ -0,0 +1,14 @@ +{lib, ...}: let + inherit (lib.options) mkEnableOption; + inherit (lib.nvim.types) mkPluginSetupOption; + inherit (lib.nvim.binds) mkMappingOption; +in { + options.vim.utility.outline.aerial-nvim = { + enable = mkEnableOption "Aerial.nvim"; + setupOpts = mkPluginSetupOption "aerial.nvim" {}; + + mappings = { + toggle = mkMappingOption "Toggle aerial window" "gO"; + }; + }; +} diff --git a/modules/plugins/utility/outline/aerial-nvim/config.nix b/modules/plugins/utility/outline/aerial-nvim/config.nix new file mode 100644 index 00000000..803302f7 --- /dev/null +++ b/modules/plugins/utility/outline/aerial-nvim/config.nix @@ -0,0 +1,42 @@ +{ + options, + config, + lib, + ... +}: let + inherit (lib.modules) mkIf; + inherit (lib.nvim.binds) mkKeymap; + + cfg = config.vim.utility.outline.aerial-nvim; + inherit (options.vim.utility.outline.aerial-nvim) mappings; +in { + config = mkIf cfg.enable { + vim = { + lazy.plugins.aerial-nvim = { + package = "aerial-nvim"; + + setupModule = "aerial"; + inherit (cfg) setupOpts; + + cmd = [ + "AerialClose" + "AerialCloseAll" + "AerialGo" + "AerialInfo" + "AerialNavClose" + "AerialNavOpen" + "AerialNavToggle" + "AerialNext" + "AerialOpen" + "AerialOpenAll" + "AerialPrev" + "AerialToggle" + ]; + + keys = [ + (mkKeymap "n" cfg.mappings.toggle ":AerialToggle" {desc = mappings.toggle.description;}) + ]; + }; + }; + }; +} diff --git a/modules/plugins/utility/outline/aerial-nvim/default.nix b/modules/plugins/utility/outline/aerial-nvim/default.nix new file mode 100644 index 00000000..ea782c89 --- /dev/null +++ b/modules/plugins/utility/outline/aerial-nvim/default.nix @@ -0,0 +1,6 @@ +{ + imports = [ + ./aerial-nvim.nix + ./config.nix + ]; +} diff --git a/modules/plugins/utility/outline/default.nix b/modules/plugins/utility/outline/default.nix new file mode 100644 index 00000000..d8262edd --- /dev/null +++ b/modules/plugins/utility/outline/default.nix @@ -0,0 +1,5 @@ +{ + imports = [ + ./aerial-nvim + ]; +} From c071f2caa22dddc61d9c6b9ee59a8397a4a64c36 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 6 Jan 2025 11:45:02 +0100 Subject: [PATCH 37/39] nvimtree: remove unnecessary import --- modules/plugins/filetree/nvimtree/config.nix | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/modules/plugins/filetree/nvimtree/config.nix b/modules/plugins/filetree/nvimtree/config.nix index 11fa9fed..0d0381a0 100644 --- a/modules/plugins/filetree/nvimtree/config.nix +++ b/modules/plugins/filetree/nvimtree/config.nix @@ -1,7 +1,7 @@ { + options, config, lib, - pkgs, ... }: let inherit (lib.strings) optionalString; @@ -11,8 +11,7 @@ inherit (lib.nvim.binds) pushDownDefault; cfg = config.vim.filetree.nvimTree; - self = import ./nvimtree.nix {inherit pkgs lib;}; - inherit (self.options.vim.filetree.nvimTree) mappings; + inherit (options.vim.filetree.nvimTree) mappings; in { config = mkIf cfg.enable { vim = { From de02e2fa577005885966f136a7d32ecf79db4b55 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 6 Jan 2025 11:58:08 +0100 Subject: [PATCH 38/39] docs: update release notes --- docs/release-notes/rl-0.8.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/docs/release-notes/rl-0.8.md b/docs/release-notes/rl-0.8.md index 16ec2863..eb7ca0db 100644 --- a/docs/release-notes/rl-0.8.md +++ b/docs/release-notes/rl-0.8.md @@ -28,3 +28,9 @@ - Disable the built-in format-on-save feature of zls. Use `vim.lsp.formatOnSave` instead. + +[horriblename](https://github.com/horriblename): + +[aerial.nvim](https://github.com/stevearc/aerial.nvim) + +- Add [aerial.nvim] From 2728e65a5ea3ec46812c1ac035abc5b0fadb45a2 Mon Sep 17 00:00:00 2001 From: NotAShelf Date: Tue, 7 Jan 2025 04:19:57 +0300 Subject: [PATCH 39/39] docs/installation: mark additional inputs as 'optional' --- docs/manual/installation/modules/home-manager.md | 14 ++++++++++---- docs/manual/installation/modules/nixos.md | 10 ++++++++-- 2 files changed, 18 insertions(+), 6 deletions(-) diff --git a/docs/manual/installation/modules/home-manager.md b/docs/manual/installation/modules/home-manager.md index cf56acc3..34f2757e 100644 --- a/docs/manual/installation/modules/home-manager.md +++ b/docs/manual/installation/modules/home-manager.md @@ -10,12 +10,18 @@ To use it, we first add the input flake. ```nix { inputs = { + # Optional, if you intend to follow nvf's obsidian-nvim input + # you must also add it as a flake input. obsidian-nvim.url = "github:epwalsh/obsidian.nvim"; + + # Required, nvf works best and only directly supports flakes nvf = { url = "github:notashelf/nvf"; - # you can override input nixpkgs + # You can override the input nixpkgs to follow your system's + # instance of nixpkgs. This is safe to do as nvf does not depend + # on a binary cache. inputs.nixpkgs.follows = "nixpkgs"; - # you can also override individual plugins + # Optionally, you can also override individual plugins # for example: inputs.obsidian-nvim.follows = "obsidian-nvim"; # <- this will use the obsidian-nvim from your inputs }; @@ -27,8 +33,8 @@ Followed by importing the home-manager module somewhere in your configuration. ```nix { - # assuming nvf is in your inputs and inputs is in the argset - # see example below + # Assuming "nvf" is in your inputs and inputs is in the argument set. + # See example installation below imports = [ inputs.nvf.homeManagerModules.default ]; } ``` diff --git a/docs/manual/installation/modules/nixos.md b/docs/manual/installation/modules/nixos.md index ae5ce939..bcf7472b 100644 --- a/docs/manual/installation/modules/nixos.md +++ b/docs/manual/installation/modules/nixos.md @@ -10,12 +10,18 @@ To use it, we first add the input flake. ```nix { inputs = { + # Optional, if you intend to follow nvf's obsidian-nvim input + # you must also add it as a flake input. obsidian-nvim.url = "github:epwalsh/obsidian.nvim"; + + # Required, nvf works best and only directly supports flakes nvf = { url = "github:notashelf/nvf"; - # you can override input nixpkgs + # You can override the input nixpkgs to follow your system's + # instance of nixpkgs. This is safe to do as nvf does not depend + # on a binary cache. inputs.nixpkgs.follows = "nixpkgs"; - # you can also override individual plugins + # Optionally, you can also override individual plugins # for example: inputs.obsidian-nvim.follows = "obsidian-nvim"; # <- this will use the obsidian-nvim from your inputs };