mirror of
https://github.com/NotAShelf/neovim-flake.git
synced 2024-12-19 13:19:48 +01:00
refactor: move lib out of modules
This commit is contained in:
parent
c2b0b6a053
commit
7db1f6779c
9 changed files with 1 additions and 344 deletions
|
@ -9,7 +9,7 @@
|
||||||
inherit (builtins) map filter isString toString getAttr hasAttr attrNames;
|
inherit (builtins) map filter isString toString getAttr hasAttr attrNames;
|
||||||
inherit (pkgs.vimUtils) buildVimPluginFrom2Nix;
|
inherit (pkgs.vimUtils) buildVimPluginFrom2Nix;
|
||||||
|
|
||||||
extendedLib = import ./lib/stdlib-extended.nix lib;
|
extendedLib = import ../lib/stdlib-extended.nix lib;
|
||||||
|
|
||||||
nvimModules = import ./modules.nix {
|
nvimModules = import ./modules.nix {
|
||||||
inherit check pkgs;
|
inherit check pkgs;
|
||||||
|
|
|
@ -1,9 +0,0 @@
|
||||||
# From home-manager: https://github.com/nix-community/home-manager/blob/master/modules/lib/booleans.nix
|
|
||||||
{lib}: {
|
|
||||||
# Converts a boolean to a yes/no string. This is used in lots of
|
|
||||||
# configuration formats.
|
|
||||||
yesNo = value:
|
|
||||||
if value
|
|
||||||
then "yes"
|
|
||||||
else "no";
|
|
||||||
}
|
|
|
@ -1,107 +0,0 @@
|
||||||
# From home-manager: https://github.com/nix-community/home-manager/blob/master/modules/lib/dag.nix
|
|
||||||
# A generalization of Nixpkgs's `strings-with-deps.nix`.
|
|
||||||
#
|
|
||||||
# The main differences from the Nixpkgs version are
|
|
||||||
#
|
|
||||||
# - not specific to strings, i.e., any payload is OK,
|
|
||||||
#
|
|
||||||
# - the addition of the function `entryBefore` indicating a "wanted
|
|
||||||
# by" relationship.
|
|
||||||
{lib}: let
|
|
||||||
inherit (lib) all filterAttrs nvim mapAttrs toposort;
|
|
||||||
in {
|
|
||||||
empty = {};
|
|
||||||
|
|
||||||
isEntry = e: e ? data && e ? after && e ? before;
|
|
||||||
isDag = dag:
|
|
||||||
builtins.isAttrs dag && all nvim.dag.isEntry (builtins.attrValues dag);
|
|
||||||
|
|
||||||
/*
|
|
||||||
Takes an attribute set containing entries built by entryAnywhere,
|
|
||||||
entryAfter, and entryBefore to a topologically sorted list of
|
|
||||||
entries.
|
|
||||||
|
|
||||||
Internally this function uses the `toposort` function in
|
|
||||||
`<nixpkgs/lib/lists.nix>` and its value is accordingly.
|
|
||||||
|
|
||||||
Specifically, the result on success is
|
|
||||||
|
|
||||||
{ result = [ { name = ?; data = ?; } … ] }
|
|
||||||
|
|
||||||
For example
|
|
||||||
|
|
||||||
nix-repl> topoSort {
|
|
||||||
a = entryAnywhere "1";
|
|
||||||
b = entryAfter [ "a" "c" ] "2";
|
|
||||||
c = entryBefore [ "d" ] "3";
|
|
||||||
d = entryBefore [ "e" ] "4";
|
|
||||||
e = entryAnywhere "5";
|
|
||||||
} == {
|
|
||||||
result = [
|
|
||||||
{ data = "1"; name = "a"; }
|
|
||||||
{ data = "3"; name = "c"; }
|
|
||||||
{ data = "2"; name = "b"; }
|
|
||||||
{ data = "4"; name = "d"; }
|
|
||||||
{ data = "5"; name = "e"; }
|
|
||||||
];
|
|
||||||
}
|
|
||||||
true
|
|
||||||
|
|
||||||
And the result on error is
|
|
||||||
|
|
||||||
{
|
|
||||||
cycle = [ { after = ?; name = ?; data = ? } … ];
|
|
||||||
loops = [ { after = ?; name = ?; data = ? } … ];
|
|
||||||
}
|
|
||||||
|
|
||||||
For example
|
|
||||||
|
|
||||||
nix-repl> topoSort {
|
|
||||||
a = entryAnywhere "1";
|
|
||||||
b = entryAfter [ "a" "c" ] "2";
|
|
||||||
c = entryAfter [ "d" ] "3";
|
|
||||||
d = entryAfter [ "b" ] "4";
|
|
||||||
e = entryAnywhere "5";
|
|
||||||
} == {
|
|
||||||
cycle = [
|
|
||||||
{ after = [ "a" "c" ]; data = "2"; name = "b"; }
|
|
||||||
{ after = [ "d" ]; data = "3"; name = "c"; }
|
|
||||||
{ after = [ "b" ]; data = "4"; name = "d"; }
|
|
||||||
];
|
|
||||||
loops = [
|
|
||||||
{ after = [ "a" "c" ]; data = "2"; name = "b"; }
|
|
||||||
];
|
|
||||||
}
|
|
||||||
true
|
|
||||||
*/
|
|
||||||
topoSort = dag: let
|
|
||||||
dagBefore = dag: name:
|
|
||||||
builtins.attrNames
|
|
||||||
(filterAttrs (n: v: builtins.elem name v.before) dag);
|
|
||||||
normalizedDag =
|
|
||||||
mapAttrs (n: v: {
|
|
||||||
name = n;
|
|
||||||
data = v.data;
|
|
||||||
after = v.after ++ dagBefore dag n;
|
|
||||||
})
|
|
||||||
dag;
|
|
||||||
before = a: b: builtins.elem a.name b.after;
|
|
||||||
sorted = toposort before (builtins.attrValues normalizedDag);
|
|
||||||
in
|
|
||||||
if sorted ? result
|
|
||||||
then {
|
|
||||||
result = map (v: {inherit (v) name data;}) sorted.result;
|
|
||||||
}
|
|
||||||
else sorted;
|
|
||||||
|
|
||||||
# Applies a function to each element of the given DAG.
|
|
||||||
map = f: mapAttrs (n: v: v // {data = f n v.data;});
|
|
||||||
|
|
||||||
entryBetween = before: after: data: {inherit data before after;};
|
|
||||||
|
|
||||||
# Create a DAG entry with no particular dependency information.
|
|
||||||
entryAnywhere = nvim.dag.entryBetween [] [];
|
|
||||||
|
|
||||||
entryAfter = nvim.dag.entryBetween [];
|
|
||||||
entryBefore = before: nvim.dag.entryBetween before [];
|
|
||||||
}
|
|
|
@ -1,5 +0,0 @@
|
||||||
{lib}: {
|
|
||||||
dag = import ./dag.nix {inherit lib;};
|
|
||||||
booleans = import ./booleans.nix {inherit lib;};
|
|
||||||
types = import ./types.nix {inherit lib;};
|
|
||||||
}
|
|
|
@ -1,53 +0,0 @@
|
||||||
# Home Manager module
|
|
||||||
{
|
|
||||||
config,
|
|
||||||
pkgs,
|
|
||||||
lib ? pkgs.lib,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
cfg = config.programs.neovim-ide;
|
|
||||||
set = pkgs.neovimBuilder {config = cfg.settings;};
|
|
||||||
in
|
|
||||||
with lib; {
|
|
||||||
meta.maintainers = [maintainers.notashelf];
|
|
||||||
|
|
||||||
options.programs.neovim-ide = {
|
|
||||||
enable = mkEnableOption "NeoVim with LSP enabled for Scala, Haskell, Rust and more.";
|
|
||||||
|
|
||||||
settings = mkOption {
|
|
||||||
type = types.attrsOf types.anything;
|
|
||||||
default = {};
|
|
||||||
example = literalExpression ''
|
|
||||||
{
|
|
||||||
vim.viAlias = false;
|
|
||||||
vim.vimAlias = true;
|
|
||||||
vim.lsp = {
|
|
||||||
enable = true;
|
|
||||||
formatOnSave = true;
|
|
||||||
lightbulb.enable = true;
|
|
||||||
lspsaga.enable = false;
|
|
||||||
nvimCodeActionMenu.enable = true;
|
|
||||||
trouble.enable = true;
|
|
||||||
lspSignature.enable = true;
|
|
||||||
rust.enable = false;
|
|
||||||
nix = true;
|
|
||||||
dhall = true;
|
|
||||||
elm = true;
|
|
||||||
haskell = true;
|
|
||||||
scala = true;
|
|
||||||
sql = true;
|
|
||||||
python = false;
|
|
||||||
clang = false;
|
|
||||||
ts = false;
|
|
||||||
go = false;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
'';
|
|
||||||
description = "Attribute set of neoflake preferences.";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
|
||||||
home.packages = [set.neovim];
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,13 +0,0 @@
|
||||||
# From home-manager: https://github.com/nix-community/home-manager/blob/master/modules/lib/stdlib-extended.nix
|
|
||||||
# Just a convenience function that returns the given Nixpkgs standard
|
|
||||||
# library extended with the HM library.
|
|
||||||
nixpkgsLib: let
|
|
||||||
mkNvimLib = import ./.;
|
|
||||||
in
|
|
||||||
nixpkgsLib.extend (self: super: {
|
|
||||||
nvim = mkNvimLib {lib = self;};
|
|
||||||
|
|
||||||
# For forward compatibility.
|
|
||||||
literalExpression = super.literalExpression or super.literalExample;
|
|
||||||
literalDocBook = super.literalDocBook or super.literalExample;
|
|
||||||
})
|
|
|
@ -1,68 +0,0 @@
|
||||||
# From home-manager: https://github.com/nix-community/home-manager/blob/master/modules/lib/types-dag.nix
|
|
||||||
# Used for ordering config text.
|
|
||||||
{lib}: let
|
|
||||||
inherit
|
|
||||||
(lib)
|
|
||||||
defaultFunctor
|
|
||||||
nvim
|
|
||||||
mkIf
|
|
||||||
mkOrder
|
|
||||||
mkOption
|
|
||||||
mkOptionType
|
|
||||||
types
|
|
||||||
;
|
|
||||||
|
|
||||||
dagEntryOf = elemType: let
|
|
||||||
submoduleType = types.submodule ({name, ...}: {
|
|
||||||
options = {
|
|
||||||
data = mkOption {type = elemType;};
|
|
||||||
after = mkOption {type = with types; listOf str;};
|
|
||||||
before = mkOption {type = with types; listOf str;};
|
|
||||||
};
|
|
||||||
config = mkIf (elemType.name == "submodule") {
|
|
||||||
data._module.args.dagName = name;
|
|
||||||
};
|
|
||||||
});
|
|
||||||
maybeConvert = def:
|
|
||||||
if nvim.dag.isEntry def.value
|
|
||||||
then def.value
|
|
||||||
else
|
|
||||||
nvim.dag.entryAnywhere (
|
|
||||||
if def ? priority
|
|
||||||
then mkOrder def.priority def.value
|
|
||||||
else def.value
|
|
||||||
);
|
|
||||||
in
|
|
||||||
mkOptionType {
|
|
||||||
name = "dagEntryOf";
|
|
||||||
description = "DAG entry of ${elemType.description}";
|
|
||||||
# leave the checking to the submodule type
|
|
||||||
merge = loc: defs:
|
|
||||||
submoduleType.merge loc (map (def: {
|
|
||||||
inherit (def) file;
|
|
||||||
value = maybeConvert def;
|
|
||||||
})
|
|
||||||
defs);
|
|
||||||
};
|
|
||||||
in rec {
|
|
||||||
# A directed acyclic graph of some inner type.
|
|
||||||
#
|
|
||||||
# Note, if the element type is a submodule then the `name` argument
|
|
||||||
# will always be set to the string "data" since it picks up the
|
|
||||||
# internal structure of the DAG values. To give access to the
|
|
||||||
# "actual" attribute name a new submodule argument is provided with
|
|
||||||
# the name `dagName`.
|
|
||||||
dagOf = elemType: let
|
|
||||||
attrEquivalent = types.attrsOf (dagEntryOf elemType);
|
|
||||||
in
|
|
||||||
mkOptionType rec {
|
|
||||||
name = "dagOf";
|
|
||||||
description = "DAG of ${elemType.description}";
|
|
||||||
inherit (attrEquivalent) check merge emptyValue;
|
|
||||||
getSubOptions = prefix: elemType.getSubOptions (prefix ++ ["<name>"]);
|
|
||||||
getSubModules = elemType.getSubModules;
|
|
||||||
substSubModules = m: dagOf (elemType.substSubModules m);
|
|
||||||
functor = (defaultFunctor name) // {wrapped = elemType;};
|
|
||||||
nestedTypes.elemType = elemType;
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,81 +0,0 @@
|
||||||
{lib}:
|
|
||||||
with lib; let
|
|
||||||
# Plugin must be same as input name from flake.nix
|
|
||||||
availablePlugins = [
|
|
||||||
# TODO: sort by category
|
|
||||||
"nvim-treesitter-context"
|
|
||||||
"gitsigns-nvim"
|
|
||||||
"plenary-nvim"
|
|
||||||
"nvim-lspconfig"
|
|
||||||
"nvim-treesitter"
|
|
||||||
"lspsaga"
|
|
||||||
"lspkind"
|
|
||||||
"nvim-lightbulb"
|
|
||||||
"lsp-signature"
|
|
||||||
"nvim-tree-lua"
|
|
||||||
"nvim-bufferline-lua"
|
|
||||||
"lualine"
|
|
||||||
"nvim-compe"
|
|
||||||
"nvim-autopairs"
|
|
||||||
"nvim-ts-autotag"
|
|
||||||
"nvim-web-devicons"
|
|
||||||
"tokyonight"
|
|
||||||
"bufdelete-nvim"
|
|
||||||
"nvim-cmp"
|
|
||||||
"cmp-nvim-lsp"
|
|
||||||
"cmp-buffer"
|
|
||||||
"cmp-vsnip"
|
|
||||||
"cmp-path"
|
|
||||||
"cmp-treesitter"
|
|
||||||
"crates-nvim"
|
|
||||||
"vim-vsnip"
|
|
||||||
"nvim-code-action-menu"
|
|
||||||
"trouble"
|
|
||||||
"null-ls"
|
|
||||||
"which-key"
|
|
||||||
"indent-blankline"
|
|
||||||
"nvim-cursorline"
|
|
||||||
"sqls-nvim"
|
|
||||||
"glow-nvim"
|
|
||||||
"telescope"
|
|
||||||
"rust-tools"
|
|
||||||
"onedark"
|
|
||||||
"catppuccin"
|
|
||||||
"minimap-vim"
|
|
||||||
"dashboard-nvim"
|
|
||||||
"alpha-nvim"
|
|
||||||
"scrollbar-nvim"
|
|
||||||
"codewindow-nvim"
|
|
||||||
"nvim-notify"
|
|
||||||
"cinnamon-nvim"
|
|
||||||
"cheatsheet-nvim"
|
|
||||||
"colorizer"
|
|
||||||
"venn-nvim"
|
|
||||||
"cellular-automaton"
|
|
||||||
"presence-nvim"
|
|
||||||
"icon-picker-nvim"
|
|
||||||
"dressing-nvim"
|
|
||||||
"orgmode-nvim"
|
|
||||||
"obsidian-nvim"
|
|
||||||
"vim-markdown"
|
|
||||||
"tabular"
|
|
||||||
"toggleterm-nvim"
|
|
||||||
"noice-nvim"
|
|
||||||
"nui-nvim"
|
|
||||||
"copilot-lua"
|
|
||||||
"tabnine-nvim"
|
|
||||||
"nvim-session-manager"
|
|
||||||
"gesture-nvim"
|
|
||||||
];
|
|
||||||
# You can either use the name of the plugin or a package.
|
|
||||||
pluginsType = with types; listOf (nullOr (either (enum availablePlugins) package));
|
|
||||||
in {
|
|
||||||
pluginsOpt = {
|
|
||||||
description,
|
|
||||||
default ? [],
|
|
||||||
}:
|
|
||||||
mkOption {
|
|
||||||
inherit description default;
|
|
||||||
type = pluginsType;
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,7 +0,0 @@
|
||||||
{lib}: let
|
|
||||||
typesDag = import ./types-dag.nix {inherit lib;};
|
|
||||||
typesPlugin = import ./types-plugin.nix {inherit lib;};
|
|
||||||
in {
|
|
||||||
inherit (typesDag) dagOf;
|
|
||||||
inherit (typesPlugin) pluginsOpt;
|
|
||||||
}
|
|
Loading…
Reference in a new issue