make custom dir classes easier to use, fix bugs, write docs, rename parameters to be consistent
parent
9b818960c2
commit
e8ec504dac
|
@ -42,16 +42,6 @@ typeset -gi _P9K_I
|
||||||
typeset -g _P9K_BG
|
typeset -g _P9K_BG
|
||||||
typeset -g _P9K_F
|
typeset -g _P9K_F
|
||||||
|
|
||||||
typeset -gA ICON_ASSOC=(
|
|
||||||
"/etc|/etc/*" ETC_ICON
|
|
||||||
"${HOME}" HOME_ICON
|
|
||||||
"${HOME}/*" HOME_SUB_ICON
|
|
||||||
)
|
|
||||||
typeset -gA STATE_ASSOC=(
|
|
||||||
"/etc|/etc/*" ETC
|
|
||||||
"${HOME}" HOME
|
|
||||||
"${HOME}/*" HOME_SUBFOLDER
|
|
||||||
)
|
|
||||||
# Specifies the maximum number of elements in the cache. When the cache grows over this limit,
|
# Specifies the maximum number of elements in the cache. When the cache grows over this limit,
|
||||||
# it gets cleared. This is meant to avoid memory leaks when a rogue prompt is filling the cache
|
# it gets cleared. This is meant to avoid memory leaks when a rogue prompt is filling the cache
|
||||||
# with data.
|
# with data.
|
||||||
|
@ -85,12 +75,24 @@ _p9k_cache_get() {
|
||||||
[[ -n $v ]] && _P9K_CACHE_VAL=("${(@0)${v[1,-2]}}")
|
[[ -n $v ]] && _P9K_CACHE_VAL=("${(@0)${v[1,-2]}}")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
typeset -gA _p9k_icon_cache=()
|
||||||
|
|
||||||
# Sets _P9K_RETVAL to the icon whose name is supplied via $1.
|
# Sets _P9K_RETVAL to the icon whose name is supplied via $1.
|
||||||
_p9k_get_icon() {
|
_p9k_get_icon() {
|
||||||
local x=POWERLEVEL9K_$1
|
_P9K_RETVAL=$_p9k_icon_cache[$1]
|
||||||
(( $+parameters[$x] )) && x=${(P)x} || x=$icons[$1]
|
if [[ -n $_P9K_RETVAL ]]; then
|
||||||
_P9K_RETVAL=${(g::)x}
|
_P9K_RETVAL[-1,-1]=''
|
||||||
[[ $_P9K_RETVAL != $'\b'? ]] || _P9K_RETVAL="%{$_P9K_RETVAL%}" # penance for past sins
|
else
|
||||||
|
if [[ $1 == $'\1'* ]]; then
|
||||||
|
_P9K_RETVAL=${1[2,-1]}
|
||||||
|
else
|
||||||
|
local x=POWERLEVEL9K_$1
|
||||||
|
(( $+parameters[$x] )) && x=${(P)x} || x=$icons[$1]
|
||||||
|
_P9K_RETVAL=${(g::)x}
|
||||||
|
[[ $_P9K_RETVAL != $'\b'? ]] || _P9K_RETVAL="%{$_P9K_RETVAL%}" # penance for past sins
|
||||||
|
fi
|
||||||
|
_p9k_icon_cache[$1]=${_P9K_RETVAL}.
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
typeset -ga _P9K_LEFT_JOIN=(1)
|
typeset -ga _P9K_LEFT_JOIN=(1)
|
||||||
|
@ -696,6 +698,37 @@ set_default POWERLEVEL9K_DIR_MAX_LENGTH 0
|
||||||
# by `emulate zsh && setopt extended_glob`.
|
# by `emulate zsh && setopt extended_glob`.
|
||||||
set_default -a POWERLEVEL9K_DIR_PACKAGE_FILES package.json composer.json
|
set_default -a POWERLEVEL9K_DIR_PACKAGE_FILES package.json composer.json
|
||||||
|
|
||||||
|
# You can define POWERLEVEL9K_DIR_CLASSES to specify custom styling and icons for different
|
||||||
|
# directories.
|
||||||
|
#
|
||||||
|
# POWERLEVEL9K_DIR_CLASSES must be an array with 3 * N elements. Each triplet consists of:
|
||||||
|
#
|
||||||
|
# 1. A pattern against which the current directory is matched. Matching is done with
|
||||||
|
# extended_glob option enabled.
|
||||||
|
# 2. Directory class for the purpose of styling.
|
||||||
|
# 3. Icon.
|
||||||
|
#
|
||||||
|
# Triplets are tried in order. The first triplet whose patterm matches $PWD wins. If there are no
|
||||||
|
# matches, there will be no icon and the styling is done according to POWERLEVEL9K_DIR_BACKGROUND,
|
||||||
|
# POWERLEVEL9K_DIR_FOREGROUND, etc.
|
||||||
|
#
|
||||||
|
# Example:
|
||||||
|
#
|
||||||
|
# POWERLEVEL9K_DIR_CLASSES=(
|
||||||
|
# '~/work(/*)#' WORK '(╯°□°)╯︵ ┻━┻'
|
||||||
|
# '~(/*)#' HOME '⌂'
|
||||||
|
# '*' DEFAULT '')
|
||||||
|
#
|
||||||
|
# POWERLEVEL9K_DIR_WORK_BACKGROUND=red
|
||||||
|
# POWERLEVEL9K_DIR_HOME_BACKGROUND=blue
|
||||||
|
# POWERLEVEL9K_DIR_DEFAULT_BACKGROUND=yellow
|
||||||
|
#
|
||||||
|
# With the settins, the current directory in the prompt may look like this:
|
||||||
|
#
|
||||||
|
# (╯°□°)╯︵ ┻━┻ ~/work/projects/important/urgent
|
||||||
|
#
|
||||||
|
# ⌂ ~/best/powerlevel10k
|
||||||
|
|
||||||
function _p9k_shorten_delim_len() {
|
function _p9k_shorten_delim_len() {
|
||||||
local def=$1
|
local def=$1
|
||||||
_P9K_RETVAL=${POWERLEVEL9K_SHORTEN_DELIMITER_LENGTH:--1}
|
_P9K_RETVAL=${POWERLEVEL9K_SHORTEN_DELIMITER_LENGTH:--1}
|
||||||
|
@ -872,20 +905,28 @@ prompt_dir() {
|
||||||
|
|
||||||
[[ $POWERLEVEL9K_DIR_SHOW_WRITABLE == true && ! -w $PWD ]]
|
[[ $POWERLEVEL9K_DIR_SHOW_WRITABLE == true && ! -w $PWD ]]
|
||||||
local w=$?
|
local w=$?
|
||||||
if ! _p9k_cache_get $0 $w $fake_first "$delim" "${parts[@]}"; then
|
if ! _p9k_cache_get $0 $PWD $w $fake_first "$delim" "${parts[@]}"; then
|
||||||
local state='' icon=''
|
local state=$0
|
||||||
|
local icon=''
|
||||||
if (( ! w )); then
|
if (( ! w )); then
|
||||||
state=NOT_WRITABLE
|
state+=_NOT_WRITABLE
|
||||||
icon=LOCK_ICON
|
icon=LOCK_ICON
|
||||||
else
|
else
|
||||||
icon=${ICON_ASSOC[(k)$PWD]:-DEFAULT}
|
local a='' b='' c=''
|
||||||
state=${STATE_ASSOC[(k)$PWD]:-DEFAULT}
|
for a b c in "${POWERLEVEL9K_DIR_CLASSES[@]}"; do
|
||||||
|
if [[ $PWD == ${~a} ]]; then
|
||||||
|
[[ -n $b ]] && state+=_${(U)b}
|
||||||
|
icon=$'\1'$c
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
local style=%b
|
local style=%b
|
||||||
_p9k_color blue $0_$state BACKGROUND
|
_p9k_color blue $state BACKGROUND
|
||||||
_p9k_background $_P9K_RETVAL
|
_p9k_background $_P9K_RETVAL
|
||||||
style+=$_P9K_RETVAL
|
style+=$_P9K_RETVAL
|
||||||
_p9k_color "$DEFAULT_COLOR" "$0_$state" FOREGROUND
|
_p9k_color "$DEFAULT_COLOR" $state FOREGROUND
|
||||||
_p9k_foreground $_P9K_RETVAL
|
_p9k_foreground $_P9K_RETVAL
|
||||||
style+=$_P9K_RETVAL
|
style+=$_P9K_RETVAL
|
||||||
|
|
||||||
|
@ -914,7 +955,7 @@ prompt_dir() {
|
||||||
if [[ $POWERLEVEL9K_DIR_HYPERLINK == true ]]; then
|
if [[ $POWERLEVEL9K_DIR_HYPERLINK == true ]]; then
|
||||||
content=$'%{\e]8;;file://'${${PWD//\%/%%25}//'#'/%%23}$'\a%}'$content$'%{\e]8;;\a%}'
|
content=$'%{\e]8;;file://'${${PWD//\%/%%25}//'#'/%%23}$'\a%}'$content$'%{\e]8;;\a%}'
|
||||||
fi
|
fi
|
||||||
_p9k_cache_set "$0_$state" "$2" blue "$DEFAULT_COLOR" "$icon" 0 "" $content
|
_p9k_cache_set $state "$2" blue "$DEFAULT_COLOR" "$icon" 0 "" $content
|
||||||
fi
|
fi
|
||||||
"$1_prompt_segment" "$_P9K_CACHE_VAL[@]"
|
"$1_prompt_segment" "$_P9K_CACHE_VAL[@]"
|
||||||
}
|
}
|
||||||
|
@ -2703,6 +2744,27 @@ _p9k_init() {
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if segment_in_use dir; then
|
||||||
|
if (( $+POWERLEVEL9K_DIR_CLASSES )); then
|
||||||
|
local -a x=()
|
||||||
|
local a='' b='' c=''
|
||||||
|
for a b c in "${POWERLEVEL9K_DIR_CLASSES[@]}"; do
|
||||||
|
x+=("$a" "$b" "${(g::)c}")
|
||||||
|
done
|
||||||
|
POWERLEVEL9K_DIR_CLASSES=("${x[@]}")
|
||||||
|
else
|
||||||
|
typeset -ga POWERLEVEL9K_DIR_CLASSES=()
|
||||||
|
_p9k_get_icon ETC_ICON
|
||||||
|
POWERLEVEL9K_DIR_CLASSES+=('/etc|/etc/*' ETC "$_P9K_RETVAL")
|
||||||
|
_p9k_get_icon HOME_ICON
|
||||||
|
POWERLEVEL9K_DIR_CLASSES+=('~' HOME "$_P9K_RETVAL")
|
||||||
|
_p9k_get_icon HOME_SUB_ICON
|
||||||
|
POWERLEVEL9K_DIR_CLASSES+=('~/*' HOME_SUBFOLDER "$_P9K_RETVAL")
|
||||||
|
_p9k_get_icon FOLDER_ICON
|
||||||
|
POWERLEVEL9K_DIR_CLASSES+=('*' DEFAULT "$_P9K_RETVAL")
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
_p9k_init_async_pump
|
_p9k_init_async_pump
|
||||||
|
|
||||||
if segment_in_use vi_mode && (( $+POWERLEVEL9K_VI_VISUAL_MODE_STRING )); then
|
if segment_in_use vi_mode && (( $+POWERLEVEL9K_VI_VISUAL_MODE_STRING )); then
|
||||||
|
@ -2764,4 +2826,4 @@ zmodload zsh/mathfunc
|
||||||
zmodload zsh/system
|
zmodload zsh/system
|
||||||
zmodload -F zsh/stat b:zstat
|
zmodload -F zsh/stat b:zstat
|
||||||
|
|
||||||
prompt_powerlevel9k_setup
|
prompt_powerlevel9k_setup
|
Loading…
Reference in New Issue