Zsh: Difference between revisions
I divided the information into more manageable sections and formatted the code using Alejandra. Additionally, I added references and some other options. |
|||
Line 1: | Line 1: | ||
[https://www.zsh.org/ Zsh] is a powerful [ | [https://www.zsh.org/ Zsh] is a powerful Unix [https://wiki.nixos.org/wiki/Command_Shell shell] that functions both as an interactive shell and a scripting language interpreter. It extends the Bourne Shell (sh) with features from bash, ksh, and tcsh, offering [http://zsh.sourceforge.net/Guide/zshguide06.html advanced tab completion], improved [http://zsh.sourceforge.net/Doc/Release/Expansion.html globbing], and extensive customization options. Though not POSIX sh-compatible by default, it can be configured to be so with <code>emulate sh</code>. | ||
Key features include highly customizable prompts, enhanced command history, spelling correction, and robust job control. The Oh My Zsh framework simplifies managing plugins and themes. Zsh is cross-platform, available on Unix-like systems including Linux and macOS, and is popular among developers and system administrators for its advanced features and user-friendly enhancements. | |||
The [http://zsh.sourceforge.net/FAQ/zshfaq01.html#l4 Zsh FAQ] offers more reasons to use Zsh. | The [http://zsh.sourceforge.net/FAQ/zshfaq01.html#l4 Zsh FAQ] offers more reasons to use Zsh. | ||
Line 7: | Line 9: | ||
== Configuration == | == Configuration == | ||
==== 3.1 Basic ==== | |||
<syntaxhighlight lang="nix"> | |||
programs.zsh = { | |||
enable = true; | |||
}; | |||
</syntaxhighlight> | |||
=== | ==== 3.2 Advanced ==== | ||
The configuration below is using home manager, but a more limited version of it can be achieved if system-wide.<syntaxhighlight lang="nix"> | |||
programs.zsh = { | programs.zsh = { | ||
enable = true; | |||
enableCompletion = true; | |||
autosuggestions.enable = true; | |||
syntaxHighlighting.enable = true; | |||
shellAliases = { | |||
ll = "ls -l"; | |||
edit = "sudo -e"; | |||
update = "sudo nixos-rebuild switch"; | |||
}; | |||
history.size = 10000; | |||
history.ignoreAllDups = true; | |||
history.path = "$HOME/.zsh_history"; | |||
history.ignorePatterns = ["rm *" "pkill *" "cp *"]; | |||
}; | }; | ||
</ | </syntaxhighlight> | ||
== | == Tips and Tricks == | ||
==== | ==== 4.1 Where to see a list of options? ==== | ||
The home manager options are defined in the following [https://nix-community.github.io/home-manager/options.xhtml#opt-programs.zsh.enable Home Manager Options Manual]. | |||
The system-wide options are listed on [https://mynixos.com/search?q=zsh MyNixOS]. | |||
==== 4.2 How to use plugins? ==== | |||
Home manager has three ways of managing plugins: '''Zplug''', '''Oh-My-Zsh''' and '''Manual'''.<syntaxhighlight lang="nix"> | |||
programs.zsh = { | programs.zsh = { | ||
enable = true; | |||
zplug = { | zplug = { | ||
enable = true; | enable = true; | ||
plugins = [ | plugins = [ | ||
{ name = "zsh-users/zsh-autosuggestions"; } # Simple plugin installation | {name = "zsh-users/zsh-autosuggestions";} # Simple plugin installation | ||
{ name = "romkatv/powerlevel10k"; tags = [ as:theme depth:1 ]; } # Installations with additional options. For the list of options, please refer to Zplug README. | { | ||
name = "romkatv/powerlevel10k"; | |||
tags = [as:theme depth:1]; | |||
} # Installations with additional options. For the list of options, please refer to Zplug README. | |||
]; | ]; | ||
}; | }; | ||
ohMyZsh = { | ohMyZsh = { | ||
enable = true; | enable = true; | ||
plugins = [ "git" "thefuck" ]; | plugins = ["git" "thefuck"]; | ||
theme = "robbyrussell"; | theme = "robbyrussell"; | ||
}; | }; | ||
plugins = [ | plugins = [ | ||
{ | { | ||
name = "zsh-autocomplete"; | |||
name = "zsh- | |||
src = pkgs.fetchFromGitHub { | src = pkgs.fetchFromGitHub { | ||
owner = " | owner = "marlonrichert"; | ||
repo = "zsh- | repo = "zsh-autocomplete"; | ||
rev = " | rev = "23.07.13"; | ||
sha256 = " | sha256 = "sha256-/6V6IHwB5p0GT1u5SAiUa20LjFDSrMo731jFBq/bnpw="; | ||
}; | }; | ||
} | } | ||
{ | { | ||
name = " | name = "powerlevel10k"; | ||
file = " | src = pkgs.zsh-powerlevel10k; | ||
file = "share/zsh-powerlevel10k/powerlevel10k.zsh-theme"; | |||
} | |||
{ | |||
name = "powerlevel10k-config"; | |||
src = ./p10k-config; | |||
file = "p10k.zsh"; | |||
} | |||
{ | |||
name = "zsh-syntax-highlighting"; | |||
src = pkgs.fetchFromGitHub { | src = pkgs.fetchFromGitHub { | ||
owner = " | owner = "zsh-users"; | ||
repo = " | repo = "zsh-syntax-highlighting"; | ||
rev = " | rev = "0.8.0"; | ||
sha256 = " | sha256 = "sha256-iJdWopZwHpSyYl5/FQXEW7gl/SrKaYDEtTH9cGP7iPo="; | ||
}; | }; | ||
} | } | ||
]; | ]; | ||
}; | }; | ||
</ | </syntaxhighlight> | ||
== Troubleshooting == | == Troubleshooting == | ||
=== Zsh-autocomplete not working === | |||
==== 5.1 Zsh-autocomplete not working ==== | |||
You may have some issues with the {{ic|marlonrichert/zsh-autocomplete}} plugin on NixOS. That's because the default NixOS configuration overrides keybinds for up and down arrow keys. To fix this issue, you need to add this somewhere in your .zshrc (either manually if your .zshrc is not managed by Nix, or with {{ic|packages.zsh.initExtra}}) | You may have some issues with the {{ic|marlonrichert/zsh-autocomplete}} plugin on NixOS. That's because the default NixOS configuration overrides keybinds for up and down arrow keys. To fix this issue, you need to add this somewhere in your .zshrc (either manually if your .zshrc is not managed by Nix, or with {{ic|packages.zsh.initExtra}}) | ||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
Line 92: | Line 108: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
=== SHA Mismatch during manual plugin installation === | ==== 5.2 SHA Mismatch during manual plugin installation ==== | ||
If manual plugin installation fails with SHA mismatch, generating a valid hash as part of the error message can be achieved by temporarily switching to: | If manual plugin installation fails with SHA mismatch, generating a valid hash as part of the error message can be achieved by temporarily switching to: | ||
<syntaxhighlight lang="nix"> | <syntaxhighlight lang="nix"> | ||
Line 101: | Line 117: | ||
Redoing this is mandatory if one wants to update to a newer commit of the targeted plugin repository. | Redoing this is mandatory if one wants to update to a newer commit of the targeted plugin repository. | ||
=== GDM does not show user when zsh is the default shell === | ==== 5.3 GDM does not show user when zsh is the default shell ==== | ||
GDM only shows users that have their default shell set to a shell listed in /etc/shells. Setting the default shell using the following does not update /etc/shells. | GDM only shows users that have their default shell set to a shell listed in /etc/shells. Setting the default shell using the following does not update /etc/shells. | ||
<syntaxhighlight lang="nix"> | <syntaxhighlight lang="nix"> | ||
Line 111: | Line 127: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
== | == References == | ||
# https://www.zsh.org/ | |||
# http://zsh.sourceforge.net/Guide/zshguide06.html | |||
# http://zsh.sourceforge.net/Doc/Release/Expansion.html | |||
# http://zsh.sourceforge.net/FAQ/zshfaq01.html#l4 | |||
# https://nix-community.github.io/home-manager/options.xhtml#opt-programs.zsh.enable | |||
# https://mynixos.com/search?q=zsh | |||
[[Category:Shell]] | [[Category:Shell]] | ||
[[Category:NixOS Manual]] | [[Category:NixOS Manual]] |
Revision as of 09:22, 20 June 2024
Zsh is a powerful Unix shell that functions both as an interactive shell and a scripting language interpreter. It extends the Bourne Shell (sh) with features from bash, ksh, and tcsh, offering advanced tab completion, improved globbing, and extensive customization options. Though not POSIX sh-compatible by default, it can be configured to be so with emulate sh
.
Key features include highly customizable prompts, enhanced command history, spelling correction, and robust job control. The Oh My Zsh framework simplifies managing plugins and themes. Zsh is cross-platform, available on Unix-like systems including Linux and macOS, and is popular among developers and system administrators for its advanced features and user-friendly enhancements.
The Zsh FAQ offers more reasons to use Zsh.
Installation
See Command Shell.
Configuration
3.1 Basic
programs.zsh = {
enable = true;
};
3.2 Advanced
The configuration below is using home manager, but a more limited version of it can be achieved if system-wide.
programs.zsh = {
enable = true;
enableCompletion = true;
autosuggestions.enable = true;
syntaxHighlighting.enable = true;
shellAliases = {
ll = "ls -l";
edit = "sudo -e";
update = "sudo nixos-rebuild switch";
};
history.size = 10000;
history.ignoreAllDups = true;
history.path = "$HOME/.zsh_history";
history.ignorePatterns = ["rm *" "pkill *" "cp *"];
};
Tips and Tricks
4.1 Where to see a list of options?
The home manager options are defined in the following Home Manager Options Manual.
The system-wide options are listed on MyNixOS.
4.2 How to use plugins?
Home manager has three ways of managing plugins: Zplug, Oh-My-Zsh and Manual.
programs.zsh = {
enable = true;
zplug = {
enable = true;
plugins = [
{name = "zsh-users/zsh-autosuggestions";} # Simple plugin installation
{
name = "romkatv/powerlevel10k";
tags = [as:theme depth:1];
} # Installations with additional options. For the list of options, please refer to Zplug README.
];
};
ohMyZsh = {
enable = true;
plugins = ["git" "thefuck"];
theme = "robbyrussell";
};
plugins = [
{
name = "zsh-autocomplete";
src = pkgs.fetchFromGitHub {
owner = "marlonrichert";
repo = "zsh-autocomplete";
rev = "23.07.13";
sha256 = "sha256-/6V6IHwB5p0GT1u5SAiUa20LjFDSrMo731jFBq/bnpw=";
};
}
{
name = "powerlevel10k";
src = pkgs.zsh-powerlevel10k;
file = "share/zsh-powerlevel10k/powerlevel10k.zsh-theme";
}
{
name = "powerlevel10k-config";
src = ./p10k-config;
file = "p10k.zsh";
}
{
name = "zsh-syntax-highlighting";
src = pkgs.fetchFromGitHub {
owner = "zsh-users";
repo = "zsh-syntax-highlighting";
rev = "0.8.0";
sha256 = "sha256-iJdWopZwHpSyYl5/FQXEW7gl/SrKaYDEtTH9cGP7iPo=";
};
}
];
};
Troubleshooting
5.1 Zsh-autocomplete not working
You may have some issues with the marlonrichert/zsh-autocomplete
plugin on NixOS. That's because the default NixOS configuration overrides keybinds for up and down arrow keys. To fix this issue, you need to add this somewhere in your .zshrc (either manually if your .zshrc is not managed by Nix, or with packages.zsh.initExtra
)
bindkey "''${key[Up]}" up-line-or-search
5.2 SHA Mismatch during manual plugin installation
If manual plugin installation fails with SHA mismatch, generating a valid hash as part of the error message can be achieved by temporarily switching to:
sha256 = lib.fakeSha256;
This will print a valid SHA to the console and then can be used as final value for the sha256 field. Redoing this is mandatory if one wants to update to a newer commit of the targeted plugin repository.
5.3 GDM does not show user when zsh is the default shell
GDM only shows users that have their default shell set to a shell listed in /etc/shells. Setting the default shell using the following does not update /etc/shells.
users.defaultUserShell = pkgs.zsh;
To add the zsh package to /etc/shells you must update environment.shells.
environment.shells = with pkgs; [ zsh ];