{ config, pkgs, rnix-lsp, ... }: { # Home Manager needs a bit of information about you and the paths it should # manage. home.username = "coder"; home.homeDirectory = "/home/coder"; # 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 = "22.11"; # Please read the comment before changing. # The home.packages option allows you to install Nix packages into your # environment. home.packages = with pkgs; [ direnv procps bat icdiff thefuck kubectl kubernetes-helm krew yarn python39 rustup nodejs_20 virtualenv proxychains-ng less openssh wget curl rnix-lsp.rnix-lsp ]; # Home Manager is pretty good at managing dotfiles. The primary way to manage # plain files is through 'home.file'. home.file = {}; # You can also manage environment variables but you will have to manually # source # # ~/.nix-profile/etc/profile.d/hm-session-vars.sh # # or # # /etc/profiles/per-user/coder/etc/profile.d/hm-session-vars.sh # # if you don't want to manage your shell through Home Manager. home.sessionVariables = { # EDITOR = "emacs"; TZ = "Asia/Shanghai"; LANG = "zh_CN.UTF-8"; GOPROXY = "https://goproxy.cn,direct"; }; home.sessionPath = [ ".local/bin" ".cargo/bin" ]; home.shellAliases = { cao = "fuck"; ls = "ls --color=auto"; cat = "bat -p --paging=never -u"; diff = "icdiff"; }; # Let Home Manager install and manage itself. programs.home-manager.enable = true; }