aboutsummaryrefslogtreecommitdiff
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