oh-my-posh/src/shell/scripts/omp.zsh

206 lines
5.6 KiB
Bash
Raw Normal View History

export POSH_THEME=::CONFIG::
2023-03-26 08:26:39 -07:00
export POSH_SHELL_VERSION=$ZSH_VERSION
export POSH_PID=$$
export POWERLINE_COMMAND="oh-my-posh"
2021-05-20 10:24:58 -07:00
export CONDA_PROMPT_MODIFIER=false
export POSH_PROMPT_COUNT=0
export ZLE_RPROMPT_INDENT=0
2020-12-23 04:00:50 -08:00
2022-02-20 04:56:28 -08:00
# set secondary prompt
2022-03-25 11:03:37 -07:00
PS2="$(::OMP:: print secondary --config="$POSH_THEME" --shell=zsh)"
2022-02-20 04:56:28 -08:00
function _omp_set_cursor_position() {
# not supported in Midnight Commander
# see https://github.com/JanDeDobbeleer/oh-my-posh/issues/3415
if [[ "::CURSOR::" != "true" ]] || [[ -v MC_SID ]]; then
return
fi
local oldstty=$(stty -g)
stty raw -echo min 0
local pos
echo -en "\033[6n" >/dev/tty
read -r -d R pos
pos=${pos:2} # strip off the esc-[
local parts=(${(s:;:)pos})
stty $oldstty
export POSH_CURSOR_LINE=${parts[1]}
export POSH_CURSOR_COLUMN=${parts[2]}
}
# template function for context loading
function set_poshcontext() {
return
}
function _omp_preexec() {
if [[ "::FTCS_MARKS::" = "true" ]]; then
printf "\033]133;C\007"
fi
_omp_start_time=$(::OMP:: get millis)
2020-12-23 04:00:50 -08:00
}
function _omp_precmd() {
_omp_status_cache=$?
_omp_pipestatus_cache=(${pipestatus[@]})
_omp_stack_count=${#dirstack[@]}
_omp_elapsed=-1
_omp_no_exit_code="true"
if [ $_omp_start_time ]; then
local omp_now=$(::OMP:: get millis --shell=zsh)
_omp_elapsed=$(($omp_now - $_omp_start_time))
_omp_no_exit_code="false"
2020-12-23 04:00:50 -08:00
fi
if [[ "${_omp_pipestatus_cache[-1]}" != "$_omp_status_cache" ]]; then
_omp_pipestatus_cache=("$_omp_status_cache")
fi
count=$((POSH_PROMPT_COUNT + 1))
export POSH_PROMPT_COUNT=$count
set_poshcontext
_omp_set_cursor_position
eval "$(::OMP:: print primary --config="$POSH_THEME" --status="$_omp_status_cache" --pipestatus="${_omp_pipestatus_cache[*]}" --execution-time="$_omp_elapsed" --stack-count="$_omp_stack_count" --eval --shell=zsh --shell-version="$ZSH_VERSION" --no-status="$_omp_no_exit_code")"
unset _omp_start_time
2020-12-23 04:00:50 -08:00
}
# add hook functions
autoload -Uz add-zsh-hook
add-zsh-hook precmd _omp_precmd
add-zsh-hook preexec _omp_preexec
2021-03-20 11:32:15 -07:00
# Prevent incorrect behaviors when the initialization is executed twice in current session.
function _omp_cleanup() {
local omp_widgets=(
self-insert
zle-line-init
)
local widget
for widget in "${omp_widgets[@]}"; do
if [[ "${widgets[_omp_original::$widget]}" ]]; then
# Restore the original widget.
zle -A _omp_original::$widget $widget
elif [[ "${widgets[$widget]}" = user:_omp_* ]]; then
# Delete the OMP-defined widget.
zle -D $widget
fi
done
}
_omp_cleanup
unset -f _omp_cleanup
function _omp_render_tooltip() {
if [[ "$KEYS" != ' ' ]]; then
return
fi
# Get the first word of command line as tip.
local tooltip_command=${${(MS)BUFFER##[[:graph:]]*}%%[[:space:]]*}
# Ignore an empty/repeated tooltip command.
if [[ -z "$tooltip_command" ]] || [[ "$tooltip_command" = "$_omp_tooltip_command" ]]; then
return
fi
_omp_tooltip_command="$tooltip_command"
local tooltip=$(::OMP:: print tooltip --config="$POSH_THEME" --status="$_omp_status_cache" --pipestatus="${_omp_pipestatus_cache[*]}" --execution-time="$_omp_elapsed" --stack-count="$_omp_stack_count" --command="$tooltip_command" --shell=zsh --shell-version="$ZSH_VERSION" --no-status="$_omp_no_exit_code")
if [[ -z "$tooltip" ]]; then
return
fi
RPROMPT=$tooltip
zle .reset-prompt
2021-06-05 07:14:44 -07:00
}
function _omp_zle-line-init() {
[[ $CONTEXT == start ]] || return 0
2021-07-03 09:38:23 -07:00
# Start regular line editor.
(( $+zle_bracketed_paste )) && print -r -n - $zle_bracketed_paste[1]
zle .recursive-edit
local -i ret=$?
(( $+zle_bracketed_paste )) && print -r -n - $zle_bracketed_paste[2]
2021-07-03 09:38:23 -07:00
_omp_tooltip_command=''
eval "$(::OMP:: print transient --config="$POSH_THEME" --status="$_omp_status_cache" --pipestatus="${_omp_pipestatus_cache[*]}" --execution-time="$_omp_elapsed" --stack-count="$_omp_stack_count" --eval --shell=zsh --shell-version="$ZSH_VERSION" --no-status="$_omp_no_exit_code")"
zle .reset-prompt
2021-07-03 09:38:23 -07:00
# Exit the shell if we receive EOT.
if [[ $ret == 0 && $KEYS == $'\4' ]]; then
exit
fi
2021-07-03 09:38:23 -07:00
if ((ret)); then
# TODO (fix): this is not equal to sending a SIGINT, since the status code ($?) is set to 1 instead of 130.
zle .send-break
else
# Enter
zle .accept-line
fi
return ret
2021-07-03 09:38:23 -07:00
}
# Helper function for calling a widget before the specified OMP function.
function _omp_call_widget() {
# The name of the OMP function.
local omp_func=$1
# The remainder are the widget to call and potential arguments.
shift
zle "$@" && shift 2 && $omp_func "$@"
}
# Create a widget with the specified OMP function.
# An existing widget will be preserved and decorated with the function.
function _omp_create_widget() {
# The name of the widget to create/decorate.
local widget=$1
# The name of the OMP function.
local omp_func=$2
case ${widgets[$widget]:-''} in
# Already decorated: do nothing.
user:_omp_decorated_*) ;;
# Non-existent: just create it.
'')
zle -N $widget $omp_func
;;
# User-defined or builtin: backup and decorate it.
*)
# Back up the original widget.
zle -A $widget _omp_original::$widget
eval "_omp_decorated_${(q)widget}() { _omp_call_widget ${(q)omp_func} _omp_original::${(q)widget} -- \"\$@\" }"
zle -N $widget _omp_decorated_$widget
;;
esac
}
# legacy functions
function enable_poshtooltips() {}
function enable_poshtransientprompt() {}
if [[ "::TOOLTIPS::" = "true" ]]; then
_omp_create_widget self-insert _omp_render_tooltip
fi
if [[ "::TRANSIENT::" = "true" ]]; then
_omp_create_widget zle-line-init _omp_zle-line-init
fi
2023-03-03 11:21:35 -08:00
if [[ "::UPGRADE::" = "true" ]]; then
echo "::UPGRADENOTICE::"
2023-03-03 11:21:35 -08:00
fi
2024-06-03 02:26:05 -07:00
if [[ "::AUTOUPGRADE::" = "true" ]]; then
::OMP:: upgrade
2024-06-03 02:26:05 -07:00
fi