diff options
| author | seth <[email protected]> | 2024-05-05 11:35:18 -0400 |
|---|---|---|
| committer | GitHub <[email protected]> | 2024-05-05 11:35:18 -0400 |
| commit | 34a7a042a36b63eb6b900932b1e420e4b6014a57 (patch) | |
| tree | 40dace9b4bb7b6e99c5d54165d8eb203963f5306 /users/seth/shell | |
| parent | 9380483bdf038149fc308698e9f115b1474a0c85 (diff) | |
simplify some things (#353)
* flake: drop flake-parts
* flake: add back flake-parts
* flake: use flake module again for configurations
Diffstat (limited to 'users/seth/shell')
| -rw-r--r-- | users/seth/shell/bash.nix | 34 | ||||
| -rw-r--r-- | users/seth/shell/default.nix | 40 | ||||
| -rw-r--r-- | users/seth/shell/fish.nix | 53 | ||||
| -rw-r--r-- | users/seth/shell/nu.nix | 43 | ||||
| -rw-r--r-- | users/seth/shell/zsh.nix | 128 |
5 files changed, 298 insertions, 0 deletions
diff --git a/users/seth/shell/bash.nix b/users/seth/shell/bash.nix new file mode 100644 index 0000000..958794d --- /dev/null +++ b/users/seth/shell/bash.nix @@ -0,0 +1,34 @@ +{ + config, + lib, + ... +}: let + cfg = config.seth.shell.bash; +in { + options.seth.shell.bash = { + enable = lib.mkEnableOption "Bash configuration" // {default = config.seth.enable;}; + }; + + config = lib.mkIf cfg.enable { + programs.bash = { + enable = true; + # TODO: find out if i need this anymore with standalone HM + bashrcExtra = '' + nixfile=${config.home.homeDirectory}/.nix-profile/etc/profile.d/nix.sh + [ -e "$nixfile" ] && source "$nixfile" + ''; + historyFile = "${config.xdg.stateHome}/bash/history"; + historyFileSize = 1000; + historySize = 100; + shellOptions = [ + "cdspell" + "checkjobs" + "checkwinsize" + "dirspell" + "globstar" + "histappend" + "no_empty_cmd_completion" + ]; + }; + }; +} diff --git a/users/seth/shell/default.nix b/users/seth/shell/default.nix new file mode 100644 index 0000000..b86697c --- /dev/null +++ b/users/seth/shell/default.nix @@ -0,0 +1,40 @@ +{ + config, + lib, + ... +}: let + cfg = config.seth.shell; +in { + options.seth.shell = { + aliases.enable = lib.mkEnableOption "Shell aliases" // {default = config.seth.enable;}; + variables.enable = lib.mkEnableOption "Shell variables" // {default = config.seth.enable;}; + }; + + imports = [ + ./bash.nix + ./fish.nix + ./nu.nix + ./zsh.nix + ]; + + config = { + home = lib.mkMerge [ + (lib.mkIf cfg.variables.enable { + sessionVariables = rec { + EDITOR = "nvim"; + VISUAL = EDITOR; + CARGO_HOME = "${config.xdg.dataHome}/cargo"; + LESSHISTFILE = "${config.xdg.stateHome}/less/history"; + }; + }) + + (lib.mkIf cfg.aliases.enable { + shellAliases = { + diff = "diff --color=auto"; + g = "git"; + gs = "g status"; + }; + }) + ]; + }; +} diff --git a/users/seth/shell/fish.nix b/users/seth/shell/fish.nix new file mode 100644 index 0000000..0b37273 --- /dev/null +++ b/users/seth/shell/fish.nix @@ -0,0 +1,53 @@ +{ + config, + lib, + pkgs, + ... +}: let + cfg = config.seth.shell.fish; +in { + options.seth.shell.fish = { + enable = lib.mkEnableOption "Fish configuration" // {default = config.seth.enable;}; + withPlugins = lib.mkEnableOption "Fish plugins" // {default = true;}; + }; + + config = lib.mkIf cfg.enable { + programs.fish = lib.mkMerge [ + { + enable = true; + catppuccin.enable = true; + + interactiveShellInit = '' + set -l nixfile ${config.home.homeDirectory}/.nix-profile/etc/profile.d/nix.fish + if test -e $nixfile + source $nixfile + end + + ${lib.getExe pkgs.nix-your-shell} fish | source + + abbr -a !! --position anywhere --function last_history_item + ''; + + functions = { + last_history_item.body = "echo $history[1]"; + }; + + shellAbbrs = { + nixgc = "sudo nix-collect-garbage -d && nix-collect-garbage -d"; + }; + } + + (lib.mkIf cfg.withPlugins { + plugins = let + mkFishPlugins = builtins.map (plugin: { + name = plugin; + inherit (pkgs.fishPlugins.${plugin}) src; + }); + in + mkFishPlugins [ + "autopair" + ]; + }) + ]; + }; +} diff --git a/users/seth/shell/nu.nix b/users/seth/shell/nu.nix new file mode 100644 index 0000000..b5b1529 --- /dev/null +++ b/users/seth/shell/nu.nix @@ -0,0 +1,43 @@ +{ + config, + lib, + inputs, + ... +}: let + cfg = config.seth.shell.nushell; + theme = "catppuccin-${config.catppuccin.flavour}"; +in { + options.seth.shell.nushell = { + enable = lib.mkEnableOption "Nushell configuration"; + }; + + config = lib.mkIf cfg.enable { + programs = { + nushell = { + enable = true; + + configFile.text = '' + def "nixgc" [] { + sudo nix-collect-garbage -d; nix-collect-garbage -d + } + ''; + + envFile.text = '' + use ${inputs.nu-scripts}/themes/nu-themes/${theme}.nu + $env.config.color_config = (${theme}) + ''; + + inherit (config.home) shellAliases; + }; + + bash.initExtra = lib.mkAfter '' + if [[ $(ps --no-header --pid=$PPID --format=comm) != "nu" && -z ''${BASH_EXECUTION_STRING} ]]; then + exec ${lib.getExe config.programs.nushell.package} + fi + ''; + + # builtin `ls` is good here! + eza.enable = lib.mkForce false; + }; + }; +} diff --git a/users/seth/shell/zsh.nix b/users/seth/shell/zsh.nix new file mode 100644 index 0000000..b3f31b9 --- /dev/null +++ b/users/seth/shell/zsh.nix @@ -0,0 +1,128 @@ +{ + config, + lib, + pkgs, + ... +}: let + cfg = config.seth.shell.zsh; +in { + options.seth.shell.zsh = { + enable = lib.mkEnableOption "Zsh configuration"; + withPlugins = lib.mkEnableOption "Zsh plugins" // {default = true;}; + }; + + config = lib.mkIf cfg.enable { + programs.zsh = lib.mkMerge [ + { + enable = true; + enableAutosuggestions = true; + + completionInit = '' + autoload -Uz bashcompinit compinit + local zdump="${config.xdg.cacheHome}/zsh/zdump" + bashcompinit + compinit -d "$zdump" + if [[ ! "$zdump.zwc" -nt "$zdump" ]] + then + zcompile "$zdump" + fi + unset zdump + ''; + + defaultKeymap = "emacs"; + dotDir = ".config/zsh"; + + initExtra = '' + if [[ -r "$XDG_CACHE_HOME/p10k-instant-prompt-*.zsh" ]]; then + source "$XDG_CACHE_HOME/p10k-instant-prompt-*.zsh" + fi + autoload -Uz promptinit colors + promptinit + colors + + ${lib.getExe pkgs.nix-your-shell} zsh | source /dev/stdin + + zmodload zsh/zutil + zmodload zsh/complist + zstyle ":completion::*" group-name "" + zstyle ":completion:*" menu "select" + zstyle ":completion:*" squeeze-slashes "true" + zstyle ":completion::*" use-cache "true" + zstyle ":completion::*" cache-path "$zdump" + + unsetopt beep + unsetopt hist_beep + unsetopt ignore_braces + unsetopt list_beep + setopt always_to_end + setopt prompt_subst + setopt share_history + + # clear backbuffer with ctrl-l + function clear-screen-and-scrollback() { + echoti civis >"$TTY" + printf '%b' '\e[H\e[2J' >"$TTY" + zle .reset-prompt + zle -R + printf '%b' '\e[3J' >"$TTY" + echoti cnorm >"$TTY" + } + + zle -N clear-screen-and-scrollback + bindkey '^L' clear-screen-and-scrollback + + [[ ! -f ~/.config/zsh/.p10k.zsh ]] || source ~/.config/zsh/.p10k.zsh + ''; + + history = { + expireDuplicatesFirst = true; + path = "${config.xdg.stateHome}/zsh/zsh_history"; + save = 1000; + size = 100; + }; + } + + (lib.mkIf cfg.withPlugins { + plugins = [ + { + name = "cattppuccin-zsh-syntax-highlighting"; + src = pkgs.fetchFromGitHub { + owner = "catppuccin"; + repo = "zsh-syntax-highlighting"; + rev = "06d519c20798f0ebe275fc3a8101841faaeee8ea"; + sha256 = "sha256-Q7KmwUd9fblprL55W0Sf4g7lRcemnhjh4/v+TacJSfo="; + }; + + file = "themes/catppuccin_mocha-zsh-syntax-highlighting.zsh"; + } + + { + name = "nix-zsh-completions"; + src = pkgs.nix-zsh-completions; + file = "share/zsh/plugins/nix/nix-zsh-completions.plugin.zsh"; + } + + { + name = "powerlevel10k"; + src = pkgs.zsh-powerlevel10k; + file = "share/zsh-powerlevel10k/powerlevel10k.zsh-theme"; + } + + { + name = "zsh-autopair"; + src = pkgs.zsh-autopair; + file = "share/zsh/zsh-autopair/autopair.zsh"; + } + + { + name = "zsh-completions"; + src = pkgs.zsh-completions; + file = "share/zsh-completions/zsh-completions.plugin.zsh"; + } + ]; + + enableSyntaxHighlighting = true; + }) + ]; + }; +} |
