zsh: fix double compinit slowdown with oh-my-zsh

Integrate the oh-my-zsh module into the zsh module in order to be able to control invocation order.
This commit is contained in:
Robin Stumm 2017-09-07 23:57:13 +02:00
parent f98f72a825
commit 76681a9591
No known key found for this signature in database
GPG key ID: 3DA3D7B8285FBE55
3 changed files with 70 additions and 77 deletions

View file

@ -29,7 +29,6 @@ let
./programs/htop.nix ./programs/htop.nix
./programs/info.nix ./programs/info.nix
./programs/lesspipe.nix ./programs/lesspipe.nix
./programs/oh-my-zsh.nix
./programs/ssh.nix ./programs/ssh.nix
./programs/termite.nix ./programs/termite.nix
./programs/texlive.nix ./programs/texlive.nix

View file

@ -1,66 +0,0 @@
{ config, lib, pkgs, ... }:
with lib;
let
cfg = config.programs.zsh.oh-my-zsh;
in
{
options = {
programs.zsh.oh-my-zsh = {
enable = mkEnableOption "oh-my-zsh";
plugins = mkOption {
default = [];
example = [ "git" "sudo" ];
type = types.listOf types.str;
description = ''
List of oh-my-zsh plugins
'';
};
custom = mkOption {
default = "";
type = types.str;
example = "$HOME/my_customizations";
description = ''
Path to a custom oh-my-zsh package to override config of oh-my-zsh.
See: https://github.com/robbyrussell/oh-my-zsh/wiki/Customization
'';
};
theme = mkOption {
default = "";
example = "robbyrussell";
type = types.str;
description = ''
Name of the theme to be used by oh-my-zsh.
'';
};
};
};
config = mkIf cfg.enable {
home.packages = [ pkgs.oh-my-zsh ];
programs.zsh.initExtra = with pkgs; ''
# oh-my-zsh configuration generated by NixOS
export ZSH=${oh-my-zsh}/share/oh-my-zsh
export ZSH_CACHE_DIR=''${XDG_CACHE_HOME:-$HOME/.cache}/oh-my-zsh
${optionalString (cfg.plugins != [])
"plugins=(${concatStringsSep " " cfg.plugins})"
}
${optionalString (cfg.custom != "")
"ZSH_CUSTOM=\"${cfg.custom}\""
}
${optionalString (cfg.theme != "")
"ZSH_THEME=\"${cfg.theme}\""
}
source $ZSH/oh-my-zsh.sh
'';
};
}

View file

@ -58,6 +58,40 @@ let
config.file = mkDefault "${config.name}.plugin.zsh"; config.file = mkDefault "${config.name}.plugin.zsh";
}); });
ohMyZshModule = types.submodule {
options = {
enable = mkEnableOption "oh-my-zsh";
plugins = mkOption {
default = [];
example = [ "git" "sudo" ];
type = types.listOf types.str;
description = ''
List of oh-my-zsh plugins
'';
};
custom = mkOption {
default = "";
type = types.str;
example = "$HOME/my_customizations";
description = ''
Path to a custom oh-my-zsh package to override config of oh-my-zsh.
See: https://github.com/robbyrussell/oh-my-zsh/wiki/Customization
'';
};
theme = mkOption {
default = "";
example = "robbyrussell";
type = types.str;
description = ''
Name of the theme to be used by oh-my-zsh.
'';
};
};
};
in in
{ {
@ -126,11 +160,17 @@ in
''; '';
description = "Plugins to source in <filename>.zshrc</filename>."; description = "Plugins to source in <filename>.zshrc</filename>.";
}; };
oh-my-zsh = mkOption {
type = ohMyZshModule;
default = {};
description = "Options to configure oh-my-zsh.";
};
}; };
}; };
config = ( config = mkMerge [
let (let
aliasesStr = concatStringsSep "\n" ( aliasesStr = concatStringsSep "\n" (
mapAttrsToList (k: v: "alias ${k}='${v}'") cfg.shellAliases mapAttrsToList (k: v: "alias ${k}='${v}'") cfg.shellAliases
); );
@ -141,8 +181,9 @@ in
mapAttrsToList export config.home.sessionVariables mapAttrsToList export config.home.sessionVariables
); );
in mkIf cfg.enable { in mkIf cfg.enable {
home.packages = [ pkgs.zsh ] home.packages = with pkgs; [ zsh ]
++ optional cfg.enableCompletion pkgs.nix-zsh-completions; ++ optional cfg.enableCompletion nix-zsh-completions
++ optional cfg.oh-my-zsh.enable oh-my-zsh;
home.file.".zshenv".text = '' home.file.".zshenv".text = ''
${optionalString (config.home.sessionVariableSetter == "zsh") ${optionalString (config.home.sessionVariableSetter == "zsh")
@ -169,6 +210,23 @@ in
"source ${pkgs.zsh-autosuggestions}/share/zsh-autosuggestions/zsh-autosuggestions.zsh" "source ${pkgs.zsh-autosuggestions}/share/zsh-autosuggestions/zsh-autosuggestions.zsh"
} }
${optionalString cfg.oh-my-zsh.enable ''
# oh-my-zsh configuration generated by NixOS
export ZSH=${pkgs.oh-my-zsh}/share/oh-my-zsh
export ZSH_CACHE_DIR=''${XDG_CACHE_HOME:-$HOME/.cache}/oh-my-zsh
${optionalString (cfg.oh-my-zsh.plugins != [])
"plugins=(${concatStringsSep " " cfg.oh-my-zsh.plugins})"
}
${optionalString (cfg.oh-my-zsh.custom != "")
"ZSH_CUSTOM=\"${cfg.oh-my-zsh.custom}\""
}
${optionalString (cfg.oh-my-zsh.theme != "")
"ZSH_THEME=\"${cfg.oh-my-zsh.theme}\""
}
source $ZSH/oh-my-zsh.sh
''}
${concatStrings (map (plugin: '' ${concatStrings (map (plugin: ''
source "${plugin.src}/${plugin.file}" source "${plugin.src}/${plugin.file}"
'') cfg.plugins)} '') cfg.plugins)}
@ -177,10 +235,12 @@ in
${cfg.initExtra} ${cfg.initExtra}
''; '';
})
programs.zsh = mkIf (builtins.length cfg.plugins > 0) { (mkIf cfg.oh-my-zsh.enable {
enableCompletion = mkDefault true; programs.zsh.enableCompletion = mkForce false;
}; })
} (mkIf (builtins.length cfg.plugins > 0) {
); programs.zsh.enableCompletion = mkDefault true;
})
];
} }