diff options
author | Franck Cuny <franck@fcuny.net> | 2022-06-19 15:57:45 -0700 |
---|---|---|
committer | Franck Cuny <franck@fcuny.net> | 2022-06-20 14:39:35 -0700 |
commit | b5c428822468b9a2dfb00a673c39e809f4ac0651 (patch) | |
tree | 54e2190f9b20ce11827d0d5b10da2a96c135437a /home/shell/fish | |
parent | feat(tools/seqstat): add a tool to report stats about a sequence (diff) | |
download | world-b5c428822468b9a2dfb00a673c39e809f4ac0651.tar.gz |
ref(home/shell): make it easier to share common things between shells
I'm considering trying again fish, and there are a number of things that should be common between zsh and fish (aliases, environment variables, ...). Instead of duplicating these settings multiple time, I'm consolidating the shell configurations under `home/shell`, and I can set the shell I want to use with `my.home.shell.name`. The first step is to move the modules for fish and zsh under `home/shell`, add an interface to pick which one I want to use, and modify the `host/home.nix` configuration to keep using zsh with the new interface. Change-Id: Idb66b1a6fcc11a6eeaf5fd2d32dd3698d2d85bdf Reviewed-on: https://cl.fcuny.net/c/world/+/455 Tested-by: CI Reviewed-by: Franck Cuny <franck@fcuny.net>
Diffstat (limited to 'home/shell/fish')
-rw-r--r-- | home/shell/fish/default.nix | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/home/shell/fish/default.nix b/home/shell/fish/default.nix new file mode 100644 index 0000000..3a21b24 --- /dev/null +++ b/home/shell/fish/default.nix @@ -0,0 +1,29 @@ +{ config, lib, pkgs, ... }: +let + cfg = config.my.home.shell; + swayEnabled = config.my.home.wm.windowManager == "sway"; +in +{ + config = lib.mkIf (cfg.name == "fish") { + programs.fish = { + enable = true; + interactiveShellInit = '' + set fish_greeting + + # Tmux on terminal start, unless we're in a SSH connection + if status is-interactive + if test -z "$SSH_CONNECTION" + if not tmux has-session 2>/dev/null; or test -z "$TMUX" + exec tmux new-session -A -s 0 + end + end + end + ''; + loginShellInit = lib.mkIf swayEnabled '' + if test -z "$DISPLAY"; and test (tty) = "/dev/tty1" + exec sway + end + ''; + }; + }; +} |