home: zsh: refactor tmux auto-launch configuration
Introduce an actual option for this behaviour.
This commit is contained in:
parent
0bbf522c03
commit
34c13b077f
|
@ -5,6 +5,10 @@ in
|
||||||
{
|
{
|
||||||
options.my.home.zsh = with lib; {
|
options.my.home.zsh = with lib; {
|
||||||
enable = my.mkDisableOption "zsh configuration";
|
enable = my.mkDisableOption "zsh configuration";
|
||||||
|
|
||||||
|
launchTmux = mkEnableOption "auto launch tmux at shell start" // {
|
||||||
|
default = config.my.home.tmux.enable;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
config = lib.mkIf cfg.enable {
|
config = lib.mkIf cfg.enable {
|
||||||
|
@ -44,14 +48,16 @@ in
|
||||||
defaultKeymap = "emacs";
|
defaultKeymap = "emacs";
|
||||||
|
|
||||||
# Make those happen early to avoid doing double the work
|
# Make those happen early to avoid doing double the work
|
||||||
initExtraFirst =
|
initExtraFirst = ''
|
||||||
lib.optionalString config.my.home.tmux.enable ''
|
${
|
||||||
# Launch tmux unless already inside one
|
lib.optionalString cfg.launchTmux ''
|
||||||
if [ -z "$TMUX" ]; then
|
# Launch tmux unless already inside one
|
||||||
exec tmux new-session
|
if [ -z "$TMUX" ]; then
|
||||||
fi
|
exec tmux new-session
|
||||||
''
|
fi
|
||||||
;
|
''
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
|
||||||
initExtra = ''
|
initExtra = ''
|
||||||
source ${./completion-styles.zsh}
|
source ${./completion-styles.zsh}
|
||||||
|
|
Loading…
Reference in a new issue