forked from foxora/nix
Compare commits
7 commits
d512a54074
...
fbafcca488
| Author | SHA1 | Date | |
|---|---|---|---|
| fbafcca488 | |||
| 476258b8aa | |||
| cc953bd60e | |||
| 583cc19589 | |||
| 62b01c6294 | |||
| 8a4f8f5513 | |||
| 0d9b86942a |
20 changed files with 908 additions and 722 deletions
68
flake.lock
generated
68
flake.lock
generated
|
|
@ -144,26 +144,27 @@
|
||||||
"cerulean": {
|
"cerulean": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"deploy-rs": "deploy-rs",
|
"deploy-rs": "deploy-rs",
|
||||||
"home-manager": "home-manager",
|
|
||||||
"microvm": "microvm",
|
"microvm": "microvm",
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
"nixpkgs"
|
"nixpkgs"
|
||||||
],
|
],
|
||||||
"nt": "nt",
|
"nt": "nt",
|
||||||
|
"sops-nix": "sops-nix",
|
||||||
"systems": [
|
"systems": [
|
||||||
"systems"
|
"systems"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1771409623,
|
"lastModified": 1772502315,
|
||||||
"narHash": "sha256-1IhHueuQTVCVrui700IP9DfLXwb3kU2rnEWPSdxQY0k=",
|
"narHash": "sha256-DHE6jU97GZ+QfUdPi4plZRnXtAvtGubOxqA5sQ4DD9M=",
|
||||||
"ref": "refs/heads/main",
|
"ref": "bleeding",
|
||||||
"rev": "d5211287bd3cb96078f2053488d67d557848a8f2",
|
"rev": "9bab917d8cc3b16f3c73b1980fcb55a4b5ce5239",
|
||||||
"revCount": 176,
|
"revCount": 191,
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://tearforge.net/cry/cerulean"
|
"url": "https://tearforge.net/cry/cerulean"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
"ref": "bleeding",
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://tearforge.net/cry/cerulean"
|
"url": "https://tearforge.net/cry/cerulean"
|
||||||
}
|
}
|
||||||
|
|
@ -455,28 +456,6 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"home-manager": {
|
"home-manager": {
|
||||||
"inputs": {
|
|
||||||
"nixpkgs": [
|
|
||||||
"cerulean",
|
|
||||||
"nixpkgs"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1770260404,
|
|
||||||
"narHash": "sha256-3iVX1+7YUIt23hBx1WZsUllhbmP2EnXrV8tCRbLxHc8=",
|
|
||||||
"owner": "nix-community",
|
|
||||||
"repo": "home-manager",
|
|
||||||
"rev": "0d782ee42c86b196acff08acfbf41bb7d13eed5b",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "nix-community",
|
|
||||||
"ref": "release-25.11",
|
|
||||||
"repo": "home-manager",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"home-manager_2": {
|
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
"nixpkgs-unstable"
|
"nixpkgs-unstable"
|
||||||
|
|
@ -497,7 +476,7 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"home-manager_3": {
|
"home-manager_2": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
"zen",
|
"zen",
|
||||||
|
|
@ -1293,11 +1272,11 @@
|
||||||
},
|
},
|
||||||
"nixpkgs-master": {
|
"nixpkgs-master": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1771439456,
|
"lastModified": 1771702014,
|
||||||
"narHash": "sha256-HtQgNJrjYvZdpqpPJddF+TxGCazNyxvA8umbDcjrxT8=",
|
"narHash": "sha256-/P7uAp8q1xFhaw9Z+OG7lUK3wVz1Q/wreAyeiMyyjLI=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "f84d6f6cd5f17d594439710f40349ba7d0706f4b",
|
"rev": "cceb9213362e92c06b60b50c1e2877bc5fb95887",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|
@ -1548,7 +1527,7 @@
|
||||||
"awww": "awww",
|
"awww": "awww",
|
||||||
"cachyos": "cachyos",
|
"cachyos": "cachyos",
|
||||||
"cerulean": "cerulean",
|
"cerulean": "cerulean",
|
||||||
"home-manager": "home-manager_2",
|
"home-manager": "home-manager",
|
||||||
"hyprland-git": "hyprland-git",
|
"hyprland-git": "hyprland-git",
|
||||||
"hyprland-plugins": "hyprland-plugins",
|
"hyprland-plugins": "hyprland-plugins",
|
||||||
"iamb": "iamb",
|
"iamb": "iamb",
|
||||||
|
|
@ -1625,6 +1604,27 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"sops-nix": {
|
||||||
|
"inputs": {
|
||||||
|
"nixpkgs": [
|
||||||
|
"cerulean",
|
||||||
|
"nixpkgs"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1772495394,
|
||||||
|
"narHash": "sha256-hmIvE/slLKEFKNEJz27IZ8BKlAaZDcjIHmkZ7GCEjfw=",
|
||||||
|
"owner": "Mic92",
|
||||||
|
"repo": "sops-nix",
|
||||||
|
"rev": "1d9b98a29a45abe9c4d3174bd36de9f28755e3ff",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "Mic92",
|
||||||
|
"repo": "sops-nix",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"spectrum": {
|
"spectrum": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
|
|
@ -1856,7 +1856,7 @@
|
||||||
},
|
},
|
||||||
"zen": {
|
"zen": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"home-manager": "home-manager_3",
|
"home-manager": "home-manager_2",
|
||||||
"nixpkgs": "nixpkgs_10"
|
"nixpkgs": "nixpkgs_10"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
|
|
|
||||||
|
|
@ -15,7 +15,7 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
cerulean = {
|
cerulean = {
|
||||||
url = "git+https://tearforge.net/cry/cerulean";
|
url = "git+https://tearforge.net/cry/cerulean?ref=bleeding";
|
||||||
inputs = {
|
inputs = {
|
||||||
systems.follows = "systems";
|
systems.follows = "systems";
|
||||||
nixpkgs.follows = "nixpkgs";
|
nixpkgs.follows = "nixpkgs";
|
||||||
|
|
@ -70,6 +70,8 @@
|
||||||
extra-experimental-features = "pipe-operators";
|
extra-experimental-features = "pipe-operators";
|
||||||
};
|
};
|
||||||
|
|
||||||
outputs = inputs:
|
outputs = inputs: let
|
||||||
import ./snow.nix inputs;
|
inherit (inputs.cerulean) snow;
|
||||||
|
in
|
||||||
|
snow.flake inputs ./.;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -22,23 +22,35 @@ local function load_colors()
|
||||||
-- ensure the table has enough entries to avoid indexing issues
|
-- ensure the table has enough entries to avoid indexing issues
|
||||||
if #new_colors >= 18 then
|
if #new_colors >= 18 then
|
||||||
colors = new_colors
|
colors = new_colors
|
||||||
require('base16-colorscheme').setup({
|
require("base16-colorscheme").setup({
|
||||||
base00 = colors[17], base01 = colors[1], base02 = colors[3], base03 = colors[3],
|
base00 = colors[17],
|
||||||
base04 = colors[5], base05 = colors[8], base06 = colors[5], base07 = colors[8],
|
base01 = colors[1],
|
||||||
base08 = colors[18], base09 = colors[4], base0A = colors[11], base0B = colors[5],
|
base02 = colors[3],
|
||||||
base0C = colors[6], base0D = colors[7], base0E = colors[6], base0F = colors[16],
|
base03 = colors[3],
|
||||||
|
base04 = colors[5],
|
||||||
|
base05 = colors[8],
|
||||||
|
base06 = colors[5],
|
||||||
|
base07 = colors[8],
|
||||||
|
base08 = colors[18],
|
||||||
|
base09 = colors[4],
|
||||||
|
base0A = colors[11],
|
||||||
|
base0B = colors[5],
|
||||||
|
base0C = colors[6],
|
||||||
|
base0D = colors[7],
|
||||||
|
base0E = colors[6],
|
||||||
|
base0F = colors[16],
|
||||||
})
|
})
|
||||||
|
|
||||||
-- set colors for blink.cmp's completion menu
|
-- set colors for blink.cmp's completion menu
|
||||||
vim.api.nvim_set_hl(0, 'BlinkCmpMenu', { bg = colors[17] })
|
vim.api.nvim_set_hl(0, "BlinkCmpMenu", { bg = colors[17] })
|
||||||
vim.api.nvim_set_hl(0, 'BlinkCmpMenuBorder', { bg = colors[17], fg = colors[13] })
|
vim.api.nvim_set_hl(0, "BlinkCmpMenuBorder", { bg = colors[17], fg = colors[13] })
|
||||||
vim.api.nvim_set_hl(0, 'BlinkCmpMenuSelection', { bg = colors[15], fg = colors[17] })
|
vim.api.nvim_set_hl(0, "BlinkCmpMenuSelection", { bg = colors[15], fg = colors[17] })
|
||||||
vim.api.nvim_set_hl(0, 'BlinkCmpScrollBarThumb', { bg = colors[18] })
|
vim.api.nvim_set_hl(0, "BlinkCmpScrollBarThumb", { bg = colors[18] })
|
||||||
vim.api.nvim_set_hl(0, 'BlinkCmpKind', { bg = colors[17], fg = colors[14] })
|
vim.api.nvim_set_hl(0, "BlinkCmpKind", { bg = colors[17], fg = colors[14] })
|
||||||
vim.api.nvim_set_hl(0, 'BlinkCmpLabel', { bg = colors[17], fg = colors[18] })
|
vim.api.nvim_set_hl(0, "BlinkCmpLabel", { bg = colors[17], fg = colors[18] })
|
||||||
vim.api.nvim_set_hl(0, 'BlinkCmpLabelMatch', { bg = colors[17], fg = colors[18] })
|
vim.api.nvim_set_hl(0, "BlinkCmpLabelMatch", { bg = colors[17], fg = colors[18] })
|
||||||
vim.api.nvim_set_hl(0, 'BlinkCmpLabelDetail', { bg = colors[17], fg = colors[18] })
|
vim.api.nvim_set_hl(0, "BlinkCmpLabelDetail", { bg = colors[17], fg = colors[18] })
|
||||||
vim.api.nvim_set_hl(0, 'BlinkCmpLabelDescription', { bg = colors[17], fg = colors[18] })
|
vim.api.nvim_set_hl(0, "BlinkCmpLabelDescription", { bg = colors[17], fg = colors[18] })
|
||||||
else
|
else
|
||||||
print("Error: Not enough colors in file")
|
print("Error: Not enough colors in file")
|
||||||
end
|
end
|
||||||
|
|
@ -66,4 +78,3 @@ local function watch_colorscheme()
|
||||||
end
|
end
|
||||||
|
|
||||||
watch_colorscheme()
|
watch_colorscheme()
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -6,53 +6,60 @@ function M.on_attach(_, bufnr)
|
||||||
|
|
||||||
local nmap = function(keys, func, desc)
|
local nmap = function(keys, func, desc)
|
||||||
if desc then
|
if desc then
|
||||||
desc = 'LSP: ' .. desc
|
desc = "LSP: " .. desc
|
||||||
end
|
end
|
||||||
|
|
||||||
vim.keymap.set('n', keys, func, { buffer = bufnr, desc = desc })
|
vim.keymap.set("n", keys, func, { buffer = bufnr, desc = desc })
|
||||||
end
|
end
|
||||||
|
|
||||||
nmap('<leader>rn', vim.lsp.buf.rename, '[R]e[n]ame')
|
nmap("<leader>rn", vim.lsp.buf.rename, "[R]e[n]ame")
|
||||||
nmap('<leader>ca', vim.lsp.buf.code_action, '[C]ode [A]ction')
|
nmap("<leader>ca", vim.lsp.buf.code_action, "[C]ode [A]ction")
|
||||||
|
|
||||||
nmap('gd', vim.lsp.buf.definition, '[G]oto [D]efinition')
|
nmap("gd", vim.lsp.buf.definition, "[G]oto [D]efinition")
|
||||||
|
|
||||||
-- NOTE: why are these functions that call the telescope builtin?
|
-- NOTE: why are these functions that call the telescope builtin?
|
||||||
-- because otherwise they would load telescope eagerly when this is defined.
|
-- because otherwise they would load telescope eagerly when this is defined.
|
||||||
-- due to us using the on_require handler to make sure it is available.
|
-- due to us using the on_require handler to make sure it is available.
|
||||||
if nixCats('general.telescope') then
|
if nixCats("general.telescope") then
|
||||||
nmap('gr', function() require('telescope.builtin').lsp_references() end, '[G]oto [R]eferences')
|
nmap("gr", function()
|
||||||
nmap('gI', function() require('telescope.builtin').lsp_implementations() end, '[G]oto [I]mplementation')
|
require("telescope.builtin").lsp_references()
|
||||||
nmap('<leader>ds', function() require('telescope.builtin').lsp_document_symbols() end, '[D]ocument [S]ymbols')
|
end, "[G]oto [R]eferences")
|
||||||
nmap('<leader>ws', function() require('telescope.builtin').lsp_dynamic_workspace_symbols() end, '[W]orkspace [S]ymbols')
|
nmap("gI", function()
|
||||||
nmap('<leader>dd', "<cmd>Telescope diagnostics bufnr=0<CR>", '[D]ocument [D]iagnostics')
|
require("telescope.builtin").lsp_implementations()
|
||||||
nmap('<leader>wd', "<cmd>Telescope diagnostics<CR>", '[W]orkspace [D]iagnostics')
|
end, "[G]oto [I]mplementation")
|
||||||
|
nmap("<leader>ds", function()
|
||||||
|
require("telescope.builtin").lsp_document_symbols()
|
||||||
|
end, "[D]ocument [S]ymbols")
|
||||||
|
nmap("<leader>ws", function()
|
||||||
|
require("telescope.builtin").lsp_dynamic_workspace_symbols()
|
||||||
|
end, "[W]orkspace [S]ymbols")
|
||||||
|
nmap("<leader>dd", "<cmd>Telescope diagnostics bufnr=0<CR>", "[D]ocument [D]iagnostics")
|
||||||
|
nmap("<leader>wd", "<cmd>Telescope diagnostics<CR>", "[W]orkspace [D]iagnostics")
|
||||||
end -- TODO: someone who knows the builtin versions of these to do instead help me out please.
|
end -- TODO: someone who knows the builtin versions of these to do instead help me out please.
|
||||||
|
|
||||||
nmap('<leader>D', vim.lsp.buf.type_definition, 'Type [D]efinition')
|
nmap("<leader>D", vim.lsp.buf.type_definition, "Type [D]efinition")
|
||||||
nmap('<leader>e', vim.diagnostic.open_float, 'Show [E]rror')
|
nmap("<leader>e", vim.diagnostic.open_float, "Show [E]rror")
|
||||||
|
|
||||||
-- See `:help K` for why this keymap
|
-- See `:help K` for why this keymap
|
||||||
nmap('K', vim.lsp.buf.hover, 'Hover Documentation')
|
nmap("K", vim.lsp.buf.hover, "Hover Documentation")
|
||||||
nmap('<C-k>', vim.lsp.buf.signature_help, 'Signature Documentation')
|
nmap("<C-k>", vim.lsp.buf.signature_help, "Signature Documentation")
|
||||||
|
|
||||||
-- Lesser used LSP functionality
|
-- Lesser used LSP functionality
|
||||||
nmap('gD', vim.lsp.buf.declaration, '[G]oto [D]eclaration')
|
nmap("gD", vim.lsp.buf.declaration, "[G]oto [D]eclaration")
|
||||||
nmap('<leader>wa', vim.lsp.buf.add_workspace_folder, '[W]orkspace [A]dd Folder')
|
nmap("<leader>wa", vim.lsp.buf.add_workspace_folder, "[W]orkspace [A]dd Folder")
|
||||||
nmap('<leader>wr', vim.lsp.buf.remove_workspace_folder, '[W]orkspace [R]emove Folder')
|
nmap("<leader>wr", vim.lsp.buf.remove_workspace_folder, "[W]orkspace [R]emove Folder")
|
||||||
nmap('<leader>wl', function()
|
nmap("<leader>wl", function()
|
||||||
print(vim.inspect(vim.lsp.buf.list_workspace_folders()))
|
print(vim.inspect(vim.lsp.buf.list_workspace_folders()))
|
||||||
end, '[W]orkspace [L]ist Folders')
|
end, "[W]orkspace [L]ist Folders")
|
||||||
|
|
||||||
-- Create a command `:Format` local to the LSP buffer
|
-- Create a command `:Format` local to the LSP buffer
|
||||||
vim.api.nvim_buf_create_user_command(bufnr, 'Format', function(_)
|
vim.api.nvim_buf_create_user_command(bufnr, "Format", function(_)
|
||||||
vim.lsp.buf.format()
|
vim.lsp.buf.format()
|
||||||
end, { desc = 'Format current buffer with LSP' })
|
end, { desc = "Format current buffer with LSP" })
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function M.get(server_name)
|
function M.get(server_name)
|
||||||
local capabilities = require('blink.cmp').get_lsp_capabilities()
|
local capabilities = require("blink.cmp").get_lsp_capabilities()
|
||||||
|
|
||||||
return capabilities
|
return capabilities
|
||||||
end
|
end
|
||||||
|
|
|
||||||
|
|
@ -7,42 +7,42 @@ return {
|
||||||
"blink.cmp",
|
"blink.cmp",
|
||||||
event = { "InsertEnter", "CmdlineEnter" },
|
event = { "InsertEnter", "CmdlineEnter" },
|
||||||
on_require = "blink",
|
on_require = "blink",
|
||||||
load = function (name)
|
load = function(name)
|
||||||
vim.cmd.packadd(name)
|
vim.cmd.packadd(name)
|
||||||
end,
|
end,
|
||||||
after = function(plugin)
|
after = function(plugin)
|
||||||
local blink = require('blink.cmp')
|
local blink = require("blink.cmp")
|
||||||
|
|
||||||
blink.setup({
|
blink.setup({
|
||||||
keymap = {
|
keymap = {
|
||||||
preset = 'default',
|
preset = "default",
|
||||||
},
|
},
|
||||||
|
|
||||||
appearance = {
|
appearance = {
|
||||||
nerd_font_variant = 'mono',
|
nerd_font_variant = "mono",
|
||||||
},
|
},
|
||||||
|
|
||||||
sources = {
|
sources = {
|
||||||
default = { 'lsp', 'path', 'snippets', 'buffer' },
|
default = { "lsp", "path", "snippets", "buffer" },
|
||||||
providers = {
|
providers = {
|
||||||
lsp = {
|
lsp = {
|
||||||
name = 'LSP',
|
name = "LSP",
|
||||||
module = 'blink.cmp.sources.lsp',
|
module = "blink.cmp.sources.lsp",
|
||||||
enabled = true,
|
enabled = true,
|
||||||
},
|
},
|
||||||
path = {
|
path = {
|
||||||
name = 'Path',
|
name = "Path",
|
||||||
module = 'blink.cmp.sources.path',
|
module = "blink.cmp.sources.path",
|
||||||
enabled = true,
|
enabled = true,
|
||||||
},
|
},
|
||||||
snippets = {
|
snippets = {
|
||||||
name = 'Snippets',
|
name = "Snippets",
|
||||||
module = 'blink.cmp.sources.snippets',
|
module = "blink.cmp.sources.snippets",
|
||||||
enabled = true,
|
enabled = true,
|
||||||
},
|
},
|
||||||
buffer = {
|
buffer = {
|
||||||
name = 'Buffer',
|
name = "Buffer",
|
||||||
module = 'blink.cmp.sources.buffer',
|
module = "blink.cmp.sources.buffer",
|
||||||
enabled = true,
|
enabled = true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
@ -56,14 +56,14 @@ return {
|
||||||
},
|
},
|
||||||
|
|
||||||
menu = {
|
menu = {
|
||||||
border = 'rounded',
|
border = "rounded",
|
||||||
max_height = 12,
|
max_height = 12,
|
||||||
scrolloff = 2,
|
scrolloff = 2,
|
||||||
|
|
||||||
draw = {
|
draw = {
|
||||||
columns = {
|
columns = {
|
||||||
{ "kind_icon", gap = 1, },
|
{ "kind_icon", gap = 1 },
|
||||||
{ "label", "label_description", gap = 1, },
|
{ "label", "label_description", gap = 1 },
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
@ -71,7 +71,7 @@ return {
|
||||||
documentation = {
|
documentation = {
|
||||||
auto_show = false,
|
auto_show = false,
|
||||||
window = {
|
window = {
|
||||||
border = 'rounded',
|
border = "rounded",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
@ -79,10 +79,10 @@ return {
|
||||||
signature = {
|
signature = {
|
||||||
enabled = true,
|
enabled = true,
|
||||||
window = {
|
window = {
|
||||||
border = 'rounded',
|
border = "rounded",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
end
|
end,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
require("lze").load {
|
require("lze").load({
|
||||||
{ import = "lsp.completion", },
|
{ import = "lsp.completion" },
|
||||||
}
|
})
|
||||||
|
|
||||||
require("lsp.indentation")
|
require("lsp.indentation")
|
||||||
require("lsp.lsp")
|
require("lsp.lsp")
|
||||||
|
|
|
||||||
|
|
@ -8,7 +8,7 @@ servers.lua_ls = {
|
||||||
},
|
},
|
||||||
signatureHelp = { enable = true },
|
signatureHelp = { enable = true },
|
||||||
diagnostics = {
|
diagnostics = {
|
||||||
globals = { 'nixCats', 'vim' },
|
globals = { "nixCats", "vim" },
|
||||||
-- disable = { 'missing-fields' },
|
-- disable = { 'missing-fields' },
|
||||||
},
|
},
|
||||||
workspace = {
|
workspace = {
|
||||||
|
|
@ -67,7 +67,7 @@ local java_home = os.getenv("JAVA_HOME")
|
||||||
servers.jdtls = {
|
servers.jdtls = {
|
||||||
settings = {
|
settings = {
|
||||||
java = {
|
java = {
|
||||||
contentProvider = { preferred = 'fernflower' },
|
contentProvider = { preferred = "fernflower" },
|
||||||
configuration = {
|
configuration = {
|
||||||
runtimes = {
|
runtimes = {
|
||||||
{
|
{
|
||||||
|
|
@ -78,10 +78,10 @@ servers.jdtls = {
|
||||||
name = "OpenJDK 21",
|
name = "OpenJDK 21",
|
||||||
path = os.getenv("OPENJDK_21"),
|
path = os.getenv("OPENJDK_21"),
|
||||||
},
|
},
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
}
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
-- Taken from nixCats example:
|
-- Taken from nixCats example:
|
||||||
|
|
@ -90,14 +90,14 @@ servers.jdtls = {
|
||||||
-- nvim-lspconfig, it would do the same thing.
|
-- nvim-lspconfig, it would do the same thing.
|
||||||
-- come to think of it, it might be better because then lspconfig doesnt have to be called before lsp attach?
|
-- come to think of it, it might be better because then lspconfig doesnt have to be called before lsp attach?
|
||||||
-- but you would still end up triggering on a FileType event anyway, so, it makes little difference.
|
-- but you would still end up triggering on a FileType event anyway, so, it makes little difference.
|
||||||
vim.api.nvim_create_autocmd('LspAttach', {
|
vim.api.nvim_create_autocmd("LspAttach", {
|
||||||
group = vim.api.nvim_create_augroup('nixCats-lsp-attach', { clear = true }),
|
group = vim.api.nvim_create_augroup("nixCats-lsp-attach", { clear = true }),
|
||||||
callback = function(event)
|
callback = function(event)
|
||||||
require('lsp.capabilities').on_attach(vim.lsp.get_client_by_id(event.data.client_id), event.buf)
|
require("lsp.capabilities").on_attach(vim.lsp.get_client_by_id(event.data.client_id), event.buf)
|
||||||
end
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
require("lze").load {
|
require("lze").load({
|
||||||
{
|
{
|
||||||
"nvim-lspconfig",
|
"nvim-lspconfig",
|
||||||
event = "FileType",
|
event = "FileType",
|
||||||
|
|
@ -105,7 +105,7 @@ require("lze").load {
|
||||||
-- Just register configs, don't enable yet
|
-- Just register configs, don't enable yet
|
||||||
for server_name, cfg in pairs(servers) do
|
for server_name, cfg in pairs(servers) do
|
||||||
vim.lsp.config(server_name, {
|
vim.lsp.config(server_name, {
|
||||||
capabilities = require('lsp.capabilities').get(server_name),
|
capabilities = require("lsp.capabilities").get(server_name),
|
||||||
settings = (cfg or {}).settings,
|
settings = (cfg or {}).settings,
|
||||||
filetypes = (cfg or {}).filetypes,
|
filetypes = (cfg or {}).filetypes,
|
||||||
cmd = (cfg or {}).cmd,
|
cmd = (cfg or {}).cmd,
|
||||||
|
|
@ -117,7 +117,7 @@ require("lze").load {
|
||||||
for server_name, cfg in pairs(servers) do
|
for server_name, cfg in pairs(servers) do
|
||||||
local filetypes = cfg.filetypes or vim.lsp.config[server_name].filetypes
|
local filetypes = cfg.filetypes or vim.lsp.config[server_name].filetypes
|
||||||
if filetypes then
|
if filetypes then
|
||||||
vim.api.nvim_create_autocmd('FileType', {
|
vim.api.nvim_create_autocmd("FileType", {
|
||||||
pattern = filetypes,
|
pattern = filetypes,
|
||||||
callback = function()
|
callback = function()
|
||||||
vim.lsp.enable(server_name)
|
vim.lsp.enable(server_name)
|
||||||
|
|
@ -127,4 +127,4 @@ require("lze").load {
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
},
|
},
|
||||||
}
|
})
|
||||||
|
|
|
||||||
23
homes/modules/programs/neovim/lua/plugins/comment.lua
Normal file
23
homes/modules/programs/neovim/lua/plugins/comment.lua
Normal file
|
|
@ -0,0 +1,23 @@
|
||||||
|
return {
|
||||||
|
{
|
||||||
|
"comment.nvim",
|
||||||
|
event = { "BufReadPost", "BufNewFile" },
|
||||||
|
after = function(plugin)
|
||||||
|
require("Comment").setup({
|
||||||
|
toggler = {
|
||||||
|
line = "<leader>cc",
|
||||||
|
block = "<leader>bc",
|
||||||
|
},
|
||||||
|
opLeader = {
|
||||||
|
line = "<leader>c",
|
||||||
|
block = "<leader>b",
|
||||||
|
},
|
||||||
|
extra = {
|
||||||
|
above = "<leader>c0",
|
||||||
|
below = "<leader>bo",
|
||||||
|
eol = "<leader>cA",
|
||||||
|
},
|
||||||
|
})
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
return {
|
return {
|
||||||
{
|
{
|
||||||
"dressing.nvim"
|
"dressing.nvim",
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
||||||
33
homes/modules/programs/neovim/lua/plugins/format.lua
Normal file
33
homes/modules/programs/neovim/lua/plugins/format.lua
Normal file
|
|
@ -0,0 +1,33 @@
|
||||||
|
-- docs -> https://github.com/stevearc/conform.nvim
|
||||||
|
return {
|
||||||
|
{
|
||||||
|
"conform.nvim",
|
||||||
|
enabled = nixCats("format") or false,
|
||||||
|
keys = {
|
||||||
|
{ "<leader>p", desc = "Format File (pretty :3)" },
|
||||||
|
},
|
||||||
|
after = function(plugin)
|
||||||
|
local conform = require("conform")
|
||||||
|
|
||||||
|
conform.setup({
|
||||||
|
formatters_by_ft = {
|
||||||
|
lua = nixCats("lang.lua.format") and { "stylua" } or nil,
|
||||||
|
nix = nixCats("lang.nix.format") and { "nixfmt" } or nil,
|
||||||
|
rust = nixCats("lang.rust.format") and { "rustfmt", lsp_format = "fallback" } or nil,
|
||||||
|
haskell = nixCats("lang.haskell.format") and { "ormolu" } or nil,
|
||||||
|
},
|
||||||
|
format_on_save = {
|
||||||
|
timeout_ms = 500,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
vim.keymap.set({ "n", "v" }, "<leader>p", function()
|
||||||
|
conform.format({
|
||||||
|
lsp_fallback = false,
|
||||||
|
async = false,
|
||||||
|
timeout_ms = 1000,
|
||||||
|
})
|
||||||
|
end, { desc = "Format File (pretty :3)" })
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
@ -3,9 +3,16 @@ return {
|
||||||
"fyler.nvim",
|
"fyler.nvim",
|
||||||
cmd = { "Fyler" },
|
cmd = { "Fyler" },
|
||||||
keys = {
|
keys = {
|
||||||
{ "<leader>tf", function() return require('fyler').toggle({ kind = "split_right" }) end, mode = {"n"}, desc = 'Open [F]yler' },
|
{
|
||||||
|
"<leader>tf",
|
||||||
|
function()
|
||||||
|
return require("fyler").toggle({ kind = "split_right" })
|
||||||
|
end,
|
||||||
|
mode = { "n" },
|
||||||
|
desc = "Open [F]yler",
|
||||||
},
|
},
|
||||||
load = function (name)
|
},
|
||||||
|
load = function(name)
|
||||||
vim.cmd.packadd(name)
|
vim.cmd.packadd(name)
|
||||||
end,
|
end,
|
||||||
after = function(plugin)
|
after = function(plugin)
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,9 @@
|
||||||
require("lze").load {
|
require("lze").load({
|
||||||
{ import = "plugins.dressing", },
|
{ import = "plugins.dressing" },
|
||||||
{ import = "plugins.telescope", },
|
{ import = "plugins.telescope" },
|
||||||
{ import = "plugins.treesitter", },
|
{ import = "plugins.treesitter" },
|
||||||
{ import = "plugins.fyler", },
|
{ import = "plugins.fyler" },
|
||||||
{ import = "plugins.mini-hipatterns", },
|
{ import = "plugins.mini-hipatterns" },
|
||||||
}
|
{ import = "plugins.format" },
|
||||||
|
{ import = "plugins.comment" },
|
||||||
|
})
|
||||||
|
|
|
||||||
|
|
@ -9,9 +9,9 @@ return {
|
||||||
---@param match string
|
---@param match string
|
||||||
---@return string
|
---@return string
|
||||||
local hex_color_short = function(_, match)
|
local hex_color_short = function(_, match)
|
||||||
local style = 'fg' -- 'fg' or 'bg', for extmark_opts_inline use 'fg'
|
local style = "fg" -- 'fg' or 'bg', for extmark_opts_inline use 'fg'
|
||||||
local r, g, b = match:sub(2, 2), match:sub(3, 3), match:sub(4, 4)
|
local r, g, b = match:sub(2, 2), match:sub(3, 3), match:sub(4, 4)
|
||||||
local hex = string.format('#%s%s%s%s%s%s', r, r, g, g, b, b)
|
local hex = string.format("#%s%s%s%s%s%s", r, r, g, g, b, b)
|
||||||
return hipatterns.compute_hex_color_group(hex, style)
|
return hipatterns.compute_hex_color_group(hex, style)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
@ -20,9 +20,9 @@ return {
|
||||||
---@param match string
|
---@param match string
|
||||||
---@return string
|
---@return string
|
||||||
local hex_color_alpha = function(_, match)
|
local hex_color_alpha = function(_, match)
|
||||||
local style = 'fg' -- 'fg' or 'bg', for extmark_opts_inline use 'fg'
|
local style = "fg" -- 'fg' or 'bg', for extmark_opts_inline use 'fg'
|
||||||
local r, g, b = match:sub(2, 3), match:sub(4, 5), match:sub(6, 7)
|
local r, g, b = match:sub(2, 3), match:sub(4, 5), match:sub(6, 7)
|
||||||
local hex = string.format('#%s%s%s', r, g, b)
|
local hex = string.format("#%s%s%s", r, g, b)
|
||||||
return hipatterns.compute_hex_color_group(hex, style)
|
return hipatterns.compute_hex_color_group(hex, style)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
@ -32,8 +32,8 @@ return {
|
||||||
---@return table
|
---@return table
|
||||||
local extmark_opts_inline = function(_, _, data)
|
local extmark_opts_inline = function(_, _, data)
|
||||||
return {
|
return {
|
||||||
virt_text = { { '', data.hl_group } },
|
virt_text = { { "", data.hl_group } },
|
||||||
virt_text_pos = 'inline',
|
virt_text_pos = "inline",
|
||||||
right_gravity = false,
|
right_gravity = false,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
@ -44,8 +44,8 @@ return {
|
||||||
---@return table
|
---@return table
|
||||||
local extmark_opts_inline_alpha = function(_, _, data)
|
local extmark_opts_inline_alpha = function(_, _, data)
|
||||||
return {
|
return {
|
||||||
virt_text = { { '', data.hl_group } },
|
virt_text = { { "", data.hl_group } },
|
||||||
virt_text_pos = 'inline',
|
virt_text_pos = "inline",
|
||||||
right_gravity = false,
|
right_gravity = false,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
@ -55,7 +55,7 @@ return {
|
||||||
-- #rrggbb
|
-- #rrggbb
|
||||||
hex_color = hipatterns.gen_highlighter.hex_color({
|
hex_color = hipatterns.gen_highlighter.hex_color({
|
||||||
style = "inline",
|
style = "inline",
|
||||||
inline_text = '',
|
inline_text = "",
|
||||||
}),
|
}),
|
||||||
-- #rgb
|
-- #rgb
|
||||||
hex_color_short = {
|
hex_color_short = {
|
||||||
|
|
|
||||||
|
|
@ -3,14 +3,56 @@ return {
|
||||||
"telescope.nvim",
|
"telescope.nvim",
|
||||||
cmd = { "Telescope" },
|
cmd = { "Telescope" },
|
||||||
keys = {
|
keys = {
|
||||||
{ "<leader>f", function() return require('telescope.builtin').find_files() end, mode = {"n"}, desc = 'Telescope search [F]iles' },
|
{
|
||||||
{ "<leader>tr", function() return require('telescope.builtin').oldfiles() end, mode = {"n"}, desc = '[T]elescope search [R]ecent files' },
|
"<leader>f",
|
||||||
{ "<leader>ts", function() return require('telescope.builtin').live_grep() end, mode = {"n"}, desc = '[T]elescope [S]earch cwd with grep' },
|
function()
|
||||||
{ "<leader>tw", function() return require('telescope.builtin').grep_string() end, mode = {"n"}, desc = '[T]elescope search current [W]ord' },
|
return require("telescope.builtin").find_files()
|
||||||
{ "<leader>tk", function() return require('telescope.builtin').keymaps() end, mode = {"n"}, desc = '[T]elescope search [K]eymaps' },
|
end,
|
||||||
{ "<leader>tb", function() return require('telescope.builtin').buffers() end, mode = {"n"}, desc = '[T]elescope search [B]uffers' },
|
mode = { "n" },
|
||||||
|
desc = "Telescope search [F]iles",
|
||||||
},
|
},
|
||||||
load = function (name)
|
{
|
||||||
|
"<leader>tr",
|
||||||
|
function()
|
||||||
|
return require("telescope.builtin").oldfiles()
|
||||||
|
end,
|
||||||
|
mode = { "n" },
|
||||||
|
desc = "[T]elescope search [R]ecent files",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>ts",
|
||||||
|
function()
|
||||||
|
return require("telescope.builtin").live_grep()
|
||||||
|
end,
|
||||||
|
mode = { "n" },
|
||||||
|
desc = "[T]elescope [S]earch cwd with grep",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>tw",
|
||||||
|
function()
|
||||||
|
return require("telescope.builtin").grep_string()
|
||||||
|
end,
|
||||||
|
mode = { "n" },
|
||||||
|
desc = "[T]elescope search current [W]ord",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>tk",
|
||||||
|
function()
|
||||||
|
return require("telescope.builtin").keymaps()
|
||||||
|
end,
|
||||||
|
mode = { "n" },
|
||||||
|
desc = "[T]elescope search [K]eymaps",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>tb",
|
||||||
|
function()
|
||||||
|
return require("telescope.builtin").buffers()
|
||||||
|
end,
|
||||||
|
mode = { "n" },
|
||||||
|
desc = "[T]elescope search [B]uffers",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
load = function(name)
|
||||||
vim.cmd.packadd(name)
|
vim.cmd.packadd(name)
|
||||||
vim.cmd.packadd("telescope-fzf-native.nvim")
|
vim.cmd.packadd("telescope-fzf-native.nvim")
|
||||||
end,
|
end,
|
||||||
|
|
@ -18,17 +60,17 @@ return {
|
||||||
local telescope = require("telescope")
|
local telescope = require("telescope")
|
||||||
local actions = require("telescope.actions")
|
local actions = require("telescope.actions")
|
||||||
|
|
||||||
telescope.setup {
|
telescope.setup({
|
||||||
defaults = {
|
defaults = {
|
||||||
mappings = {
|
mappings = {
|
||||||
i = {
|
i = {
|
||||||
["<C-k>"] = actions.move_selection_previous, -- move to prev result
|
["<C-k>"] = actions.move_selection_previous, -- move to prev result
|
||||||
["<C-j>"] = actions.move_selection_next, -- move to next result
|
["<C-j>"] = actions.move_selection_next, -- move to next result
|
||||||
["<C-q>"] = actions.send_selected_to_qflist + actions.open_qflist
|
["<C-q>"] = actions.send_selected_to_qflist + actions.open_qflist,
|
||||||
}
|
},
|
||||||
}
|
},
|
||||||
}
|
},
|
||||||
}
|
})
|
||||||
|
|
||||||
pcall(telescope.load_extension, "fzf")
|
pcall(telescope.load_extension, "fzf")
|
||||||
end,
|
end,
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@ return {
|
||||||
{
|
{
|
||||||
"nvim-treesitter",
|
"nvim-treesitter",
|
||||||
lazy = false,
|
lazy = false,
|
||||||
after = function (plugin)
|
after = function(plugin)
|
||||||
--@param buf integer
|
--@param buf integer
|
||||||
--@param language string
|
--@param language string
|
||||||
local function treesitter_try_attach(buf, language)
|
local function treesitter_try_attach(buf, language)
|
||||||
|
|
@ -58,33 +58,33 @@ return {
|
||||||
vim.g.no_plugin_maps = true
|
vim.g.no_plugin_maps = true
|
||||||
end,
|
end,
|
||||||
after = function(plugin)
|
after = function(plugin)
|
||||||
require("nvim-treesitter-textobjects").setup {
|
require("nvim-treesitter-textobjects").setup({
|
||||||
select = {
|
select = {
|
||||||
lookahead = true,
|
lookahead = true,
|
||||||
selection_modes = {
|
selection_modes = {
|
||||||
['@parameter.outer'] = 'v', -- charwise
|
["@parameter.outer"] = "v", -- charwise
|
||||||
['@function.outer'] = 'V', -- linewise
|
["@function.outer"] = "V", -- linewise
|
||||||
},
|
},
|
||||||
include_surrounding_whitespace = false,
|
include_surrounding_whitespace = false,
|
||||||
},
|
},
|
||||||
}
|
})
|
||||||
|
|
||||||
-- keymaps
|
-- keymaps
|
||||||
vim.keymap.set({ "x", "o" }, "am", function()
|
vim.keymap.set({ "x", "o" }, "am", function()
|
||||||
require "nvim-treesitter-textobjects.select".select_textobject("@function.outer", "textobjects")
|
require("nvim-treesitter-textobjects.select").select_textobject("@function.outer", "textobjects")
|
||||||
end)
|
end)
|
||||||
vim.keymap.set({ "x", "o" }, "im", function()
|
vim.keymap.set({ "x", "o" }, "im", function()
|
||||||
require "nvim-treesitter-textobjects.select".select_textobject("@function.inner", "textobjects")
|
require("nvim-treesitter-textobjects.select").select_textobject("@function.inner", "textobjects")
|
||||||
end)
|
end)
|
||||||
vim.keymap.set({ "x", "o" }, "ac", function()
|
vim.keymap.set({ "x", "o" }, "ac", function()
|
||||||
require "nvim-treesitter-textobjects.select".select_textobject("@class.outer", "textobjects")
|
require("nvim-treesitter-textobjects.select").select_textobject("@class.outer", "textobjects")
|
||||||
end)
|
end)
|
||||||
vim.keymap.set({ "x", "o" }, "ic", function()
|
vim.keymap.set({ "x", "o" }, "ic", function()
|
||||||
require "nvim-treesitter-textobjects.select".select_textobject("@class.inner", "textobjects")
|
require("nvim-treesitter-textobjects.select").select_textobject("@class.inner", "textobjects")
|
||||||
end)
|
end)
|
||||||
-- You can also use captures from other query groups like `locals.scm`
|
-- You can also use captures from other query groups like `locals.scm`
|
||||||
vim.keymap.set({ "x", "o" }, "as", function()
|
vim.keymap.set({ "x", "o" }, "as", function()
|
||||||
require "nvim-treesitter-textobjects.select".select_textobject("@local.scope", "locals")
|
require("nvim-treesitter-textobjects.select").select_textobject("@local.scope", "locals")
|
||||||
end)
|
end)
|
||||||
|
|
||||||
-- NOTE: for more textobjects options, see the following link.
|
-- NOTE: for more textobjects options, see the following link.
|
||||||
|
|
|
||||||
|
|
@ -1,14 +1,17 @@
|
||||||
|
# TODO: look into changing to this:
|
||||||
|
# https://github.com/BirdeeHub/nix-wrapper-modules
|
||||||
{
|
{
|
||||||
inputs,
|
inputs,
|
||||||
spkgs,
|
spkgs,
|
||||||
mpkgs,
|
mpkgs,
|
||||||
...
|
...
|
||||||
}: let
|
}:
|
||||||
inherit
|
let
|
||||||
(inputs.nixcats)
|
inherit (inputs.nixcats)
|
||||||
utils
|
utils
|
||||||
;
|
;
|
||||||
in {
|
in
|
||||||
|
{
|
||||||
imports = [
|
imports = [
|
||||||
inputs.nixcats.homeModule
|
inputs.nixcats.homeModule
|
||||||
];
|
];
|
||||||
|
|
@ -23,22 +26,21 @@ in {
|
||||||
# add any plugins in inputs named "plugins-pluginName" to pkgs.neovimPlugins
|
# add any plugins in inputs named "plugins-pluginName" to pkgs.neovimPlugins
|
||||||
# It will not apply to overall system, just nixCats.
|
# It will not apply to overall system, just nixCats.
|
||||||
addOverlays =
|
addOverlays =
|
||||||
/*
|
# (import ./overlays inputs) ++
|
||||||
(import ./overlays inputs) ++
|
|
||||||
*/
|
|
||||||
[
|
[
|
||||||
(utils.standardPluginOverlay inputs)
|
(utils.standardPluginOverlay inputs)
|
||||||
];
|
];
|
||||||
# see the packageDefinitions below.
|
# see the packageDefinitions below.
|
||||||
# This says which of those to install.
|
# This says which of those to install.
|
||||||
packageNames = ["auroranvim"];
|
packageNames = [ "auroranvim" ];
|
||||||
|
|
||||||
luaPath = "${./.}";
|
luaPath = "${./.}";
|
||||||
|
|
||||||
# the .replace vs .merge options are for modules based on existing configurations,
|
# the .replace vs .merge options are for modules based on existing configurations,
|
||||||
# they refer to how multiple categoryDefinitions get merged together by the module.
|
# they refer to how multiple categoryDefinitions get merged together by the module.
|
||||||
# for useage of this section, refer to :h nixCats.flake.outputs.categories
|
# for useage of this section, refer to :h nixCats.flake.outputs.categories
|
||||||
categoryDefinitions.replace = {
|
categoryDefinitions.replace =
|
||||||
|
{
|
||||||
pkgs,
|
pkgs,
|
||||||
settings,
|
settings,
|
||||||
categories,
|
categories,
|
||||||
|
|
@ -46,41 +48,49 @@ in {
|
||||||
name,
|
name,
|
||||||
mkNvimPlugin,
|
mkNvimPlugin,
|
||||||
...
|
...
|
||||||
} @ packageDef: {
|
}@packageDef:
|
||||||
lspsAndRuntimeDeps = {
|
{
|
||||||
general = with pkgs; [
|
lspsAndRuntimeDeps = with pkgs; {
|
||||||
|
general = [
|
||||||
ripgrep
|
ripgrep
|
||||||
fd
|
fd
|
||||||
];
|
];
|
||||||
treesitter = with pkgs; [
|
treesitter = [
|
||||||
tree-sitter
|
tree-sitter
|
||||||
];
|
];
|
||||||
lang = with pkgs; {
|
lang = {
|
||||||
lua = [
|
lua = {
|
||||||
lua-language-server
|
lsp = [ lua-language-server ];
|
||||||
];
|
format = [ stylua ];
|
||||||
nix = [
|
};
|
||||||
|
nix = {
|
||||||
|
lsp = [
|
||||||
nil
|
nil
|
||||||
nix-doc
|
nix-doc # TODO: i forgot what this is for
|
||||||
];
|
];
|
||||||
rust = with pkgs; [
|
format = [ nixfmt ];
|
||||||
|
};
|
||||||
|
rust = {
|
||||||
|
lsp = [
|
||||||
cargo
|
cargo
|
||||||
mpkgs.rust-analyzer
|
mpkgs.rust-analyzer
|
||||||
];
|
];
|
||||||
zig = with pkgs; [
|
format = [ rustfmt ];
|
||||||
|
};
|
||||||
|
zig = [
|
||||||
spkgs.zls # FIX: using spkgs version as zls is broken rn ;-;
|
spkgs.zls # FIX: using spkgs version as zls is broken rn ;-;
|
||||||
];
|
];
|
||||||
elixir = with pkgs; [
|
elixir = [
|
||||||
elixir-ls
|
elixir-ls
|
||||||
];
|
];
|
||||||
gleam = with pkgs; [
|
gleam = [
|
||||||
gleam
|
gleam
|
||||||
];
|
];
|
||||||
haskell = with pkgs; [
|
haskell = {
|
||||||
haskell-language-server
|
lsp = [ haskell-language-server ];
|
||||||
ormolu
|
format = [ ormolu ];
|
||||||
];
|
};
|
||||||
java = with pkgs; [
|
java = [
|
||||||
jdt-language-server
|
jdt-language-server
|
||||||
javaPackages.compiler.openjdk17
|
javaPackages.compiler.openjdk17
|
||||||
javaPackages.compiler.openjdk21
|
javaPackages.compiler.openjdk21
|
||||||
|
|
@ -88,8 +98,8 @@ in {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
startupPlugins = {
|
startupPlugins = with pkgs.vimPlugins; {
|
||||||
general = with pkgs.vimPlugins; [
|
general = [
|
||||||
lze
|
lze
|
||||||
plenary-nvim
|
plenary-nvim
|
||||||
nvim-notify
|
nvim-notify
|
||||||
|
|
@ -97,33 +107,34 @@ in {
|
||||||
base16-nvim
|
base16-nvim
|
||||||
mini-nvim
|
mini-nvim
|
||||||
];
|
];
|
||||||
treesitter = with pkgs.vimPlugins; [
|
treesitter = [
|
||||||
nvim-treesitter-textobjects
|
nvim-treesitter-textobjects
|
||||||
nvim-treesitter.withAllGrammars
|
nvim-treesitter.withAllGrammars
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
optionalPlugins = {
|
|
||||||
general = with pkgs.vimPlugins; [
|
optionalPlugins = with pkgs.vimPlugins; {
|
||||||
|
general = [
|
||||||
];
|
];
|
||||||
ui = with pkgs.vimPlugins; [
|
ui = [
|
||||||
dressing-nvim
|
dressing-nvim
|
||||||
];
|
];
|
||||||
qol = with pkgs.vimPlugins; [
|
qol = [
|
||||||
undotree
|
undotree
|
||||||
mini-hipatterns
|
mini-hipatterns
|
||||||
];
|
];
|
||||||
telescope = with pkgs.vimPlugins; [
|
telescope = [
|
||||||
telescope-nvim
|
telescope-nvim
|
||||||
telescope-fzf-native-nvim
|
telescope-fzf-native-nvim
|
||||||
telescope-ui-select-nvim
|
telescope-ui-select-nvim
|
||||||
];
|
];
|
||||||
fyler = with pkgs.vimPlugins; [
|
fyler = [
|
||||||
fyler-nvim
|
fyler-nvim
|
||||||
];
|
];
|
||||||
lsp = with pkgs.vimPlugins; [
|
lsp = [
|
||||||
nvim-lspconfig
|
nvim-lspconfig
|
||||||
];
|
];
|
||||||
completion = with pkgs.vimPlugins; [
|
completion = [
|
||||||
blink-cmp
|
blink-cmp
|
||||||
nvim-cmp
|
nvim-cmp
|
||||||
luasnip
|
luasnip
|
||||||
|
|
@ -138,7 +149,13 @@ in {
|
||||||
cmp-cmdline-history
|
cmp-cmdline-history
|
||||||
lspkind-nvim
|
lspkind-nvim
|
||||||
];
|
];
|
||||||
lang = with pkgs.vimPlugins; {
|
format = [
|
||||||
|
conform-nvim
|
||||||
|
];
|
||||||
|
comment = [
|
||||||
|
comment-nvim
|
||||||
|
];
|
||||||
|
lang = {
|
||||||
java = [
|
java = [
|
||||||
nvim-jdtls
|
nvim-jdtls
|
||||||
];
|
];
|
||||||
|
|
@ -152,23 +169,25 @@ in {
|
||||||
# libgit2
|
# libgit2
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
environmentVariables = {
|
environmentVariables = {
|
||||||
lang = {
|
lang = {
|
||||||
rust = {
|
rust.lsp = {
|
||||||
# it literally won't see the rust-analyzer provided to it
|
# it literally won't see the rust-analyzer provided to it
|
||||||
# if you don't use an envrionment variable to tell it
|
# if you don't use an envrionment variable to tell it
|
||||||
RUST_ANALYZER_CMD = "${pkgs.rust-analyzer}/bin/rust-analyzer";
|
RUST_ANALYZER_CMD = "${mpkgs.rust-analyzer}/bin/rust-analyzer";
|
||||||
};
|
};
|
||||||
elixir = {
|
elixir.lsp = {
|
||||||
ELIXIR_LS_CMD = "${pkgs.elixir-ls}/scripts/language_server.sh";
|
ELIXIR_LS_CMD = "${pkgs.elixir-ls}/scripts/language_server.sh";
|
||||||
};
|
};
|
||||||
java = {
|
java.lsp = {
|
||||||
JAVA_HOME = "${pkgs.javaPackages.compiler.openjdk17}";
|
JAVA_HOME = "${pkgs.javaPackages.compiler.openjdk17}";
|
||||||
OPENJDK_17 = "${pkgs.javaPackages.compiler.openjdk17}";
|
OPENJDK_17 = "${pkgs.javaPackages.compiler.openjdk17}";
|
||||||
OPENJDK_21 = "${pkgs.javaPackages.compiler.openjdk21}";
|
OPENJDK_21 = "${pkgs.javaPackages.compiler.openjdk21}";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
extraWrapperArgs = {
|
extraWrapperArgs = {
|
||||||
test = [
|
test = [
|
||||||
''--set CATTESTVAR2 "It worked again!"''
|
''--set CATTESTVAR2 "It worked again!"''
|
||||||
|
|
@ -182,11 +201,11 @@ in {
|
||||||
# vim.g.python3_host_prog
|
# vim.g.python3_host_prog
|
||||||
# or run from nvim terminal via :!<packagename>-python3
|
# or run from nvim terminal via :!<packagename>-python3
|
||||||
extraPython3Packages = {
|
extraPython3Packages = {
|
||||||
test = _: [];
|
test = _: [ ];
|
||||||
};
|
};
|
||||||
# populates $LUA_PATH and $LUA_CPATH
|
# populates $LUA_PATH and $LUA_CPATH
|
||||||
extraLuaPackages = {
|
extraLuaPackages = {
|
||||||
test = [(_: [])];
|
test = [ (_: [ ]) ];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -194,14 +213,23 @@ in {
|
||||||
packageDefinitions.replace = {
|
packageDefinitions.replace = {
|
||||||
# these are the names of your packages
|
# these are the names of your packages
|
||||||
# you can include as many as you wish.
|
# you can include as many as you wish.
|
||||||
auroranvim = {pkgs, ...}: {
|
auroranvim =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
# they contain a settings set defined above
|
# they contain a settings set defined above
|
||||||
# see :help nixCats.flake.outputs.settings
|
# see :help nixCats.flake.outputs.settings
|
||||||
settings = {
|
settings = {
|
||||||
wrapRc = true;
|
wrapRc = true;
|
||||||
# IMPORTANT:
|
# IMPORTANT:
|
||||||
# your alias may not conflict with your other packages.
|
# your alias may not conflict with your other packages.
|
||||||
aliases = ["auroravim" "auravim" "foxyvim" "avix" "fvix" "auim"];
|
aliases = [
|
||||||
|
"auroravim"
|
||||||
|
"auravim"
|
||||||
|
"foxyvim"
|
||||||
|
"avix"
|
||||||
|
"fvix"
|
||||||
|
"auim"
|
||||||
|
];
|
||||||
};
|
};
|
||||||
# and a set of categories that you want
|
# and a set of categories that you want
|
||||||
# (and other information to pass to lua)
|
# (and other information to pass to lua)
|
||||||
|
|
@ -215,15 +243,29 @@ in {
|
||||||
lsp = true;
|
lsp = true;
|
||||||
completion = true;
|
completion = true;
|
||||||
treesitter = true;
|
treesitter = true;
|
||||||
|
format = true;
|
||||||
|
comment = true;
|
||||||
|
|
||||||
lang = {
|
lang = {
|
||||||
lua = true;
|
lua = {
|
||||||
nix = true;
|
lsp = true;
|
||||||
rust = true;
|
format = true;
|
||||||
|
};
|
||||||
|
nix = {
|
||||||
|
lsp = true;
|
||||||
|
format = true;
|
||||||
|
};
|
||||||
|
rust = {
|
||||||
|
lsp = true;
|
||||||
|
format = true;
|
||||||
|
};
|
||||||
zig = true;
|
zig = true;
|
||||||
elixir = true;
|
elixir = true;
|
||||||
gleam = true;
|
gleam = true;
|
||||||
haskell = true;
|
haskell = {
|
||||||
|
lsp = true;
|
||||||
|
format = true;
|
||||||
|
};
|
||||||
java = true;
|
java = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
||||||
|
|
@ -23,6 +23,7 @@
|
||||||
|
|
||||||
networking = {
|
networking = {
|
||||||
useNetworkd = false;
|
useNetworkd = false;
|
||||||
|
networkmanager.enable = false;
|
||||||
useDHCP = false;
|
useDHCP = false;
|
||||||
|
|
||||||
nftables.enable = true;
|
nftables.enable = true;
|
||||||
|
|
@ -92,6 +93,7 @@
|
||||||
Gateway = "10.16.1.1";
|
Gateway = "10.16.1.1";
|
||||||
DNS = ["10.16.1.1"];
|
DNS = ["10.16.1.1"];
|
||||||
LinkLocalAddressing = "no";
|
LinkLocalAddressing = "no";
|
||||||
|
DHCP = "no";
|
||||||
};
|
};
|
||||||
linkConfig.RequiredForOnline = "routable";
|
linkConfig.RequiredForOnline = "routable";
|
||||||
};
|
};
|
||||||
|
|
|
||||||
40
snow.nix
40
snow.nix
|
|
@ -1,22 +1,20 @@
|
||||||
{cerulean, ...} @ inputs:
|
{
|
||||||
cerulean.mkNexus ./. (self: {
|
inputs,
|
||||||
nexus = {
|
cerulean,
|
||||||
args = {inherit inputs;};
|
...
|
||||||
|
} @ args: {
|
||||||
modules = with inputs; [];
|
nodes = {
|
||||||
|
|
||||||
base = inputs.nixpkgs;
|
base = inputs.nixpkgs;
|
||||||
|
homeManager = inputs.home-manager;
|
||||||
|
|
||||||
|
args = {inherit inputs;};
|
||||||
|
modules = with inputs; [];
|
||||||
|
|
||||||
groups = {
|
groups = {
|
||||||
servers = {};
|
servers = {};
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes = let
|
nodes = {
|
||||||
inherit
|
|
||||||
(self.nexus)
|
|
||||||
groups
|
|
||||||
;
|
|
||||||
in {
|
|
||||||
nixarawrui = {
|
nixarawrui = {
|
||||||
system = "x86_64-linux";
|
system = "x86_64-linux";
|
||||||
|
|
||||||
|
|
@ -30,7 +28,7 @@ cerulean.mkNexus ./. (self: {
|
||||||
arcturus = {
|
arcturus = {
|
||||||
system = "x86_64-linux";
|
system = "x86_64-linux";
|
||||||
|
|
||||||
groups = [
|
groups = groups: [
|
||||||
groups.servers
|
groups.servers
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
@ -75,11 +73,11 @@ cerulean.mkNexus ./. (self: {
|
||||||
];
|
];
|
||||||
|
|
||||||
volumes = [
|
volumes = [
|
||||||
{
|
#{
|
||||||
image = "/var/lib/microvms/home-assistant/data.img";
|
#image = "/var/lib/microvms/home-assistant/data.img";
|
||||||
mountPoint = "/var/lib/hass";
|
#mountPoint = "/var/lib/hass";
|
||||||
size = 16384; # 16GB
|
#autoCreate = false;
|
||||||
}
|
#}
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -110,7 +108,7 @@ cerulean.mkNexus ./. (self: {
|
||||||
lyra = {
|
lyra = {
|
||||||
system = "x86_64-linux";
|
system = "x86_64-linux";
|
||||||
|
|
||||||
groups = [
|
groups = groups: [
|
||||||
groups.servers
|
groups.servers
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
@ -122,4 +120,4 @@ cerulean.mkNexus ./. (self: {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
})
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,7 +2,7 @@
|
||||||
{
|
{
|
||||||
services.home-assistant = {
|
services.home-assistant = {
|
||||||
enable = true;
|
enable = true;
|
||||||
configDir = "/var/lib/hass";
|
configDir = "/var/lib/hass/hass";
|
||||||
|
|
||||||
# disables config generation, i don't wanna configure home assistant
|
# disables config generation, i don't wanna configure home assistant
|
||||||
# through nix at the moment
|
# through nix at the moment
|
||||||
|
|
@ -16,15 +16,32 @@
|
||||||
|
|
||||||
extraPackages = python3Packages: with python3Packages; [
|
extraPackages = python3Packages: with python3Packages; [
|
||||||
getmac
|
getmac
|
||||||
|
aiohue
|
||||||
|
numpy
|
||||||
|
aiodhcpwatcher
|
||||||
|
async-upnp-client
|
||||||
|
gtts
|
||||||
|
numpy
|
||||||
|
plexapi
|
||||||
|
pyipp
|
||||||
|
paho-mqtt
|
||||||
|
pyturbojpeg
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
systemd.tmpfiles.rules = [
|
|
||||||
# configures the config directory to be mounted
|
# configures the config directory to be mounted
|
||||||
# correclty with the right permissions
|
# correctly with the right permissions
|
||||||
"z /var/lib/hass 0755 hass hass -"
|
systemd.services.hass-permissions = {
|
||||||
"z /var/lib/hass/lost+found 0755 hass hass -"
|
wantedBy = [ "multi-user.target" ];
|
||||||
];
|
after = [ "var-lib-hass.mount" ];
|
||||||
|
requires = [ "var-lib-hass.mount" ];
|
||||||
|
before = [ "home-assistant.service" ];
|
||||||
|
serviceConfig = {
|
||||||
|
Type = "oneshot";
|
||||||
|
ExecStart = "${pkgs.bash}/bin/bash -c 'mkdir -p /var/lib/hass/hass && chown hass:hass /var/lib/hass/hass'";
|
||||||
|
RemainAfterExit = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
networking = {
|
networking = {
|
||||||
nftables.enable = true;
|
nftables.enable = true;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue