add POWERLEVEL9K_EXPERIMENTAL_TIME_REALTIME

This commit is contained in:
romkatv 2019-03-11 19:12:53 +01:00
parent 14366ed0ce
commit afc1a07a71

View file

@ -1551,9 +1551,16 @@ build_test_stats() {
################################################################ ################################################################
# System time # System time
# If set to true, `time` prompt will update every second.
set_default POWERLEVEL9K_EXPERIMENTAL_TIME_REALTIME false
prompt_time() { prompt_time() {
set_default POWERLEVEL9K_TIME_FORMAT "%D{%H:%M:%S}" set_default POWERLEVEL9K_TIME_FORMAT "%D{%H:%M:%S}"
[[ -v _P9K_REFRESH_PROMPT ]] || typeset -gH _P9K_TIME=$(print -P $POWERLEVEL9K_TIME_FORMAT) if [[ $POWERLEVEL9K_EXPERIMENTAL_TIME_REALTIME == true ]]; then
local _P9K_TIME=$POWERLEVEL9K_TIME_FORMAT
else
[[ -v _P9K_REFRESH_PROMPT ]] || typeset -gH _P9K_TIME=$(print -P $POWERLEVEL9K_TIME_FORMAT)
fi
"$1_prompt_segment" "$0" "$2" "$DEFAULT_COLOR_INVERTED" "$DEFAULT_COLOR" "$_P9K_TIME" "TIME_ICON" "$1_prompt_segment" "$0" "$2" "$DEFAULT_COLOR_INVERTED" "$DEFAULT_COLOR" "$_P9K_TIME" "TIME_ICON"
} }
@ -1759,7 +1766,7 @@ typeset -fH _p9k_vcs_resume() {
if [[ -z $_P9K_NEXT_VCS_DIR ]]; then if [[ -z $_P9K_NEXT_VCS_DIR ]]; then
unset _P9K_NEXT_VCS_DIR unset _P9K_NEXT_VCS_DIR
_p9k_reset_prompts _p9k_update_prompts
else else
typeset -gFH _P9K_GITSTATUS_START_TIME=$EPOCHREALTIME typeset -gFH _P9K_GITSTATUS_START_TIME=$EPOCHREALTIME
if ! gitstatus_query -d $_P9K_NEXT_VCS_DIR -t 0 -c _p9k_vcs_resume POWERLEVEL9K; then if ! gitstatus_query -d $_P9K_NEXT_VCS_DIR -t 0 -c _p9k_vcs_resume POWERLEVEL9K; then
@ -1769,7 +1776,7 @@ typeset -fH _p9k_vcs_resume() {
case $VCS_STATUS_RESULT in case $VCS_STATUS_RESULT in
*-sync) *-sync)
unset _P9K_NEXT_VCS_DIR unset _P9K_NEXT_VCS_DIR
_p9k_reset_prompts _p9k_update_prompts
;; ;;
tout) tout)
typeset -gH _P9K_NEXT_VCS_DIR="" typeset -gH _P9K_NEXT_VCS_DIR=""
@ -2090,7 +2097,7 @@ typeset -fH _p9k_set_prompts() {
[[ $ITERM_SHELL_INTEGRATION_INSTALLED == "Yes" ]] && PROMPT="%{$(iterm2_prompt_mark)%}$PROMPT" [[ $ITERM_SHELL_INTEGRATION_INSTALLED == "Yes" ]] && PROMPT="%{$(iterm2_prompt_mark)%}$PROMPT"
} }
typeset -fH _p9k_reset_prompts() { typeset -fH _p9k_update_prompts() {
[[ $_P9K_LOADED == true ]] || return [[ $_P9K_LOADED == true ]] || return
typeset -gH _P9K_REFRESH_PROMPT='' typeset -gH _P9K_REFRESH_PROMPT=''
_p9k_set_prompts _p9k_set_prompts
@ -2187,6 +2194,31 @@ prompt_powerlevel9k_setup() {
local -i max_dirty=${POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY:--1} local -i max_dirty=${POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY:--1}
[[ $POWERLEVEL9K_DISABLE_GITSTATUS == true ]] || gitstatus_start -m $max_dirty POWERLEVEL9K [[ $POWERLEVEL9K_DISABLE_GITSTATUS == true ]] || gitstatus_start -m $max_dirty POWERLEVEL9K
if [[ $POWERLEVEL9K_EXPERIMENTAL_TIME_REALTIME == true ]]; then
local fifo && fifo=$(mktemp -u "${TMPDIR:-/tmp}"/p10k.$$.pipe.time.XXXXXXXXXX)
typeset -giH _P9K_TIMER_FD=0
_p9k_start_timer() {
emulate -L zsh
setopt err_return
unsetopt bg_nice
mkfifo $fifo
exec {_P9K_TIMER_FD}<>$fifo
typeset -gfH _p9k_on_timer() {
local _ && IFS='' read -u $_P9K_TIMER_FD _ && zle && zle .reset-prompt
}
zle -F $_P9K_TIMER_FD _p9k_on_timer
zsh -c "while kill -0 $$; do sleep 1; echo; done" >&$_P9K_TIMER_FD 2>/dev/null &!
}
if ! _p9k_start_timer ; then
echo "powerlevel10k: failed to initialize realtime clock" >&2
zle -F $_P9K_TIMER_FD
(( _P9K_TIMER_FD )) && exec {_P9K_TIMER_FD}>&-
unset _P9K_TIMER_FD
unset -f _p9k_on_timer
fi
rm -f "$fifo"
fi
_P9K_LOADED=true _P9K_LOADED=true
} }