Skip to content

Commit

Permalink
packer: init plugin
Browse files Browse the repository at this point in the history
  • Loading branch information
pta2002 committed Mar 18, 2021
1 parent 5ffa2b4 commit f7e02b3
Show file tree
Hide file tree
Showing 6 changed files with 119 additions and 22 deletions.
18 changes: 9 additions & 9 deletions flake.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

14 changes: 12 additions & 2 deletions flake.nix
Original file line number Diff line number Diff line change
Expand Up @@ -43,8 +43,18 @@
pkgs.vimPlugins.vim-nix
];

options.number = true;
options.mouse = "a";
options = {
number = true;
mouse = "a";
tabstop = 2;
shiftwidth = 2;
expandtab = true;
smarttab = true;
autoindent = true;
cindent = true;
linebreak = true;
hidden = true;
};

maps.normalVisualOp."ç" = ":";

Expand Down
2 changes: 2 additions & 0 deletions plugins/default.nix
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@
./colorschemes/one.nix
./colorschemes/base16.nix

./pluginmanagers/packer.nix

./statuslines/lightline.nix
./statuslines/airline.nix

Expand Down
15 changes: 11 additions & 4 deletions plugins/helpers.nix
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,15 @@ rec {
# lua equivalents!
toLuaObject = args:
if builtins.isAttrs args then
"{" + (concatStringsSep ","
(mapAttrsToList
(n: v: "[${toLuaObject n}] = " + (toLuaObject v))
(filterAttrs (n: v: !isNull v || v == {}) args))) + "}"
if hasAttr "__raw" args then
args.__raw
else
"{" + (concatStringsSep ","
(mapAttrsToList
(n: v: if head (stringToCharacters n) == "@" then
toLuaObject v
else "[${toLuaObject n}] = " + (toLuaObject v))
(filterAttrs (n: v: !isNull v || v == {}) args))) + "}"
else if builtins.isList args then
"{" + concatMapStringsSep "," toLuaObject args + "}"
else if builtins.isString args then
Expand Down Expand Up @@ -97,4 +102,6 @@ rec {

inherit value global;
};

mkRaw = r: { __raw = r; };
}
19 changes: 12 additions & 7 deletions plugins/languages/treesitter.nix
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,7 @@ in

disabledLanguages = mkOption {
type = types.listOf types.str;
# Nix is out of date right now! Try not to use it :D
default = [ "nix" ];
default = [];
description = "A list of languages to disable";
};

Expand Down Expand Up @@ -76,11 +75,17 @@ in
};
in mkIf cfg.enable {
programs.nixvim = {
extraPlugins = [ pkgs.vimPlugins.nvim-treesitter ];

extraConfigLua = ''
require('nvim-treesitter.configs').setup(${helpers.toLuaObject tsOptions})
'';
plugins.packer = {
enable = true;
plugins = [{
name = "nvim-treesitter/nvim-treesitter";
run = ":TSUpdate";
config = helpers.mkRaw ''function()
require('nvim-treesitter.configs').setup(${helpers.toLuaObject tsOptions})
end'';
}];
};
extraPackages = [ pkgs.tree-sitter ];

options = mkIf cfg.folding {
foldmethod = "expr";
Expand Down
73 changes: 73 additions & 0 deletions plugins/pluginmanagers/packer.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
{ pkgs, config, lib, ... }:
with lib;
let
cfg = config.programs.nixvim.plugins.packer;
helpers = import ../helpers.nix { lib = lib; };
in {
options = {
programs.nixvim.plugins.packer = {
enable = mkEnableOption "Enable packer.nvim";

plugins = mkOption {
type = types.listOf (types.oneOf [types.str (with types; let
mkOpt = type: desc: mkOption {
type = nullOr type;
default = null;
description = desc;
};
function = attrsOf str;
in types.submodule {
options = {
name = mkOption {
type = str;
description = "Name of the plugin to install";
};

disable = mkOpt bool "Mark plugin as inactive";
as = mkOpt bool "Specifies an alias under which to install the plugin";
installer = mkOpt function "A custom installer";
updater = mkOpt function "A custom updater";
after = mkOpt (oneOf [str (listOf any)]) "Plugins to load after this plugin";
rtp = mkOpt str "Specifies a subdirectory of the plugin to add to runtimepath";
opt = mkOpt str "Marks a plugin as optional";
branch = mkOpt str "Git branch to use";
tag = mkOpt str "Git tag to use";
commit = mkOpt str "Git commit to use";
lock = mkOpt bool "Skip this plugin in updates";
run = mkOpt (oneOf [str function]) "Post-install hook";
requires = mkOpt (oneOf [str (listOf any)]) "Plugin dependencies";
rocks = mkOpt (oneOf [str (listOf any)]) "Luarocks dependencies";
config = mkOpt (oneOf [str function]) "Code to run after this plugin is loaded";
setup = mkOpt (oneOf [str function]) "Code to be run before this plugin is loaded";
cmd = mkOpt (oneOf [str (listOf str)]) "Commands which load this plugin";
ft = mkOpt (oneOf [str (listOf str)]) "Filetypes which load this plugin";
keys = mkOpt (oneOf [str (listOf str)]) "Keymaps which load this plugin";
event = mkOpt (oneOf [str (listOf str)]) "Autocommand events which load this plugin";
fn = mkOpt (oneOf [str (listOf str)]) "Functions which load this plugin";
cond = mkOpt (oneOf [str function (listOf (oneOf [str function]))]) "Conditional test to load this plugin";
module = mkOpt (oneOf [str (listOf str)]) "Patterns of module names which load this plugin";
};
})]);
default = [];
description = "List of plugins";
};
};
};

config = mkIf cfg.enable {
programs.nixvim = {
extraPlugins = [ pkgs.vimPlugins.packer-nvim ];

extraConfigLua = let
plugins = map (plugin: if isAttrs plugin then
mapAttrs' (k: v: { name = if k == "name" then "@" else k; value = v; }) plugin
else plugin) cfg.plugins;
packedPlugins = if length plugins == 1 then head plugins else plugins;
in mkIf (cfg.plugins != []) ''
require('packer').startup(function()
use ${helpers.toLuaObject packedPlugins}
end)
'';
};
};
}

0 comments on commit f7e02b3

Please sign in to comment.