mirror of
https://github.com/NotAShelf/neovim-flake.git
synced 2024-12-19 15:39:49 +01:00
55 lines
1.8 KiB
Markdown
55 lines
1.8 KiB
Markdown
# Standalone Installation on Home-Manager {#ch-standalone-hm}
|
|
|
|
Your built Neovim configuration can be exposed as a flake output to make it
|
|
easier to share across machines, repositories and so on. Or it can be added to
|
|
your system packages to make it available across your system.
|
|
|
|
The following is an example installation of `nvf` as a standalone package with
|
|
the default theme enabled. You may use other options inside `config.vim` in
|
|
`configModule`, but this example will not cover that extensively.
|
|
|
|
```nix
|
|
{
|
|
inputs = {
|
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
|
home-manager.url = "github:nix-community/home-manager";
|
|
nvf.url = "github:notashelf/nvf";
|
|
};
|
|
|
|
outputs = {nixpkgs, home-manager, nvf, ...}: let
|
|
system = "x86_64-linux";
|
|
pkgs = nixpkgs.legacyPackages.${system};
|
|
configModule = {
|
|
# Add any custom options (and do feel free to upstream them!)
|
|
# options = { ... };
|
|
|
|
config.vim = {
|
|
theme.enable = true;
|
|
# and more options as you see fit...
|
|
};
|
|
};
|
|
|
|
customNeovim = nvf.lib.neovimConfiguration {
|
|
inherit pkgs;
|
|
modules = [configModule];
|
|
};
|
|
in {
|
|
# This will make the package available as a flake output under 'packages'
|
|
packages.${system}.my-neovim = customNeovim.neovim;
|
|
|
|
# Example Home-Manager configuration using the configured Neovim package
|
|
homeConfigurations = {
|
|
"your-username@your-hostname" = home-manager.lib.homeManagerConfiguration {
|
|
# ...
|
|
modules = [
|
|
# This will make Neovim available to users using the Home-Manager
|
|
# configuration. To make the package available to all users, prefer
|
|
# environment.systemPackages in your NixOS configuration.
|
|
{home.packages = [customNeovim.neovim];}
|
|
];
|
|
# ...
|
|
};
|
|
};
|
|
};
|
|
}
|
|
```
|