{ config, pkgs, inputs, ... }: { imports = [ ./home/modules/git.nix ./home/modules/fish.nix ]; # Home Manager needs a bit of information about you and the paths it should # manage. home.username = "ravenshade"; home.homeDirectory = "/home/ravenshade"; # This value determines the Home Manager release that your configuration is # compatible with. This helps avoid breakage when a new Home Manager release # introduces backwards incompatible changes. # # You should not change this value, even if you update Home Manager. If you do # want to update the value, then make sure to first check the Home Manager # release notes. home.stateVersion = "23.11"; # Please read the comment before changing. # The home.packages option allows you to install Nix packages into your # environment. home.packages = [ # # Adds the 'hello' command to your environment. It prints a friendly # # "Hello, world!" when run. # pkgs.hello # # It is sometimes useful to fine-tune packages, for example, by applying # # overrides. You can do that directly here, just don't forget the # # parentheses. Maybe you want to install Nerd Fonts with a limited number of # # fonts? # (pkgs.nerdfonts.override { fonts = [ "FantasqueSansMono" ]; }) # # You can also create simple shell scripts directly inside your # # configuration. For example, this adds a command 'my-hello' to your # # environment: # (pkgs.writeShellScriptBin "my-hello" '' # echo "Hello, ${config.home.username}!" # '') ]; # Home Manager is pretty good at managing dotfiles. The primary way to manage # plain files is through 'home.file'. home.file = { }; home.sessionVariables = { EDITOR = "nvim"; MANPAGER = "nvim +Man!"; }; # wayland.windowManager.hyprland = { # enable = true; # package = pkgs.hyprland; # xwayland.enable = true; # systemd.enable = true; # }; programs.neovim = let treesitterWithGrammars = (pkgs.vimPlugins.nvim-treesitter.withPlugins (p: [ p.bash p.comment p.css p.dockerfile p.fish p.gitattributes p.gitignore p.go p.gomod p.gowork p.javascript p.json5 p.json p.lua p.make p.markdown p.nix p.python p.rust p.toml p.typescript p.yaml ])); treesitter-parsers = pkgs.symlinkJoin { name = "treesitter-parsers"; paths = treesitterWithGrammars.dependencies; }; in { enable = true; withNodeJs = true; # extraConfig = ''vim.opt.runtimepath:append ("${treesitter-parsers}")''; extraLuaConfig = '' -- bootstrap lazy.nvim, LazyVim and your plugins require("config.lazy") vim.g.editorconfig = true vim.opt.runtimepath:append ("${treesitter-parsers}") ''; plugins = [ treesitterWithGrammars ]; }; # Let Home Manager install and manage itself. programs.home-manager.enable = true; }