summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorromkatv <roman.perepelitsa@gmail.com>2019-10-29 00:12:42 +0300
committerromkatv <roman.perepelitsa@gmail.com>2019-10-29 00:12:42 +0300
commit806ec183ffae5829451405b372c5bce37a83dfa3 (patch)
tree9b9a33df0994bdb4db3bde0ec0812b071304432c
parentaf703932b3b9279f2c6a5b8e6ec4d000fdbef429 (diff)
add `p10k display` command
-rw-r--r--internal/p10k.zsh86
1 files changed, 84 insertions, 2 deletions
diff --git a/internal/p10k.zsh b/internal/p10k.zsh
index 9f411a96..6b7d8a6d 100644
--- a/internal/p10k.zsh
+++ b/internal/p10k.zsh
@@ -5399,7 +5399,12 @@ Commands:
%Bconfigure%b run interactive configuration wizard
%Bsegment%b print a user-defined prompt segment
- %Bhelp%b print this help message"
+ %Bdisplay%b show, hide or toggle prompt parts
+ %Bhelp%b print this help message
+
+Print help for a specific command:
+
+ %2Fp10k%f %Bhelp%b command"
typeset -gr __p9k_p10k_segment_usage="Usage: %2Fp10k%f %Bsegment%b [-h] [{+|-}re] [-s state] [-b bg] [-f fg] [-i icon] [-c cond] [-t text]
@@ -5478,6 +5483,27 @@ typeset -gr __p9k_p10k_finalize_usage="Usage: %2Fp10k%f %Bfinalize%b
Perform the final stage of initialization. Must be called at the very end of zshrc."
+typeset -gr __p9k_p10k_display_usage="Usage: %2Fp10k%f %Bdisplay%b [-h] [[+|-]part]...
+
+Show, hide or toggle prompt parts. If called from zle, the current
+prompt gets refreshed.
+
+Options:
+ part toggle the designated prompt part
+ +part show the designated prompt part
+ -part hide the designated prompt part
+ -h print this help message
+
+Parts:
+ right right prompt
+ s:name segment with the given name (e.g., s:kubecontext)
+
+Example: Bind Ctrl+P to toggle right prompt.
+
+ function toggle-right-prompt() { p10k display right; }
+ zle -N toggle-right-prompt
+ bindkey '^P' toggle-right-prompt"
+
function p10k() {
[[ $# != 1 || $1 != finalize ]] || { p10k-instant-prompt-finalize; return }
@@ -5492,7 +5518,6 @@ function p10k() {
case $1 in
segment)
shift
- local -i num_opts=ARGC
local opt state bg=0 fg icon cond text ref=0 expand=0
while getopts ':s:b:f:i:c:t:reh' opt; do
case $opt in
@@ -5529,6 +5554,63 @@ function p10k() {
"$bg" "${fg:-$_p9k_color1}" "$icon" "$expand" "$cond" "$text"
return 0
;;
+ display)
+ if (( ARGC == 1 )); then
+ print -rP -- $__p9k_p10k_display_usage >&2
+ return 1
+ fi
+ shift
+ local opt
+ local -i reset
+ for opt; do
+ case $opt in
+ -h) print -rP -- $__p9k_p10k_display_usage >&2; return 0;;
+ +right)
+ if (( $+__p9k_x_right )); then
+ reset=1
+ unset __p9k_x_right __p9k_x_gap
+ fi
+ ;;
+ -right)
+ if (( ! $+__p9k_x_right )); then
+ reset=1
+ __p9k_x_gap=
+ __p9k_x_right=
+ fi
+ ;;
+ right)
+ reset=1
+ if (( $+__p9k_x_right )); then
+ unset __p9k_x_right __p9k_x_gap
+ else
+ typeset -g __p9k_x_right=
+ typeset -g __p9k_x_gap=
+ fi
+ ;;
+ +s:*)
+ if (( $+parameters[__p9k_s_${opt:3 }] )); then
+ reset=1
+ unset __p9k_s_${opt:3 }
+ fi
+ ;;
+ -s:*)
+ if (( ! $+parameters[__p9k_s_${opt:3 }] )); then
+ reset=1
+ typeset -g __p9k_s_${opt:3 }=
+ fi
+ ;;
+ s:*)
+ reset=1
+ if (( $+parameters[__p9k_s_${opt:2 }] )); then
+ unset __p9k_s_${opt:2 }
+ else
+ typeset -g __p9k_s_${opt:2 }=
+ fi
+ ;;
+ esac
+ done
+ (( reset )) && zle && _p9k_reset_prompt || true
+ ;;
configure)
if (( ARGC > 1 )); then
print -rP -- $__p9k_p10k_configure_usage >&2