about summary refs log tree commit diff
path: root/home/shell
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--home/shell/default.nix16
-rw-r--r--home/shell/fish/default.nix29
-rw-r--r--home/shell/zsh/completion-style.zsh (renamed from home/zsh/completion-style.zsh)0
-rw-r--r--home/shell/zsh/default.nix (renamed from home/zsh/default.nix)8
-rw-r--r--home/shell/zsh/gerrit.zsh (renamed from home/zsh/gerrit.zsh)0
-rw-r--r--home/shell/zsh/options.zsh (renamed from home/zsh/options.zsh)0
-rw-r--r--home/shell/zsh/prompt.zsh (renamed from home/zsh/prompt.zsh)0
-rw-r--r--home/shell/zsh/sway.zsh (renamed from home/zsh/sway.zsh)0
-rw-r--r--home/shell/zsh/tmux.zsh (renamed from home/zsh/tmux.zsh)0
9 files changed, 47 insertions, 6 deletions
diff --git a/home/shell/default.nix b/home/shell/default.nix
new file mode 100644
index 0000000..35a6275
--- /dev/null
+++ b/home/shell/default.nix
@@ -0,0 +1,16 @@
+{ config, lib, pkgs, ... }:
+
+with lib;
+let cfg = config.my.home.shell;
+in
+{
+  options.my.home.shell = {
+    name = mkOption {
+      default = "zsh";
+      type = types.enum [ "fish" "zsh" ];
+      example = "zsh";
+    };
+  };
+
+  imports = [ ./fish ./zsh ];
+}
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
+      '';
+    };
+  };
+}
diff --git a/home/zsh/completion-style.zsh b/home/shell/zsh/completion-style.zsh
index 32bd6f4..32bd6f4 100644
--- a/home/zsh/completion-style.zsh
+++ b/home/shell/zsh/completion-style.zsh
diff --git a/home/zsh/default.nix b/home/shell/zsh/default.nix
index 21dbedd..14ddd6c 100644
--- a/home/zsh/default.nix
+++ b/home/shell/zsh/default.nix
@@ -1,12 +1,8 @@
 { config, pkgs, lib, ... }:
-let cfg = config.my.home.zsh;
+let cfg = config.my.home.shell;
 in
 {
-  options.my.home.zsh = with lib; {
-    enable = mkEnableOption "zsh configuration";
-  };
-
-  config = lib.mkIf cfg.enable {
+  config = lib.mkIf (cfg.name == "zsh") {
     home.packages = with pkgs; [ zsh-completions ];
 
     programs.zsh = {
diff --git a/home/zsh/gerrit.zsh b/home/shell/zsh/gerrit.zsh
index 9766b2f..9766b2f 100644
--- a/home/zsh/gerrit.zsh
+++ b/home/shell/zsh/gerrit.zsh
diff --git a/home/zsh/options.zsh b/home/shell/zsh/options.zsh
index 6d39bc1..6d39bc1 100644
--- a/home/zsh/options.zsh
+++ b/home/shell/zsh/options.zsh
diff --git a/home/zsh/prompt.zsh b/home/shell/zsh/prompt.zsh
index 1c21d4b..1c21d4b 100644
--- a/home/zsh/prompt.zsh
+++ b/home/shell/zsh/prompt.zsh
diff --git a/home/zsh/sway.zsh b/home/shell/zsh/sway.zsh
index 69d5103..69d5103 100644
--- a/home/zsh/sway.zsh
+++ b/home/shell/zsh/sway.zsh
diff --git a/home/zsh/tmux.zsh b/home/shell/zsh/tmux.zsh
index 97944f5..97944f5 100644
--- a/home/zsh/tmux.zsh
+++ b/home/shell/zsh/tmux.zsh