summaryrefslogtreecommitdiff
path: root/users
diff options
context:
space:
mode:
Diffstat (limited to 'users')
-rw-r--r--users/seth/default.nix17
-rw-r--r--users/seth/desktop/default.nix11
-rw-r--r--users/seth/desktop/gnome.nix4
-rw-r--r--users/seth/desktop/plasma.nix4
-rw-r--r--users/seth/programs/default.nix11
-rw-r--r--users/seth/programs/git.nix4
-rw-r--r--users/seth/programs/mangohud.nix4
-rw-r--r--users/seth/programs/neovim.nix598
-rw-r--r--users/seth/shell/bash.nix2
-rw-r--r--users/seth/shell/default.nix2
-rw-r--r--users/seth/shell/fish.nix19
-rw-r--r--users/seth/shell/zsh.nix7
12 files changed, 348 insertions, 335 deletions
diff --git a/users/seth/default.nix b/users/seth/default.nix
index b278973..5f21214 100644
--- a/users/seth/default.nix
+++ b/users/seth/default.nix
@@ -1,11 +1,12 @@
-{ config
-, pkgs
-, home-manager
-, desktop
-, ...
+{
+ config,
+ pkgs,
+ home-manager,
+ desktop,
+ ...
}: {
users.users.seth = {
- extraGroups = [ "wheel" ];
+ extraGroups = ["wheel"];
isNormalUser = true;
hashedPassword = "***REMOVED***";
shell = pkgs.fish;
@@ -24,8 +25,8 @@
]
++ (
if (desktop != "")
- then [ ./desktop ]
- else [ ]
+ then [./desktop]
+ else []
);
home.stateVersion = config.system.stateVersion;
diff --git a/users/seth/desktop/default.nix b/users/seth/desktop/default.nix
index 7ad6434..254a831 100644
--- a/users/seth/desktop/default.nix
+++ b/users/seth/desktop/default.nix
@@ -1,6 +1,7 @@
-{ pkgs
-, desktop
-, ...
+{
+ pkgs,
+ desktop,
+ ...
}: {
imports =
[
@@ -8,8 +9,8 @@
]
++ (
if (desktop == "gnome")
- then [ ./gnome.nix ]
- else [ ./plasma.nix ]
+ then [./gnome.nix]
+ else [./plasma.nix]
);
home.packages = with pkgs; [
diff --git a/users/seth/desktop/gnome.nix b/users/seth/desktop/gnome.nix
index 6b80e14..f6dcd75 100644
--- a/users/seth/desktop/gnome.nix
+++ b/users/seth/desktop/gnome.nix
@@ -1,5 +1,5 @@
-{ pkgs, ... }: {
- home.packages = with pkgs; [ adw-gtk3 ] ++ (with pkgs.gnomeExtensions; [ appindicator blur-my-shell caffeine ]);
+{pkgs, ...}: {
+ home.packages = with pkgs; [adw-gtk3] ++ (with pkgs.gnomeExtensions; [appindicator blur-my-shell caffeine]);
dconf.settings = {
"org/gnome/shell" = {
diff --git a/users/seth/desktop/plasma.nix b/users/seth/desktop/plasma.nix
index dea84c2..fe8f986 100644
--- a/users/seth/desktop/plasma.nix
+++ b/users/seth/desktop/plasma.nix
@@ -1,3 +1,3 @@
-{ pkgs, ... }: {
- home.packages = with pkgs; [ catppuccin-kde ];
+{pkgs, ...}: {
+ home.packages = with pkgs; [catppuccin-kde];
}
diff --git a/users/seth/programs/default.nix b/users/seth/programs/default.nix
index a3471af..2b80cc8 100644
--- a/users/seth/programs/default.nix
+++ b/users/seth/programs/default.nix
@@ -1,4 +1,4 @@
-{ pkgs, ... }: {
+{pkgs, ...}: {
imports = [
./git.nix
./neovim.nix
@@ -22,5 +22,14 @@
statix
];
+ programs = {
+ direnv = {
+ enable = true;
+ nix-direnv = {
+ enable = true;
+ };
+ };
+ };
+
xdg.enable = true;
}
diff --git a/users/seth/programs/git.nix b/users/seth/programs/git.nix
index e4ddfa1..4ec67b8 100644
--- a/users/seth/programs/git.nix
+++ b/users/seth/programs/git.nix
@@ -2,8 +2,8 @@ _: {
programs.git = {
enable = true;
extraConfig = {
- init = { defaultBranch = "main"; };
- safe = { directory = "/etc/nixos"; };
+ init = {defaultBranch = "main";};
+ safe = {directory = "/etc/nixos";};
};
signing = {
key = "D31BD0D494BBEE86";
diff --git a/users/seth/programs/mangohud.nix b/users/seth/programs/mangohud.nix
index 2b33471..222501f 100644
--- a/users/seth/programs/mangohud.nix
+++ b/users/seth/programs/mangohud.nix
@@ -1,5 +1,5 @@
-{ pkgs, ... }: {
- home.packages = with pkgs; [ mangohud ];
+{pkgs, ...}: {
+ home.packages = with pkgs; [mangohud];
xdg.configFile."MangoHud.conf" = {
text = ''
diff --git a/users/seth/programs/neovim.nix b/users/seth/programs/neovim.nix
index f5c3a59..2a597b8 100644
--- a/users/seth/programs/neovim.nix
+++ b/users/seth/programs/neovim.nix
@@ -1,8 +1,9 @@
-{ pkgs, ... }: {
+{pkgs, ...}: {
programs.neovim = {
enable = true;
defaultEditor = true;
extraPackages = with pkgs; [
+ alejandra
clang
codespell
deadnix
@@ -10,7 +11,6 @@
nodePackages.bash-language-server
nodePackages.prettier
nodePackages.pyright
- nixpkgs-fmt
pylint
rust-analyzer
rustfmt
@@ -44,303 +44,303 @@
vim-vsnip
];
extraLuaConfig = ''
- local cmd = vim.cmd
- local opt = vim.opt
-
- -- text options
- opt.tabstop = 2
- opt.shiftwidth = 2
- opt.expandtab = false
- opt.smartindent = true
- opt.wrap = false
-
-
- -- appearance
- opt.syntax = "on"
- cmd("filetype plugin indent on")
- opt.termguicolors = true
-
- -- filetypes
- local filetypes = {
- filename = {
- PKGBUILD = "text",
- [".makepkg.conf"] = "text",
- },
- }
-
- vim.filetype.add(filetypes)
-
-
- -- helper functions/variables
- local cmp = require("cmp")
- local luasnip = require("luasnip")
- local null_ls = require("null-ls")
-
- --- catppuccin
- local compile_path = vim.fn.stdpath("cache") .. "/catppuccin-nvim"
- vim.fn.mkdir(compile_path, "p")
- vim.opt.runtimepath:append(compile_path)
-
- ---- cmp
- local mapping = cmp.mapping
- local has_words_before = function()
- local line, col = unpack(vim.api.nvim_win_get_cursor(0))
- return col ~= 0 and vim.api.nvim_buf_get_lines(0, line - 1, line, true)[1]:sub(col, col):match("%s") == nil
- end
-
- local feedkey = function(key, mode)
- vim.api.nvim_feedkeys(vim.api.nvim_replace_termcodes(key, true, true, true), mode, true)
- end
-
- local capabilities = require("cmp_nvim_lsp").default_capabilities()
- capabilities.textDocument.completion.completionItem.snippetSupport = true
-
- ---- null ls
- ------ nulls-ls shorthand
- local diagnostics = null_ls.builtins.diagnostics
- local formatting = null_ls.builtins.formatting
-
- ------ auto-format
- -- for neovim >= 8
- local lsp_formatting = function(bufnr)
- vim.lsp.buf.format({
- filter = function(client)
- return client.name == "null-ls"
- end,
- bufnr = bufnr,
- })
- end
-
- local augroup = vim.api.nvim_create_augroup("LspFormatting", {})
- local formatting_on_attach = function(client, bufnr)
- if client.supports_method("textDocument/formatting") then
- vim.api.nvim_clear_autocmds({ group = augroup, buffer = bufnr })
- vim.api.nvim_create_autocmd("BufWritePre", {
- group = augroup,
- buffer = bufnr,
- callback = function()
- -- for neovim < 8
- ---- local params = require("vim.lsp.util").make_formatting_params({})
- ---- client.request("textDocument/formatting", params, nil, bufnr)
- lsp_formatting(bufnr) -- neovim >= 8
- end,
- })
- end
- end
-
-
- -- plugin config
- bufferline_config = {
- animation = true,
- auto_hide = true,
- icons = true,
- maximum_padding = 2,
- semantic_letters = true,
- }
-
- catppuccin_config = {
- compile_path = compile_path,
- flavour = "mocha", -- mocha, macchiato, frappe, latte
- integrations = {
- barbar = true,
- gitsigns = true,
- lightspeed = true,
- cmp = true,
- nvimtree = true,
- treesitter_context = true,
- treesitter = true,
- telescope = true,
- lsp_trouble = true,
- },
- no_italic = true,
- }
-
- cmp_config = {
- snippet = {
- expand = function(args)
- vim.fn["vsnip#anonymous"](args.body)
- luasnip.lsp_expand(args.body)
- end,
- },
-
- mapping = mapping.preset.insert({
- ["<Tab>"] = cmp.mapping(function(fallback)
- if cmp.visible() then
- cmp.select_next_item()
- elseif luasnip.expand_or_jumpable() then
- luasnip.expand_or_jump()
- elseif vim.fn["vsnip#available"](1) == 1 then
- feedkey("<Plug>(vsnip-expand-or-jump)", "")
- elseif has_words_before() then
- cmp.complete()
- else
- fallback()
- end
- end, { "i", "s" }),
- ["<S-Tab>"] = cmp.mapping(function(fallback)
- if cmp.visible() then
- cmp.select_prev_item()
- elseif luasnip.jumpable(-1) then
- luasnip.jump(-1)
- elseif vim.fn["vsnip#available"](-1) == 1 then
- feedkey("<Plug>(vsnip-jump-prev)", "")
- else
- fallback()
- end
- end, { "i", "s" }),
- }),
-
- sources = cmp.config.sources({
- { name = "nvim_lsp" },
- { name = "luasnip" },
- { name = "vsnip" },
- { name = "buffer" },
- { name = "path" },
- }),
-
- capabilities = capabilities,
-
- on_attach = function(_, bufnr)
- vim.api.nvim_buf_set_option(bufnr, "omnifunc", "v:lua.vim.lsp.omnifunc")
- end,
- }
-
- sources = {
- lsp_servers = { "rust_analyzer", "pyright", "bashls" },
- null_ls = {
- diagnostics.alex,
- diagnostics.codespell,
- diagnostics.deadnix,
- diagnostics.pylint,
- diagnostics.statix,
- formatting.codespell,
- formatting.nixpkgs_fmt,
- formatting.prettier,
- formatting.rustfmt,
- formatting.stylua,
- formatting.yapf,
- }
- }
-
- local lsp_on_attach = function(client, bufnr)
- cmp_config.on_attach(client, bufnr)
- end
-
- local all_config = {
- capabilities = cmp.capabilities,
- on_attach = lsp_on_attach,
- }
-
- servers = {}
- for _, server in ipairs(sources.lsp_servers) do
- servers[server] = all_config
- end
-
- servers["lua_ls"] = {
- capabilities = cmp_config.capabilities,
- on_attach = lsp_on_attach,
- settings = {
- Lua = {
- runtime = {
- version = "LuaJIT",
- },
- diagnostics = {
- globals = { "vim" },
- },
- workspace = {
- library = vim.api.nvim_get_runtime_file("", true),
- },
- },
- },
- }
-
- lsp_config = {
- servers = servers
- }
-
- lualine_config = {
- options = {
- theme = "catppuccin",
- },
- extensions = { "nvim-tree" },
- }
-
- null_ls_config = {
- on_attach = formatting_on_attach,
- sources = sources.null_ls,
- }
-
- tree_config = {}
-
- treesitter_config = {
- auto_install = false,
- highlight = {
- enable = true,
- additional_vim_regex_highlighting = false,
- },
- }
-
- trouble = {}
-
-
- -- init plugins
- local lspconfig = require("lspconfig")
-
- require("bufferline").setup(bufferline_config)
- require("catppuccin").setup(catppuccin_config)
- vim.api.nvim_command("colorscheme catppuccin")
- require("cmp").setup(cmp_config)
- require("gitsigns").setup()
- require("lualine").setup(lualine_config)
- require("null-ls").setup(null_ls_config)
- require("nvim-tree").setup(tree_config)
- require("nvim-treesitter.configs").setup(treesitter_config)
- require("trouble").setup(trouble_config)
-
- for server, settings in pairs(lsp_config.servers) do
- lspconfig[server].setup(settings)
- end
-
-
- -- filetypes
- local opts = { noremap = true, silent = true }
- local set = function(mode, key, cmd)
- vim.keymap.set(mode, key, cmd, opts)
- end
-
-
- -- keybinds
- set("n", "<leader>t", function()
- vim.cmd("NvimTreeToggle")
- end)
-
- for i = 1, 9 do
- set("n", "<leader>" .. i, function()
- local cmd = "BufferGoto " .. i
- vim.cmd(cmd)
- end)
- end
-
- set("n", "<leader>p", function()
- vim.cmd("BufferPick")
- end)
-
- set("n", "<leader>q", function()
- vim.cmd("BufferClose")
- end)
-
- set("n", "<space>e", vim.diagnostic.open_float)
- set("n", "[d", vim.diagnostic.goto_prev)
- set("n", "]d", vim.diagnostic.goto_next)
- set("n", "<space>q", vim.diagnostic.setloclist)
-
- set("n", "<space>f", function()
- vim.cmd("Telescope")
- end)
-
- set("n", "<space>t", function()
- vim.cmd("TroubleToggle")
- end)
+ local cmd = vim.cmd
+ local opt = vim.opt
+
+ -- text options
+ opt.tabstop = 2
+ opt.shiftwidth = 2
+ opt.expandtab = false
+ opt.smartindent = true
+ opt.wrap = false
+
+
+ -- appearance
+ opt.syntax = "on"
+ cmd("filetype plugin indent on")
+ opt.termguicolors = true
+
+ -- filetypes
+ local filetypes = {
+ filename = {
+ PKGBUILD = "text",
+ [".makepkg.conf"] = "text",
+ },
+ }
+
+ vim.filetype.add(filetypes)
+
+
+ -- helper functions/variables
+ local cmp = require("cmp")
+ local luasnip = require("luasnip")
+ local null_ls = require("null-ls")
+
+ --- catppuccin
+ local compile_path = vim.fn.stdpath("cache") .. "/catppuccin-nvim"
+ vim.fn.mkdir(compile_path, "p")
+ vim.opt.runtimepath:append(compile_path)
+
+ ---- cmp
+ local mapping = cmp.mapping
+ local has_words_before = function()
+ local line, col = unpack(vim.api.nvim_win_get_cursor(0))
+ return col ~= 0 and vim.api.nvim_buf_get_lines(0, line - 1, line, true)[1]:sub(col, col):match("%s") == nil
+ end
+
+ local feedkey = function(key, mode)
+ vim.api.nvim_feedkeys(vim.api.nvim_replace_termcodes(key, true, true, true), mode, true)
+ end
+
+ local capabilities = require("cmp_nvim_lsp").default_capabilities()
+ capabilities.textDocument.completion.completionItem.snippetSupport = true
+
+ ---- null ls
+ ------ nulls-ls shorthand
+ local diagnostics = null_ls.builtins.diagnostics
+ local formatting = null_ls.builtins.formatting
+
+ ------ auto-format
+ -- for neovim >= 8
+ local lsp_formatting = function(bufnr)
+ vim.lsp.buf.format({
+ filter = function(client)
+ return client.name == "null-ls"
+ end,
+ bufnr = bufnr,
+ })
+ end
+
+ local augroup = vim.api.nvim_create_augroup("LspFormatting", {})
+ local formatting_on_attach = function(client, bufnr)
+ if client.supports_method("textDocument/formatting") then
+ vim.api.nvim_clear_autocmds({ group = augroup, buffer = bufnr })
+ vim.api.nvim_create_autocmd("BufWritePre", {
+ group = augroup,
+ buffer = bufnr,
+ callback = function()
+ -- for neovim < 8
+ ---- local params = require("vim.lsp.util").make_formatting_params({})
+ ---- client.request("textDocument/formatting", params, nil, bufnr)
+ lsp_formatting(bufnr) -- neovim >= 8
+ end,
+ })
+ end
+ end
+
+
+ -- plugin config
+ bufferline_config = {
+ animation = true,
+ auto_hide = true,
+ icons = true,
+ maximum_padding = 2,
+ semantic_letters = true,
+ }
+
+ catppuccin_config = {
+ compile_path = compile_path,
+ flavour = "mocha", -- mocha, macchiato, frappe, latte
+ integrations = {
+ barbar = true,
+ gitsigns = true,
+ lightspeed = true,
+ cmp = true,
+ nvimtree = true,
+ treesitter_context = true,
+ treesitter = true,
+ telescope = true,
+ lsp_trouble = true,
+ },
+ no_italic = true,
+ }
+
+ cmp_config = {
+ snippet = {
+ expand = function(args)
+ vim.fn["vsnip#anonymous"](args.body)
+ luasnip.lsp_expand(args.body)
+ end,
+ },
+
+ mapping = mapping.preset.insert({
+ ["<Tab>"] = cmp.mapping(function(fallback)
+ if cmp.visible() then
+ cmp.select_next_item()
+ elseif luasnip.expand_or_jumpable() then
+ luasnip.expand_or_jump()
+ elseif vim.fn["vsnip#available"](1) == 1 then
+ feedkey("<Plug>(vsnip-expand-or-jump)", "")
+ elseif has_words_before() then
+ cmp.complete()
+ else
+ fallback()
+ end
+ end, { "i", "s" }),
+ ["<S-Tab>"] = cmp.mapping(function(fallback)
+ if cmp.visible() then
+ cmp.select_prev_item()
+ elseif luasnip.jumpable(-1) then
+ luasnip.jump(-1)
+ elseif vim.fn["vsnip#available"](-1) == 1 then
+ feedkey("<Plug>(vsnip-jump-prev)", "")
+ else
+ fallback()
+ end
+ end, { "i", "s" }),
+ }),
+
+ sources = cmp.config.sources({
+ { name = "nvim_lsp" },
+ { name = "luasnip" },
+ { name = "vsnip" },
+ { name = "buffer" },
+ { name = "path" },
+ }),
+
+ capabilities = capabilities,
+
+ on_attach = function(_, bufnr)
+ vim.api.nvim_buf_set_option(bufnr, "omnifunc", "v:lua.vim.lsp.omnifunc")
+ end,
+ }
+
+ sources = {
+ lsp_servers = { "rust_analyzer", "pyright", "bashls" },
+ null_ls = {
+ diagnostics.alex,
+ diagnostics.codespell,
+ diagnostics.deadnix,
+ diagnostics.pylint,
+ diagnostics.statix,
+ formatting.alejandra,
+ formatting.codespell,
+ formatting.prettier,
+ formatting.rustfmt,
+ formatting.stylua,
+ formatting.yapf,
+ }
+ }
+
+ local lsp_on_attach = function(client, bufnr)
+ cmp_config.on_attach(client, bufnr)
+ end
+
+ local all_config = {
+ capabilities = cmp.capabilities,
+ on_attach = lsp_on_attach,
+ }
+
+ servers = {}
+ for _, server in ipairs(sources.lsp_servers) do
+ servers[server] = all_config
+ end
+
+ servers["lua_ls"] = {
+ capabilities = cmp_config.capabilities,
+ on_attach = lsp_on_attach,
+ settings = {
+ Lua = {
+ runtime = {
+ version = "LuaJIT",
+ },
+ diagnostics = {
+ globals = { "vim" },
+ },
+ workspace = {
+ library = vim.api.nvim_get_runtime_file("", true),
+ },
+ },
+ },
+ }
+
+ lsp_config = {
+ servers = servers
+ }
+
+ lualine_config = {
+ options = {
+ theme = "catppuccin",
+ },
+ extensions = { "nvim-tree" },
+ }
+
+ null_ls_config = {
+ on_attach = formatting_on_attach,
+ sources = sources.null_ls,
+ }
+
+ tree_config = {}
+
+ treesitter_config = {
+ auto_install = false,
+ highlight = {
+ enable = true,
+ additional_vim_regex_highlighting = false,
+ },
+ }
+
+ trouble = {}
+
+
+ -- init plugins
+ local lspconfig = require("lspconfig")
+
+ require("bufferline").setup(bufferline_config)
+ require("catppuccin").setup(catppuccin_config)
+ vim.api.nvim_command("colorscheme catppuccin")
+ require("cmp").setup(cmp_config)
+ require("gitsigns").setup()
+ require("lualine").setup(lualine_config)
+ require("null-ls").setup(null_ls_config)
+ require("nvim-tree").setup(tree_config)
+ require("nvim-treesitter.configs").setup(treesitter_config)
+ require("trouble").setup(trouble_config)
+
+ for server, settings in pairs(lsp_config.servers) do
+ lspconfig[server].setup(settings)
+ end
+
+
+ -- filetypes
+ local opts = { noremap = true, silent = true }
+ local set = function(mode, key, cmd)
+ vim.keymap.set(mode, key, cmd, opts)
+ end
+
+
+ -- keybinds
+ set("n", "<leader>t", function()
+ vim.cmd("NvimTreeToggle")
+ end)
+
+ for i = 1, 9 do
+ set("n", "<leader>" .. i, function()
+ local cmd = "BufferGoto " .. i
+ vim.cmd(cmd)
+ end)
+ end
+
+ set("n", "<leader>p", function()
+ vim.cmd("BufferPick")
+ end)
+
+ set("n", "<leader>q", function()
+ vim.cmd("BufferClose")
+ end)
+
+ set("n", "<space>e", vim.diagnostic.open_float)
+ set("n", "[d", vim.diagnostic.goto_prev)
+ set("n", "]d", vim.diagnostic.goto_next)
+ set("n", "<space>q", vim.diagnostic.setloclist)
+
+ set("n", "<space>f", function()
+ vim.cmd("Telescope")
+ end)
+
+ set("n", "<space>t", function()
+ vim.cmd("TroubleToggle")
+ end)
'';
};
diff --git a/users/seth/shell/bash.nix b/users/seth/shell/bash.nix
index 03f4985..f086ec4 100644
--- a/users/seth/shell/bash.nix
+++ b/users/seth/shell/bash.nix
@@ -1,4 +1,4 @@
-{ config, ... }: {
+{config, ...}: {
programs.bash = {
enable = true;
historyFile = "${config.xdg.stateHome}/bash/history";
diff --git a/users/seth/shell/default.nix b/users/seth/shell/default.nix
index 263bd22..3872731 100644
--- a/users/seth/shell/default.nix
+++ b/users/seth/shell/default.nix
@@ -1,4 +1,4 @@
-{ config, ... }: {
+{config, ...}: {
imports = [
./bash.nix
./fish.nix
diff --git a/users/seth/shell/fish.nix b/users/seth/shell/fish.nix
index a0a3046..b017f03 100644
--- a/users/seth/shell/fish.nix
+++ b/users/seth/shell/fish.nix
@@ -1,22 +1,23 @@
-{ pkgs, ... }: {
-
+{pkgs, ...}: {
xdg.configFile."fish/themes" = {
recursive = true;
source =
pkgs.fetchFromGitHub
- {
- owner = "catppuccin";
- repo = "fish";
- rev = "b90966686068b5ebc9f80e5b90fdf8c02ee7a0ba";
- sha256 = "sha256-wQlYQyqklU/79K2OXRZXg5LvuIugK7vhHgpahpLFaOw=";
- } + "/themes";
+ {
+ owner = "catppuccin";
+ repo = "fish";
+ rev = "b90966686068b5ebc9f80e5b90fdf8c02ee7a0ba";
+ sha256 = "sha256-wQlYQyqklU/79K2OXRZXg5LvuIugK7vhHgpahpLFaOw=";
+ }
+ + "/themes";
};
programs.fish = {
enable = true;
interactiveShellInit = ''
fish_config theme choose "Catppuccin Mocha"
- '';
+ direnv hook fish | source
+ '';
plugins = [
{
name = "autopair-fish";
diff --git a/users/seth/shell/zsh.nix b/users/seth/shell/zsh.nix
index dd2b58c..c6b7ee1 100644
--- a/users/seth/shell/zsh.nix
+++ b/users/seth/shell/zsh.nix
@@ -1,6 +1,7 @@
-{ config
-, pkgs
-, ...
+{
+ config,
+ pkgs,
+ ...
}: {
programs.zsh = {
enable = false;