{ config, pkgs, extraSpecialArgs, ... }: # let # # in { # 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 = { "${config.xdg.dataHome}/omf/themes/val-cat" = { enable = true; source = config.lib.file.mkOutOfStoreSymlink /. + "${config.xdg.configHome}/nixos/fish/themes/val-cat"; recursive = true; }; }; home.sessionVariables = { EDITOR = "nvim"; MANPAGER = "nvim +Man!"; }; programs.fish = { enable = true; interactiveShellInit = '' set -U fish_greeting if status is-interactive # Commands to run in interactive sessions can go here end function fish_user_key_bindings # Execute this once per mode that emacs bindings should be used in fish_default_key_bindings -M insert # Then execute the vi-bindings so they take precedence when there's a conflict. # Without --no-erase fish_vi_key_bindings will default to # resetting all bindings. # The argument specifies the initial mode (insert, "default" or visual). fish_vi_key_bindings --no-erase insert bind \cf 'fg 2>/dev/null; commandline -f repaint' end ''; }; programs.git = { enable = true; userName = "Zynh Ludwig"; userEmail = "zynh0722@gmail.com"; aliases = { co = "checkout"; ci = "commit"; st = "status"; br = "branch"; hist = "log --pretty=format:'%h %ad | %s%d [%an]' --graph --date=short"; type = "cat-file -t"; dump = "cat-file -p"; graph = "log --graph --decorate --pretty=oneline --abbrev-commit"; }; extraConfig = { init.defaultBranch = "main"; core = { editor = "nvim"; autocrlf = "input"; safecrlf = true; }; credential = { helper = [ "cache --timeout 7200" "oauth" ]; "https://git.zynh.me" = { oauthClientId = "13d5b95d-565d-4264-8961-c45cc38eaa8a"; oauthScopes = "read_repository write_repository"; oauthAuthURL = "/login/oauth/authorize"; oauthTokenURL = "/login/oauth/access_token"; }; }; }; }; # wayland.windowManager.hyprland = { # enable = true; # package = pkgs.hyprland; # xwayland.enable = true; # systemd.enable = true; # }; # Let Home Manager install and manage itself. programs.home-manager.enable = true; }