Compare commits
3 commits
b6ca45f7fc
...
87e59d7a79
Author | SHA1 | Date | |
---|---|---|---|
87e59d7a79 | |||
107ffba42c | |||
5563238f0a |
8 changed files with 122 additions and 114 deletions
|
@ -17,7 +17,10 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
moduleDev = nvimModule { };
|
moduleDev = nvimModule { };
|
||||||
moduleHeadless = nvimModule { jhome.nvim.dev.enable = false; };
|
moduleHeadless = nvimModule {
|
||||||
|
jhome.nvim.dev.enable = false;
|
||||||
|
jhome.nvim.reduceSize = true;
|
||||||
|
};
|
||||||
moduleNoLsp = nvimModule { jhome.nvim.dev.bundleLSPs = false; };
|
moduleNoLsp = nvimModule { jhome.nvim.dev.bundleLSPs = false; };
|
||||||
moduleNoTSGrammars = nvimModule { jhome.nvim.dev.bundleGrammars = false; };
|
moduleNoTSGrammars = nvimModule { jhome.nvim.dev.bundleGrammars = false; };
|
||||||
moduleNoBundledBins = nvimModule {
|
moduleNoBundledBins = nvimModule {
|
||||||
|
|
12
flake.lock
generated
12
flake.lock
generated
|
@ -281,11 +281,11 @@
|
||||||
},
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1739484910,
|
"lastModified": 1739624908,
|
||||||
"narHash": "sha256-wjWLzdM7PIq4ZAe7k3vyjtgVJn6b0UeodtRFlM/6W5U=",
|
"narHash": "sha256-f84lBmLl4tkDp1ZU5LBTSFzlxXP4926DVW3KnXrke10=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "0b73e36b1962620a8ac551a37229dd8662dac5c8",
|
"rev": "a60651b217d2e529729cbc7d989c19f3941b9250",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
@ -330,11 +330,11 @@
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1739632145,
|
"lastModified": 1739708385,
|
||||||
"narHash": "sha256-maNBjf9whO303r4+8ekfAZOrf3sHnw6DLiSph5xnXJw=",
|
"narHash": "sha256-H6qPfgE8P6rYMpwj9GsmcZEry52O3U82IqJJy6hx/88=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "nixvim",
|
"repo": "nixvim",
|
||||||
"rev": "b8c55873998948bf14a2b6cf30f9ad5ecdf79818",
|
"rev": "d636d254088a2fa49b585b79097a2766d4e3af80",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|
|
@ -37,6 +37,9 @@ in
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
(lib.mkIf cfg.enable {
|
(lib.mkIf cfg.enable {
|
||||||
|
# Add gopass if pass is enabled
|
||||||
|
packages = lib.optional config.programs.password-store.enable pkgs.gopass;
|
||||||
|
|
||||||
nix.settings.use-xdg-base-directories = fromOs [
|
nix.settings.use-xdg-base-directories = fromOs [
|
||||||
"nix"
|
"nix"
|
||||||
"settings"
|
"settings"
|
||||||
|
@ -69,12 +72,10 @@ in
|
||||||
homedir = "${config.xdg.dataHome}/gnupg";
|
homedir = "${config.xdg.dataHome}/gnupg";
|
||||||
};
|
};
|
||||||
# Mail client
|
# Mail client
|
||||||
himalaya.enable = true;
|
himalaya.enable = lib.mkDefault true;
|
||||||
# Another shell
|
|
||||||
nushell.enable = true;
|
|
||||||
# Password manager
|
# Password manager
|
||||||
password-store = {
|
password-store = {
|
||||||
enable = true;
|
enable = lib.mkDefault true;
|
||||||
package = pkgs.pass-nodmenu;
|
package = pkgs.pass-nodmenu;
|
||||||
settings.PASSWORD_STORE_DIR = "${config.xdg.dataHome}/pass";
|
settings.PASSWORD_STORE_DIR = "${config.xdg.dataHome}/pass";
|
||||||
};
|
};
|
||||||
|
@ -115,11 +116,6 @@ in
|
||||||
home = {
|
home = {
|
||||||
stateVersion = "22.11";
|
stateVersion = "22.11";
|
||||||
# Extra packages
|
# Extra packages
|
||||||
packages = [
|
|
||||||
pkgs.gopass
|
|
||||||
pkgs.sshfs
|
|
||||||
pkgs.unstable.gitoxide
|
|
||||||
];
|
|
||||||
# Extra variables
|
# Extra variables
|
||||||
sessionVariables = {
|
sessionVariables = {
|
||||||
CARGO_HOME = "${config.xdg.dataHome}/cargo";
|
CARGO_HOME = "${config.xdg.dataHome}/cargo";
|
||||||
|
|
|
@ -71,6 +71,8 @@ in
|
||||||
enable = true;
|
enable = true;
|
||||||
scripts = builtins.attrValues { inherit (pkgs.mpvScripts) uosc thumbfast; };
|
scripts = builtins.attrValues { inherit (pkgs.mpvScripts) uosc thumbfast; };
|
||||||
};
|
};
|
||||||
|
# Text editor
|
||||||
|
nixvim.clipboard.providers.wl-copy.enable = lib.mkDefault true;
|
||||||
# Status bar
|
# Status bar
|
||||||
waybar = {
|
waybar = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
|
|
@ -199,6 +199,7 @@ in
|
||||||
[ "typos" ] # low false positive rate typo checker
|
[ "typos" ] # low false positive rate typo checker
|
||||||
[ "gcc" ] # GNU Compiler Collection
|
[ "gcc" ] # GNU Compiler Collection
|
||||||
[ "git-absorb" ] # fixup! but automatic
|
[ "git-absorb" ] # fixup! but automatic
|
||||||
|
[ "gitoxide" ] # git but RiiR
|
||||||
[ "man-pages" ] # gimme the man pages
|
[ "man-pages" ] # gimme the man pages
|
||||||
[ "man-pages-posix" ] # I said gimme the man pages!!!
|
[ "man-pages-posix" ] # I said gimme the man pages!!!
|
||||||
];
|
];
|
||||||
|
|
|
@ -7,7 +7,6 @@
|
||||||
let
|
let
|
||||||
inherit (helpers) mkRaw;
|
inherit (helpers) mkRaw;
|
||||||
cfg = config.jhome.nvim;
|
cfg = config.jhome.nvim;
|
||||||
dev = cfg.dev.enable;
|
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
config.keymaps =
|
config.keymaps =
|
||||||
|
@ -202,8 +201,9 @@ in
|
||||||
'';
|
'';
|
||||||
options.desc = "Find Quickfix";
|
options.desc = "Find Quickfix";
|
||||||
}
|
}
|
||||||
|
]
|
||||||
# Nvim Silicon
|
# Nvim Silicon
|
||||||
{
|
++ lib.optional (!cfg.reduceSize) {
|
||||||
mode = "v";
|
mode = "v";
|
||||||
key = "<leader>sc";
|
key = "<leader>sc";
|
||||||
action =
|
action =
|
||||||
|
@ -215,8 +215,7 @@ in
|
||||||
'';
|
'';
|
||||||
options.desc = "Snap Code (to clipboard)";
|
options.desc = "Snap Code (to clipboard)";
|
||||||
}
|
}
|
||||||
]
|
++ lib.optional cfg.dev.enable {
|
||||||
++ lib.optional dev {
|
|
||||||
mode = "n";
|
mode = "n";
|
||||||
key = "<leader>w";
|
key = "<leader>w";
|
||||||
action =
|
action =
|
||||||
|
|
|
@ -12,6 +12,7 @@ in
|
||||||
{
|
{
|
||||||
options.jhome.nvim = {
|
options.jhome.nvim = {
|
||||||
enable = mkDisableOption "jalil's Neovim configuration";
|
enable = mkDisableOption "jalil's Neovim configuration";
|
||||||
|
reduceSize = mkEnableOption "reduce size by disabling big modules";
|
||||||
dev = mkOption {
|
dev = mkOption {
|
||||||
type = types.submodule {
|
type = types.submodule {
|
||||||
options = {
|
options = {
|
||||||
|
|
|
@ -1,4 +1,14 @@
|
||||||
{ pkgs, ... }:
|
{
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
config,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
cfg = config.jhome.nvim;
|
||||||
|
plugins = pkgs.vimPlugins;
|
||||||
|
extraPlugins = import ./extraPlugins { inherit pkgs; };
|
||||||
|
in
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
./options.nix
|
./options.nix
|
||||||
|
@ -8,7 +18,8 @@
|
||||||
./augroups.nix
|
./augroups.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
config = {
|
config = lib.mkMerge [
|
||||||
|
{
|
||||||
withRuby = false;
|
withRuby = false;
|
||||||
globals.mapleader = " ";
|
globals.mapleader = " ";
|
||||||
# Appearance
|
# Appearance
|
||||||
|
@ -20,7 +31,6 @@
|
||||||
terminal_colors = true;
|
terminal_colors = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
clipboard.providers.wl-copy.enable = true;
|
|
||||||
opts = {
|
opts = {
|
||||||
number = true;
|
number = true;
|
||||||
relativenumber = true;
|
relativenumber = true;
|
||||||
|
@ -42,22 +52,12 @@
|
||||||
# Enable local configuration :h 'exrc'
|
# Enable local configuration :h 'exrc'
|
||||||
exrc = true; # safe since nvim 0.9
|
exrc = true; # safe since nvim 0.9
|
||||||
};
|
};
|
||||||
extraPlugins =
|
extraPlugins = [
|
||||||
let
|
|
||||||
plugins = pkgs.vimPlugins;
|
|
||||||
extraPlugins = import ./extraPlugins { inherit pkgs; };
|
|
||||||
in
|
|
||||||
[
|
|
||||||
plugins.nui-nvim
|
plugins.nui-nvim
|
||||||
plugins.nvim-web-devicons
|
plugins.nvim-web-devicons
|
||||||
plugins.vim-jjdescription
|
plugins.vim-jjdescription # FIXME: included since neovim nightly
|
||||||
extraPlugins.nvim-silicon
|
|
||||||
];
|
|
||||||
# Formatting & linters
|
|
||||||
extraPackages = [
|
|
||||||
pkgs.luajitPackages.jsregexp
|
|
||||||
pkgs.silicon
|
|
||||||
];
|
];
|
||||||
|
extraPackages = [ pkgs.luajitPackages.jsregexp ];
|
||||||
extraConfigLuaPre =
|
extraConfigLuaPre =
|
||||||
# lua
|
# lua
|
||||||
''
|
''
|
||||||
|
@ -76,6 +76,11 @@
|
||||||
end
|
end
|
||||||
-- END: Lua Pre Config
|
-- END: Lua Pre Config
|
||||||
'';
|
'';
|
||||||
|
}
|
||||||
|
# Big packages that are kinda unnecessary
|
||||||
|
(lib.mkIf (!cfg.reduceSize) {
|
||||||
|
extraPlugins = [ extraPlugins.nvim-silicon ];
|
||||||
|
extraPackages = [ pkgs.silicon ];
|
||||||
extraConfigLua =
|
extraConfigLua =
|
||||||
# lua
|
# lua
|
||||||
''
|
''
|
||||||
|
@ -94,5 +99,6 @@
|
||||||
}
|
}
|
||||||
-- END: Lua Config
|
-- END: Lua Config
|
||||||
'';
|
'';
|
||||||
};
|
})
|
||||||
|
];
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue