mirror of
https://github.com/NotAShelf/nvf.git
synced 2025-01-18 16:02:24 +00:00
manual/configuring: in-depth explanation of plugin input overrides
This commit is contained in:
parent
a196e9610f
commit
38d265d434
3 changed files with 57 additions and 3 deletions
|
@ -3,6 +3,7 @@
|
||||||
```{=include=} chapters
|
```{=include=} chapters
|
||||||
configuring/custom-package.md
|
configuring/custom-package.md
|
||||||
configuring/custom-plugins.md
|
configuring/custom-plugins.md
|
||||||
|
configuring/custom-inputs.md
|
||||||
configuring/languages.md
|
configuring/languages.md
|
||||||
configuring/dags.md
|
configuring/dags.md
|
||||||
configuring/dag-entries.md
|
configuring/dag-entries.md
|
||||||
|
|
53
docs/manual/configuring/custom-inputs.md
Normal file
53
docs/manual/configuring/custom-inputs.md
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
# Custom Inputs {#ch-custom-inputs}
|
||||||
|
|
||||||
|
One of the greatest strengths of **nvf** is its ability to get plugins from
|
||||||
|
flake inputs and build them locally from any given source. For plugins that do
|
||||||
|
not require any kind of additional building step, this is a powerful method of
|
||||||
|
adding plugins to your configuration that are not packaged in nixpkgs, or those
|
||||||
|
you want to track from source without relying on nixpkgs.
|
||||||
|
|
||||||
|
The [additional plugins section](#sec-additional-plugins) details the addition
|
||||||
|
of new plugins to nvf under regular circumstances, i.e. while making a pull
|
||||||
|
request to the project. You may _override_ those plugin inputs in your own
|
||||||
|
`flake.nix` to change source versions, e.g., to use newer versions of plugins
|
||||||
|
that are not yet updated in **nvf**.
|
||||||
|
|
||||||
|
```nix
|
||||||
|
{
|
||||||
|
|
||||||
|
inputs = {
|
||||||
|
# ...
|
||||||
|
|
||||||
|
# The name here is arbitrary, you can name it whatever.
|
||||||
|
# This will add a plugin input called "your-neodev-input"
|
||||||
|
# that you can reference in a `follows` line.
|
||||||
|
your-neodev-input = {
|
||||||
|
url = "github:folke/neodev.nvim";
|
||||||
|
flake = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
nvf = {
|
||||||
|
url = "github:notashelf/nvf";
|
||||||
|
|
||||||
|
# The name of the input must match for the follows line
|
||||||
|
# plugin-neodev-nvim is what the input is called inside nvf
|
||||||
|
# so you must match the exact name here.
|
||||||
|
inputs.plugin-neodev-nvim.follows = "your-neodev-input";
|
||||||
|
};
|
||||||
|
# ...
|
||||||
|
};
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
This will override the source for the `neodev.nvim` plugin that is used in nvf
|
||||||
|
with your own input. You can update your new input via `nix flake update` or
|
||||||
|
more specifically `nix flake update <name of your input>` to keep it up to date.
|
||||||
|
|
||||||
|
::: {.warning}
|
||||||
|
|
||||||
|
While updating plugin inputs, make sure that any configuration that has been
|
||||||
|
deprecated in newer versions is changed in the plugin's `setupOpts`. If you
|
||||||
|
depend on a new version, requesting a version bump in the issues section is a
|
||||||
|
more reliable option.
|
||||||
|
|
||||||
|
:::
|
|
@ -11,11 +11,11 @@ configuration locally.
|
||||||
There are multiple ways of adding custom plugins to your **nvf** configuration.
|
There are multiple ways of adding custom plugins to your **nvf** configuration.
|
||||||
|
|
||||||
You can use custom plugins, before they are implemented in the flake. To add a
|
You can use custom plugins, before they are implemented in the flake. To add a
|
||||||
plugin to the runtime, you need to add it to the `vim.startPlugins` list in your
|
plugin to the runtime, you need to add it to the [](#opt-vim.startPlugins) list
|
||||||
configuration.
|
in your configuration.
|
||||||
|
|
||||||
Adding a plugin to `startPlugins` will not allow you to configure the plugin
|
Adding a plugin to `startPlugins` will not allow you to configure the plugin
|
||||||
that you have adeed, but **nvf** provides multiple way of configuring any custom
|
that you have added, but **nvf** provides multiple way of configuring any custom
|
||||||
plugins that you might have added to your configuration.
|
plugins that you might have added to your configuration.
|
||||||
|
|
||||||
```{=include=} sections
|
```{=include=} sections
|
||||||
|
|
Loading…
Reference in a new issue