mirror of
https://github.com/NotAShelf/nvf.git
synced 2024-11-26 15:06:45 +00:00
Compare commits
2 commits
fa660627fc
...
d48f52f065
Author | SHA1 | Date | |
---|---|---|---|
|
d48f52f065 | ||
|
1340eb34a0 |
1 changed files with 27 additions and 25 deletions
|
@ -9,7 +9,7 @@ inputs: {
|
||||||
inherit (pkgs) vimPlugins;
|
inherit (pkgs) vimPlugins;
|
||||||
inherit (lib.strings) isString toString;
|
inherit (lib.strings) isString toString;
|
||||||
inherit (lib.lists) filter map concatLists;
|
inherit (lib.lists) filter map concatLists;
|
||||||
inherit (lib.attrsets) recursiveUpdate getAttr;
|
inherit (lib.attrsets) recursiveUpdate;
|
||||||
inherit (builtins) baseNameOf;
|
inherit (builtins) baseNameOf;
|
||||||
|
|
||||||
# import modules.nix with `check`, `pkgs` and `lib` as arguments
|
# import modules.nix with `check`, `pkgs` and `lib` as arguments
|
||||||
|
@ -32,14 +32,21 @@ inputs: {
|
||||||
# build a vim plugin with the given name and arguments
|
# build a vim plugin with the given name and arguments
|
||||||
# if the plugin is nvim-treesitter, warn the user to use buildTreesitterPlug
|
# if the plugin is nvim-treesitter, warn the user to use buildTreesitterPlug
|
||||||
# instead
|
# instead
|
||||||
buildPlug = {pname, ...} @ attrs: let
|
buildPlug = attrs: let
|
||||||
src = getAttr ("plugin-" + pname) inputs;
|
src = inputs."plugin-${attrs.pname}";
|
||||||
in
|
in
|
||||||
pkgs.stdenvNoCC.mkDerivation ({
|
pkgs.stdenvNoCC.mkDerivation ({
|
||||||
version = src.shortRev or src.shortDirtyRev or "dirty";
|
version = src.shortRev or src.shortDirtyRev or "dirty";
|
||||||
|
|
||||||
inherit src;
|
inherit src;
|
||||||
|
|
||||||
|
nativeBuildInputs = with pkgs.vimUtils; [
|
||||||
|
vimCommandCheckHook
|
||||||
|
vimGenDocHook
|
||||||
|
neovimRequireCheckHook
|
||||||
|
];
|
||||||
|
passthru.vimPlugin = true;
|
||||||
|
|
||||||
buildPhase = lib.optionalString vimOptions.byteCompileLua ''
|
buildPhase = lib.optionalString vimOptions.byteCompileLua ''
|
||||||
runHook preBuild
|
runHook preBuild
|
||||||
find . -type f -name '*.lua' -exec luajit -bd -- {} {} \;
|
find . -type f -name '*.lua' -exec luajit -bd -- {} {} \;
|
||||||
|
@ -59,30 +66,25 @@ inputs: {
|
||||||
|
|
||||||
buildTreesitterPlug = grammars: vimPlugins.nvim-treesitter.withPlugins (_: grammars);
|
buildTreesitterPlug = grammars: vimPlugins.nvim-treesitter.withPlugins (_: grammars);
|
||||||
|
|
||||||
buildConfigPlugins = plugins:
|
pluginBuilders = {
|
||||||
map
|
nvim-treesitter = buildTreesitterPlug vimOptions.treesitter.grammars;
|
||||||
(plug: (
|
flutter-tools-patched =
|
||||||
if (isString plug)
|
|
||||||
then
|
|
||||||
(
|
|
||||||
if (plug == "nvim-treesitter")
|
|
||||||
then (buildTreesitterPlug vimOptions.treesitter.grammars)
|
|
||||||
else if (plug == "flutter-tools-patched")
|
|
||||||
then
|
|
||||||
(
|
|
||||||
buildPlug
|
buildPlug
|
||||||
{
|
{
|
||||||
pname = "flutter-tools";
|
pname = "flutter-tools";
|
||||||
patches = [../patches/flutter-tools.patch];
|
patches = [../patches/flutter-tools.patch];
|
||||||
}
|
};
|
||||||
)
|
};
|
||||||
else buildPlug {pname = plug;}
|
|
||||||
)
|
buildConfigPlugins = plugins:
|
||||||
|
map
|
||||||
|
(
|
||||||
|
plug:
|
||||||
|
if (isString plug)
|
||||||
|
then pluginBuilders.${plug} or (buildPlug {pname = plug;})
|
||||||
else plug
|
else plug
|
||||||
))
|
)
|
||||||
(filter
|
(filter (f: f != null) plugins);
|
||||||
(f: f != null)
|
|
||||||
plugins);
|
|
||||||
|
|
||||||
# built (or "normalized") plugins that are modified
|
# built (or "normalized") plugins that are modified
|
||||||
builtStartPlugins = buildConfigPlugins vimOptions.startPlugins;
|
builtStartPlugins = buildConfigPlugins vimOptions.startPlugins;
|
||||||
|
|
Loading…
Reference in a new issue