95d0c4b603
Co-authored-by: Andrew Janke <janke@pobox.com> Co-authored-by: Marcelo Parada <marcelo.parada@axoninsight.com> Co-authored-by: Uy Ha <hchanuy@gmail.com> Co-authored-by: Valentin Uveges <valentin.uveges@gmail.com>
93 lines
3.1 KiB
Bash
93 lines
3.1 KiB
Bash
# Sets color variable such as $fg, $bg, $color and $reset_color
|
|
autoload -U colors && colors
|
|
|
|
# Expand variables and commands in PROMPT variables
|
|
setopt prompt_subst
|
|
|
|
# Prompt function theming defaults
|
|
ZSH_THEME_GIT_PROMPT_PREFIX="git:(" # Beginning of the git prompt, before the branch name
|
|
ZSH_THEME_GIT_PROMPT_SUFFIX=")" # End of the git prompt
|
|
ZSH_THEME_GIT_PROMPT_DIRTY="*" # Text to display if the branch is dirty
|
|
ZSH_THEME_GIT_PROMPT_CLEAN="" # Text to display if the branch is clean
|
|
ZSH_THEME_RUBY_PROMPT_PREFIX="("
|
|
ZSH_THEME_RUBY_PROMPT_SUFFIX=")"
|
|
|
|
|
|
# Use diff --color if available
|
|
if command diff --color /dev/null{,} &>/dev/null; then
|
|
function diff {
|
|
command diff --color "$@"
|
|
}
|
|
fi
|
|
|
|
|
|
# Don't set ls coloring if disabled
|
|
[[ "$DISABLE_LS_COLORS" != true ]] || return 0
|
|
|
|
function test-ls-args {
|
|
local cmd="$1" # ls, gls, colorls, ...
|
|
local args="${@[2,-1]}" # arguments except the first one
|
|
command "$cmd" "$args" /dev/null &>/dev/null
|
|
}
|
|
|
|
# Find the option for using colors in ls, depending on the version
|
|
case "$OSTYPE" in
|
|
netbsd*)
|
|
# On NetBSD, test if `gls` (GNU ls) is installed (this one supports colors);
|
|
# otherwise, leave ls as is, because NetBSD's ls doesn't support -G
|
|
test-ls-args gls --color && alias ls='gls --color=tty'
|
|
;;
|
|
openbsd*)
|
|
# On OpenBSD, `gls` (ls from GNU coreutils) and `colorls` (ls from base,
|
|
# with color and multibyte support) are available from ports.
|
|
# `colorls` will be installed on purpose and can't be pulled in by installing
|
|
# coreutils (which might be installed for ), so prefer it to `gls`.
|
|
test-ls-args gls --color && alias ls='gls --color=tty'
|
|
test-ls-args colorls -G && alias ls='colorls -G'
|
|
;;
|
|
(darwin|freebsd)*)
|
|
# This alias works by default just using $LSCOLORS
|
|
test-ls-args ls -G && alias ls='ls -G'
|
|
# Only use GNU ls if installed and there are user defaults for $LS_COLORS,
|
|
# as the default coloring scheme is not very pretty
|
|
[[ -n "$LS_COLORS" || -f "$HOME/.dircolors" ]] \
|
|
&& test-ls-args gls --color \
|
|
&& alias ls='gls --color=tty'
|
|
;;
|
|
*)
|
|
if test-ls-args ls --color; then
|
|
alias ls='ls --color=tty'
|
|
elif test-ls-args ls -G; then
|
|
alias ls='ls -G'
|
|
fi
|
|
;;
|
|
esac
|
|
|
|
unfunction test-ls-args
|
|
|
|
|
|
# Default coloring for BSD-based ls
|
|
export LSCOLORS="Gxfxcxdxbxegedabagacad"
|
|
|
|
# Default coloring for GNU-based ls
|
|
if [[ -z "$LS_COLORS" ]]; then
|
|
# Define LS_COLORS via dircolors if available. Otherwise, set a default
|
|
# equivalent to LSCOLORS (generated via https://geoff.greer.fm/lscolors)
|
|
if (( $+commands[dircolors] )); then
|
|
[[ -f "$HOME/.dircolors" ]] \
|
|
&& source <(dircolors -b "$HOME/.dircolors") \
|
|
|| source <(dircolors -b)
|
|
else
|
|
export LS_COLORS="di=34:ln=35:so=32:pi=33:ex=31:bd=34;46:cd=34;43:su=37;41:sg=30;43:tw=30;42:ow=34;42:"
|
|
fi
|
|
fi
|
|
|
|
# Take advantage of $LS_COLORS for completion as well.
|
|
function omz_set_completion_colors {
|
|
zstyle ':completion:*' list-colors "${(s.:.)LS_COLORS}"
|
|
add-zsh-hook -d precmd omz_set_completion_colors
|
|
unfunction omz_set_completion_colors
|
|
}
|
|
|
|
autoload -Uz add-zsh-hook
|
|
add-zsh-hook precmd omz_set_completion_colors
|