Compare commits
No commits in common. "b5eb89382f38ae57ea27471df0c817f8b208220a" and "e52f68c62a01a049b50a12e88b4a43d710e3f1ec" have entirely different histories.
b5eb89382f
...
e52f68c62a
4 changed files with 89 additions and 2574 deletions
2235
flake.lock
generated
2235
flake.lock
generated
File diff suppressed because it is too large
Load diff
149
flake.nix
149
flake.nix
|
@ -57,27 +57,21 @@
|
||||||
url = "github:nix-community/disko";
|
url = "github:nix-community/disko";
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
|
|
||||||
nvf = {
|
|
||||||
url = "github:notashelf/nvf/v0.7";
|
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
outputs = inputs @ {
|
outputs = inputs@{
|
||||||
nixpkgs,
|
nixpkgs,
|
||||||
flake-utils,
|
flake-utils,
|
||||||
home-manager,
|
home-manager,
|
||||||
agenix,
|
agenix,
|
||||||
lanzaboote,
|
lanzaboote,
|
||||||
disko,
|
disko,
|
||||||
nvf,
|
|
||||||
...
|
...
|
||||||
}: let
|
}:
|
||||||
|
let
|
||||||
home-modules = with inputs; [
|
home-modules = with inputs; [
|
||||||
nix-flatpak.homeManagerModules.nix-flatpak
|
nix-flatpak.homeManagerModules.nix-flatpak
|
||||||
nix-doom-emacs.hmModule
|
nix-doom-emacs.hmModule
|
||||||
nvf.homeManagerModules.default
|
|
||||||
];
|
];
|
||||||
|
|
||||||
overlays = with inputs; [
|
overlays = with inputs; [
|
||||||
|
@ -85,90 +79,69 @@
|
||||||
nixgl.overlay
|
nixgl.overlay
|
||||||
];
|
];
|
||||||
|
|
||||||
customNixosSystem = {
|
customNixosSystem = { name, system, extraModules ? [] }: nixpkgs.lib.nixosSystem {
|
||||||
name,
|
inherit system;
|
||||||
system,
|
modules = [
|
||||||
extraModules ? [],
|
./hosts/${name}/configuration.nix
|
||||||
}:
|
home-manager.nixosModules.home-manager
|
||||||
nixpkgs.lib.nixosSystem {
|
agenix.nixosModules.default
|
||||||
inherit system;
|
lanzaboote.nixosModules.lanzaboote
|
||||||
modules =
|
disko.nixosModules.disko
|
||||||
[
|
{ nixpkgs.overlays = overlays; }
|
||||||
./hosts/${name}/configuration.nix
|
{
|
||||||
home-manager.nixosModules.home-manager
|
home-manager.useGlobalPkgs = true;
|
||||||
agenix.nixosModules.default
|
home-manager.useUserPackages = true;
|
||||||
lanzaboote.nixosModules.lanzaboote
|
home-manager.extraSpecialArgs = inputs;
|
||||||
disko.nixosModules.disko
|
home-manager.users.florian.imports = home-modules ++ [
|
||||||
{nixpkgs.overlays = overlays;}
|
./hosts/${name}/home.nix
|
||||||
{
|
];
|
||||||
home-manager.useGlobalPkgs = true;
|
}
|
||||||
home-manager.useUserPackages = true;
|
] ++ extraModules;
|
||||||
home-manager.extraSpecialArgs = inputs;
|
};
|
||||||
home-manager.users.florian.imports =
|
in {
|
||||||
home-modules
|
#####################################################################
|
||||||
++ [
|
#####################################################################
|
||||||
./hosts/${name}/home.nix
|
# Configure all nixos configurations
|
||||||
];
|
#####################################################################
|
||||||
}
|
#####################################################################
|
||||||
]
|
nixosConfigurations = {
|
||||||
++ extraModules;
|
nixos-test = customNixosSystem { name = "nixos-test"; system = "x86_64-linux"; };
|
||||||
|
perso-laptop = customNixosSystem { name = "perso-laptop"; system = "x86_64-linux"; };
|
||||||
|
perso-desktop = customNixosSystem { name = "perso-desktop"; system = "x86_64-linux"; };
|
||||||
|
};
|
||||||
|
|
||||||
|
#####################################################################
|
||||||
|
#####################################################################
|
||||||
|
# Configure home configuration for all others systems like Arch Linux
|
||||||
|
#####################################################################
|
||||||
|
#####################################################################
|
||||||
|
homeConfigurations = {
|
||||||
|
perso-home = home-manager.lib.homeManagerConfiguration rec {
|
||||||
|
pkgs = import nixpkgs { system = "x86_64-linux"; inherit overlays; };
|
||||||
|
|
||||||
|
modules = home-modules ++ [
|
||||||
|
{ nix.package = pkgs.nix; }
|
||||||
|
./hosts/perso-home/home.nix
|
||||||
|
];
|
||||||
};
|
};
|
||||||
in
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#####################################################################
|
||||||
|
#####################################################################
|
||||||
|
# Configure development shell for all systems and merge with all
|
||||||
|
# previous configurations with //
|
||||||
|
#####################################################################
|
||||||
|
#####################################################################
|
||||||
|
// flake-utils.lib.eachSystem flake-utils.lib.allSystems (system:
|
||||||
|
let
|
||||||
|
pkgs = import nixpkgs { inherit system; };
|
||||||
|
in
|
||||||
{
|
{
|
||||||
#####################################################################
|
|
||||||
#####################################################################
|
|
||||||
# Configure all nixos configurations
|
|
||||||
#####################################################################
|
|
||||||
#####################################################################
|
|
||||||
nixosConfigurations = {
|
|
||||||
nixos-test = customNixosSystem {
|
|
||||||
name = "nixos-test";
|
|
||||||
system = "x86_64-linux";
|
|
||||||
};
|
|
||||||
perso-laptop = customNixosSystem {
|
|
||||||
name = "perso-laptop";
|
|
||||||
system = "x86_64-linux";
|
|
||||||
};
|
|
||||||
perso-desktop = customNixosSystem {
|
|
||||||
name = "perso-desktop";
|
|
||||||
system = "x86_64-linux";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
#####################################################################
|
|
||||||
#####################################################################
|
|
||||||
# Configure home configuration for all others systems like Arch Linux
|
|
||||||
#####################################################################
|
|
||||||
#####################################################################
|
|
||||||
homeConfigurations = {
|
|
||||||
perso-home = home-manager.lib.homeManagerConfiguration rec {
|
|
||||||
pkgs = import nixpkgs {
|
|
||||||
system = "x86_64-linux";
|
|
||||||
inherit overlays;
|
|
||||||
};
|
|
||||||
|
|
||||||
modules =
|
|
||||||
home-modules
|
|
||||||
++ [
|
|
||||||
{nix.package = pkgs.nix;}
|
|
||||||
./hosts/perso-home/home.nix
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
#####################################################################
|
|
||||||
#####################################################################
|
|
||||||
# Configure development shell for all systems and merge with all
|
|
||||||
# previous configurations with //
|
|
||||||
#####################################################################
|
|
||||||
#####################################################################
|
|
||||||
// flake-utils.lib.eachSystem flake-utils.lib.allSystems (system: let
|
|
||||||
pkgs = import nixpkgs {inherit system;};
|
|
||||||
in {
|
|
||||||
devShells = {
|
devShells = {
|
||||||
default = pkgs.mkShell {
|
default = pkgs.mkShell {
|
||||||
packages = with pkgs; [
|
packages = with pkgs; [
|
||||||
nil
|
nixd
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
@ -15,10 +15,6 @@
|
||||||
minecraft.enable = true;
|
minecraft.enable = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
editors = {
|
|
||||||
neovim.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
shell = {
|
shell = {
|
||||||
zsh.enable = true;
|
zsh.enable = true;
|
||||||
atuin.enable = true;
|
atuin.enable = true;
|
||||||
|
|
|
@ -1,262 +1,41 @@
|
||||||
{
|
{ config, pkgs, lib, ... }:
|
||||||
config,
|
|
||||||
lib,
|
with lib;
|
||||||
...
|
let
|
||||||
}:
|
|
||||||
with lib; let
|
|
||||||
cfg = config.modules.home.editors.neovim;
|
cfg = config.modules.home.editors.neovim;
|
||||||
in {
|
in
|
||||||
|
{
|
||||||
options.modules.home.editors.neovim = {
|
options.modules.home.editors.neovim = {
|
||||||
enable = mkEnableOption ''
|
enable = mkEnableOption ''
|
||||||
Enable neovim with my custom configurations
|
Enable neovim with my custom configurations
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
programs.nvf = {
|
programs.neovim = {
|
||||||
enable = true;
|
enable = true;
|
||||||
enableManpages = true;
|
defaultEditor = true;
|
||||||
|
|
||||||
# https://notashelf.github.io/nvf/options.html
|
|
||||||
settings.vim = {
|
|
||||||
viAlias = true;
|
|
||||||
vimAlias = true;
|
|
||||||
debugMode = {
|
|
||||||
enable = false;
|
|
||||||
level = 16;
|
|
||||||
logFile = "/tmp/nvim.log";
|
|
||||||
};
|
|
||||||
|
|
||||||
spellcheck = {
|
|
||||||
enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
lsp = {
|
|
||||||
formatOnSave = true;
|
|
||||||
lspkind.enable = false;
|
|
||||||
lightbulb.enable = true;
|
|
||||||
lspsaga.enable = false;
|
|
||||||
trouble.enable = true;
|
|
||||||
lspSignature.enable = true;
|
|
||||||
otter-nvim.enable = true;
|
|
||||||
lsplines.enable = true;
|
|
||||||
nvim-docs-view.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
debugger = {
|
|
||||||
nvim-dap = {
|
|
||||||
enable = true;
|
|
||||||
ui.enable = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
languages = {
|
|
||||||
enableLSP = true;
|
|
||||||
enableDAP = true;
|
|
||||||
enableFormat = true;
|
|
||||||
enableTreesitter = true;
|
|
||||||
enableExtraDiagnostics = true;
|
|
||||||
|
|
||||||
bash.enable = true;
|
|
||||||
clang.enable = true; # C/C++
|
|
||||||
css.enable = true;
|
|
||||||
# Not work currently. Crash during configuration of flutter-tools
|
|
||||||
# dart = {
|
|
||||||
# enable = true;
|
|
||||||
# flutter-tools = {
|
|
||||||
# enable = true;
|
|
||||||
# enableNoResolvePatch = true;
|
|
||||||
# color = {
|
|
||||||
# enable = true;
|
|
||||||
# highlightBackground = true;
|
|
||||||
# highlightForeground = true;
|
|
||||||
# virtualText.enable = true;
|
|
||||||
# };
|
|
||||||
# };
|
|
||||||
# };
|
|
||||||
html.enable = true;
|
|
||||||
java.enable = true;
|
|
||||||
kotlin.enable = true;
|
|
||||||
markdown = {
|
|
||||||
enable = true;
|
|
||||||
# extensions.render-markdown-nvim.enable = true; # Supported at the last version in dev
|
|
||||||
};
|
|
||||||
nix.enable = true;
|
|
||||||
php.enable = true;
|
|
||||||
python.enable = true;
|
|
||||||
# ruby.enable = true; # Supported at the last version in dev
|
|
||||||
rust = {
|
|
||||||
enable = true;
|
|
||||||
crates.enable = true;
|
|
||||||
};
|
|
||||||
sql.enable = true;
|
|
||||||
tailwind.enable = true;
|
|
||||||
ts = {
|
|
||||||
enable = true;
|
|
||||||
extensions.ts-error-translator.enable = false;
|
|
||||||
};
|
|
||||||
# wgsl.enable = true; # Supported at the last version in dev
|
|
||||||
zig.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
visuals = {
|
|
||||||
nvim-scrollbar.enable = true;
|
|
||||||
nvim-web-devicons.enable = true;
|
|
||||||
nvim-cursorline.enable = true;
|
|
||||||
cinnamon-nvim.enable = true;
|
|
||||||
fidget-nvim.enable = true;
|
|
||||||
|
|
||||||
highlight-undo.enable = true;
|
|
||||||
indent-blankline.enable = true;
|
|
||||||
|
|
||||||
# Fun
|
|
||||||
cellular-automaton.enable = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
statusline = {
|
|
||||||
lualine = {
|
|
||||||
enable = true;
|
|
||||||
theme = "catppuccin";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
theme = {
|
|
||||||
enable = true;
|
|
||||||
name = "catppuccin";
|
|
||||||
style = "mocha";
|
|
||||||
transparent = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
autopairs.nvim-autopairs.enable = true;
|
|
||||||
|
|
||||||
autocomplete.nvim-cmp.enable = true;
|
|
||||||
snippets.luasnip.enable = true;
|
|
||||||
|
|
||||||
filetree = {
|
|
||||||
neo-tree = {
|
|
||||||
enable = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
tabline = {
|
|
||||||
nvimBufferline.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
treesitter.context.enable = true;
|
|
||||||
|
|
||||||
binds = {
|
|
||||||
whichKey.enable = true;
|
|
||||||
cheatsheet.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
telescope.enable = true;
|
|
||||||
|
|
||||||
git = {
|
|
||||||
enable = true;
|
|
||||||
gitsigns.enable = true;
|
|
||||||
gitsigns.codeActions.enable = false; # throws an annoying debug message
|
|
||||||
};
|
|
||||||
|
|
||||||
minimap = {
|
|
||||||
minimap-vim.enable = false;
|
|
||||||
codewindow.enable = true; # lighter, faster, and uses lua for configuration
|
|
||||||
};
|
|
||||||
|
|
||||||
dashboard = {
|
|
||||||
dashboard-nvim.enable = false;
|
|
||||||
alpha.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
notify = {
|
|
||||||
nvim-notify.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
projects = {
|
|
||||||
project-nvim.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
utility = {
|
|
||||||
ccc.enable = false;
|
|
||||||
vim-wakatime.enable = false;
|
|
||||||
icon-picker.enable = true;
|
|
||||||
surround.enable = true;
|
|
||||||
diffview-nvim.enable = true;
|
|
||||||
# yanky-nvim.enable = false; # Supported at the last version in dev
|
|
||||||
motion = {
|
|
||||||
hop.enable = true;
|
|
||||||
leap.enable = true;
|
|
||||||
precognition.enable = false; # VIM help
|
|
||||||
};
|
|
||||||
|
|
||||||
images = {
|
|
||||||
image-nvim.enable = false;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
notes = {
|
|
||||||
obsidian.enable = false; # FIXME: neovim fails to build if obsidian is enabled
|
|
||||||
neorg.enable = false;
|
|
||||||
orgmode.enable = false;
|
|
||||||
mind-nvim.enable = true;
|
|
||||||
todo-comments.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
terminal = {
|
|
||||||
toggleterm = {
|
|
||||||
enable = true;
|
|
||||||
lazygit.enable = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
ui = {
|
|
||||||
borders.enable = true;
|
|
||||||
noice.enable = true;
|
|
||||||
colorizer.enable = true;
|
|
||||||
modes-nvim.enable = false; # the theme looks terrible with catppuccin
|
|
||||||
illuminate.enable = true;
|
|
||||||
breadcrumbs = {
|
|
||||||
enable = true;
|
|
||||||
navbuddy.enable = true;
|
|
||||||
};
|
|
||||||
smartcolumn = {
|
|
||||||
enable = true;
|
|
||||||
setupOpts.custom_colorcolumn = {
|
|
||||||
# this is a freeform module, it's `buftype = int;` for configuring column position
|
|
||||||
nix = "110";
|
|
||||||
ruby = "120";
|
|
||||||
java = "130";
|
|
||||||
go = ["90" "130"];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
fastaction.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
# assistant = {
|
|
||||||
# chatgpt.enable = false;
|
|
||||||
# copilot = {
|
|
||||||
# enable = false;
|
|
||||||
# cmp.enable = true;
|
|
||||||
# };
|
|
||||||
# };
|
|
||||||
|
|
||||||
session = {
|
|
||||||
nvim-session-manager.enable = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
gestures = {
|
|
||||||
gesture-nvim.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
comments = {
|
|
||||||
comment-nvim.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
presence = {
|
|
||||||
neocord.enable = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
# Source : https://www.lazyvim.org/
|
# Source : https://www.lazyvim.org/
|
||||||
modules.home.apps.kitty.enable = lib.mkDefault true;
|
modules.home.apps.kitty.enable = lib.mkDefault true;
|
||||||
modules.home.shell.git.enable = lib.mkDefault true;
|
modules.home.shell.git.enable = lib.mkDefault true;
|
||||||
|
|
||||||
|
home.packages = with pkgs; [
|
||||||
|
lazygit
|
||||||
|
curl
|
||||||
|
gnutar
|
||||||
|
fzf
|
||||||
|
ripgrep
|
||||||
|
fd
|
||||||
|
gcc
|
||||||
|
|
||||||
|
unzip
|
||||||
|
cargo
|
||||||
|
python3
|
||||||
|
nodejs
|
||||||
|
nil
|
||||||
|
rust-analyzer
|
||||||
|
clang-tools
|
||||||
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue