mirror of
https://github.com/LnL7/nix-darwin.git
synced 2025-03-16 21:38:21 +00:00
add shell options for zsh
This commit is contained in:
parent
58f246595a
commit
2af32bbcfe
2 changed files with 105 additions and 56 deletions
|
@ -40,26 +40,17 @@
|
||||||
programs.zsh.enable = true;
|
programs.zsh.enable = true;
|
||||||
programs.zsh.shell = "${pkgs.lnl.zsh}/bin/zsh";
|
programs.zsh.shell = "${pkgs.lnl.zsh}/bin/zsh";
|
||||||
|
|
||||||
environment.variables.EDITOR = "vim";
|
programs.zsh.shellInit = ''
|
||||||
environment.variables.HOMEBREW_CASK_OPTS = "--appdir=/Applications/cask";
|
export NIX_PATH=nixpkgs=$HOME/.nix-defexpr/nixpkgs:darwin=$HOME/.nix-defexpr/darwin:darwin-config=$HOME/.nixpkgs/darwin-config.nix:$HOME/.nix-defexpr/channels_root
|
||||||
|
|
||||||
environment.variables.GIT_SSL_CAINFO = "${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt";
|
# Set up secure multi-user builds: non-root users build through the
|
||||||
environment.variables.SSL_CERT_FILE = "${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt";
|
# Nix daemon.
|
||||||
|
if [ "$USER" != root -a ! -w /nix/var/nix/db ]; then
|
||||||
environment.shellAliases.l = "ls -lh";
|
export NIX_REMOTE=daemon
|
||||||
environment.shellAliases.ls = "ls -G";
|
fi
|
||||||
environment.shellAliases.g = "git log --oneline --max-count 42";
|
'';
|
||||||
environment.shellAliases.gl = "git log --graph --oneline";
|
|
||||||
environment.shellAliases.gd = "git diff --minimal --patch";
|
|
||||||
|
|
||||||
environment.etc."zprofile".text = ''
|
|
||||||
# /etc/zprofile: DO NOT EDIT -- this file has been generated automatically.
|
|
||||||
# This file is read for login shells.
|
|
||||||
|
|
||||||
# Only execute this file once per shell.
|
|
||||||
if [ -n "$__ETC_ZPROFILE_SOURCED" ]; then return; fi
|
|
||||||
__ETC_ZPROFILE_SOURCED=1
|
|
||||||
|
|
||||||
|
programs.zsh.loginShellInit = ''
|
||||||
autoload -U promptinit && promptinit
|
autoload -U promptinit && promptinit
|
||||||
PROMPT='%B%(?..%? )%b⇒ '
|
PROMPT='%B%(?..%? )%b⇒ '
|
||||||
RPROMPT='%F{green}%~%f'
|
RPROMPT='%F{green}%~%f'
|
||||||
|
@ -100,38 +91,7 @@
|
||||||
fi
|
fi
|
||||||
'';
|
'';
|
||||||
|
|
||||||
environment.etc."zshenv".text = ''
|
programs.zsh.interactiveShellInit = ''
|
||||||
# /etc/zshenv: DO NOT EDIT -- this file has been generated automatically.
|
|
||||||
# This file is read for all shells.
|
|
||||||
|
|
||||||
# Only execute this file once per shell.
|
|
||||||
# But don't clobber the environment of interactive non-login children!
|
|
||||||
|
|
||||||
if [ -n "$__ETC_ZSHENV_SOURCED" ]; then return; fi
|
|
||||||
export __ETC_ZSHENV_SOURCED=1
|
|
||||||
|
|
||||||
export NIX_PATH=nixpkgs=$HOME/.nix-defexpr/nixpkgs:darwin=$HOME/.nix-defexpr/darwin:darwin-config=$HOME/.nixpkgs/darwin-config.nix:$HOME/.nix-defexpr/channels_root
|
|
||||||
|
|
||||||
# Set up secure multi-user builds: non-root users build through the
|
|
||||||
# Nix daemon.
|
|
||||||
if [ "$USER" != root -a ! -w /nix/var/nix/db ]; then
|
|
||||||
export NIX_REMOTE=daemon
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Read system-wide modifications.
|
|
||||||
if test -f /etc/zshenv.local; then
|
|
||||||
. /etc/zshenv.local
|
|
||||||
fi
|
|
||||||
'';
|
|
||||||
|
|
||||||
environment.etc."zshrc".text = ''
|
|
||||||
# /etc/zshrc: DO NOT EDIT -- this file has been generated automatically.
|
|
||||||
# This file is read for interactive shells.
|
|
||||||
|
|
||||||
# Only execute this file once per shell.
|
|
||||||
if [ -n "$__ETC_ZSHRC_SOURCED" -o -n "$NOSYSZSHRC" ]; then return; fi
|
|
||||||
__ETC_ZSHRC_SOURCED=1
|
|
||||||
|
|
||||||
# history defaults
|
# history defaults
|
||||||
SAVEHIST=2000
|
SAVEHIST=2000
|
||||||
HISTSIZE=2000
|
HISTSIZE=2000
|
||||||
|
@ -144,13 +104,20 @@
|
||||||
|
|
||||||
${config.system.build.setEnvironment}
|
${config.system.build.setEnvironment}
|
||||||
${config.system.build.setAliases}
|
${config.system.build.setAliases}
|
||||||
|
|
||||||
# Read system-wide modifications.
|
|
||||||
if test -f /etc/zshrc.local; then
|
|
||||||
. /etc/zshrc.local
|
|
||||||
fi
|
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
environment.variables.EDITOR = "vim";
|
||||||
|
environment.variables.HOMEBREW_CASK_OPTS = "--appdir=/Applications/cask";
|
||||||
|
|
||||||
|
environment.variables.GIT_SSL_CAINFO = "${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt";
|
||||||
|
environment.variables.SSL_CERT_FILE = "${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt";
|
||||||
|
|
||||||
|
environment.shellAliases.l = "ls -lh";
|
||||||
|
environment.shellAliases.ls = "ls -G";
|
||||||
|
environment.shellAliases.g = "git log --oneline --max-count 42";
|
||||||
|
environment.shellAliases.gl = "git log --graph --oneline";
|
||||||
|
environment.shellAliases.gd = "git diff --minimal --patch";
|
||||||
|
|
||||||
nixpkgs.config.allowUnfree = true;
|
nixpkgs.config.allowUnfree = true;
|
||||||
|
|
||||||
nixpkgs.config.packageOverrides = self: {
|
nixpkgs.config.packageOverrides = self: {
|
||||||
|
|
|
@ -6,6 +6,15 @@ let
|
||||||
|
|
||||||
cfg = config.programs.zsh;
|
cfg = config.programs.zsh;
|
||||||
|
|
||||||
|
zsh = pkgs.runCommand pkgs.zsh.name
|
||||||
|
{ buildInputs = [ pkgs.makeWrapper ]; }
|
||||||
|
''
|
||||||
|
source $stdenv/setup
|
||||||
|
|
||||||
|
mkdir -p $out/bin
|
||||||
|
makeWrapper ${pkgs.zsh}/bin/zsh $out/bin/zsh
|
||||||
|
'';
|
||||||
|
|
||||||
in
|
in
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -21,17 +30,90 @@ in
|
||||||
|
|
||||||
programs.zsh.shell = mkOption {
|
programs.zsh.shell = mkOption {
|
||||||
type = types.path;
|
type = types.path;
|
||||||
default = "${pkgs.zsh}/bin/zsh";
|
default = "${zsh}/bin/zsh";
|
||||||
description = ''
|
description = ''
|
||||||
Zsh shell to use.
|
Zsh shell to use.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
programs.zsh.shellInit = mkOption {
|
||||||
|
default = "";
|
||||||
|
description = ''
|
||||||
|
Shell script code called during zsh shell initialisation.
|
||||||
|
'';
|
||||||
|
type = types.lines;
|
||||||
|
};
|
||||||
|
|
||||||
|
programs.zsh.loginShellInit = mkOption {
|
||||||
|
default = "";
|
||||||
|
description = ''
|
||||||
|
Shell script code called during zsh login shell initialisation.
|
||||||
|
'';
|
||||||
|
type = types.lines;
|
||||||
|
};
|
||||||
|
|
||||||
|
programs.zsh.interactiveShellInit = mkOption {
|
||||||
|
default = "";
|
||||||
|
description = ''
|
||||||
|
Shell script code called during interactive zsh shell initialisation.
|
||||||
|
'';
|
||||||
|
type = types.lines;
|
||||||
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
|
|
||||||
environment.variables.SHELL = "${cfg.shell}";
|
environment.variables.SHELL = "${cfg.shell}";
|
||||||
|
|
||||||
|
environment.etc."zshenv".text = ''
|
||||||
|
# /etc/zshenv: DO NOT EDIT -- this file has been generated automatically.
|
||||||
|
# This file is read for all shells.
|
||||||
|
|
||||||
|
# Only execute this file once per shell.
|
||||||
|
# But don't clobber the environment of interactive non-login children!
|
||||||
|
if [ -n "$__ETC_ZSHENV_SOURCED" ]; then return; fi
|
||||||
|
export __ETC_ZSHENV_SOURCED=1
|
||||||
|
|
||||||
|
${cfg.shellInit}
|
||||||
|
|
||||||
|
# Read system-wide modifications.
|
||||||
|
if test -f /etc/zshenv.local; then
|
||||||
|
. /etc/zshenv.local
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
|
||||||
|
environment.etc."zprofile".text = ''
|
||||||
|
# /etc/zprofile: DO NOT EDIT -- this file has been generated automatically.
|
||||||
|
# This file is read for login shells.
|
||||||
|
|
||||||
|
# Only execute this file once per shell.
|
||||||
|
if [ -n "$__ETC_ZPROFILE_SOURCED" ]; then return; fi
|
||||||
|
__ETC_ZPROFILE_SOURCED=1
|
||||||
|
|
||||||
|
${cfg.loginShellInit}
|
||||||
|
|
||||||
|
# Read system-wide modifications.
|
||||||
|
if test -f /etc/zprofile.local; then
|
||||||
|
. /etc/zprofile.local
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
|
||||||
|
environment.etc."zshrc".text = ''
|
||||||
|
# /etc/zshrc: DO NOT EDIT -- this file has been generated automatically.
|
||||||
|
# This file is read for interactive shells.
|
||||||
|
|
||||||
|
# Only execute this file once per shell.
|
||||||
|
if [ -n "$__ETC_ZSHRC_SOURCED" -o -n "$NOSYSZSHRC" ]; then return; fi
|
||||||
|
__ETC_ZSHRC_SOURCED=1
|
||||||
|
|
||||||
|
${cfg.interactiveShellInit}
|
||||||
|
|
||||||
|
# Read system-wide modifications.
|
||||||
|
if test -f /etc/zshrc.local; then
|
||||||
|
. /etc/zshrc.local
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue