Squashed 'gitstatus/' changes from 0127fd26a..cc956ca78

cc956ca78 interrupt p10k instant prompt before printing "gitstatus failed to initialize" error
db3603bc8 improve "gitstatus failed to initialize" error message
e164594ea work around bugs in cygwin
55af96ade cleanup + todo
0e70dbc56 add an empty line before the error message

git-subtree-dir: gitstatus
git-subtree-split: cc956ca7878ef6d00bb1f35861864d0a40ffac75
pull/778/head
romkatv 2020-05-26 08:37:25 +02:00
parent ee44f9e112
commit 9a4bbcd930
4 changed files with 36 additions and 44 deletions

7
build
View File

@ -56,9 +56,12 @@ appname=gitstatusd-"$gitstatus_kernel"-"$gitstatus_arch"
libgit2_tmp="$outdir"/deps/"$appname".libgit2.tmp libgit2_tmp="$outdir"/deps/"$appname".libgit2.tmp
cleanup() { cleanup() {
cd /
command rm -rf -- "$workdir" "$outdir"/usrbin/"$appname".tmp "$libgit2_tmp"
trap - INT QUIT TERM ILL PIPE trap - INT QUIT TERM ILL PIPE
cd /
if ! command rm -rf -- "$workdir" "$outdir"/usrbin/"$appname".tmp "$libgit2_tmp"; then
command sleep 5
command rm -rf -- "$workdir" "$outdir"/usrbin/"$appname".tmp "$libgit2_tmp"
fi
} }
trap cleanup INT QUIT TERM ILL PIPE trap cleanup INT QUIT TERM ILL PIPE

View File

@ -225,6 +225,7 @@ function gitstatus_start() {
} }
if ! gitstatus_start_impl; then if ! gitstatus_start_impl; then
echo "" >&2
echo "gitstatus_start: failed to start gitstatusd" >&2 echo "gitstatus_start: failed to start gitstatusd" >&2
[[ -z "${req_fifo:-}" ]] || command rm -f "$req_fifo" [[ -z "${req_fifo:-}" ]] || command rm -f "$req_fifo"
[[ -z "${resp_fifo:-}" ]] || command rm -f "$resp_fifo" [[ -z "${resp_fifo:-}" ]] || command rm -f "$resp_fifo"

View File

@ -725,60 +725,46 @@ function gitstatus_start"${1:-}"() {
gitstatus_stop$fsuf $name gitstatus_stop$fsuf $name
setopt prompt_percent no_prompt_subst no_prompt_bang setopt prompt_percent no_prompt_subst no_prompt_bang
(( $+functions[p10k] )) && p10k clear-instant-prompt
print -ru2 -- '' print -ru2 -- ''
print -Pru2 -- '[%F{red}ERROR%f]: gitstatus failed to initialize.' print -Pru2 -- '[%F{red}ERROR%f]: gitstatus failed to initialize.'
print -ru2 -- '' print -ru2 -- ''
print -ru2 -- ' Your Git prompt may disappear or become slow.' print -ru2 -- ' Your Git prompt may disappear or become slow.'
if [[ -s $xtrace ]]; then if [[ -s $xtrace ]]; then
print -ru2 -- '' print -ru2 -- ''
print -ru2 -- " The content of ${(q-)xtrace} (gitstatus_start xtrace):" print -Pru2 -- " Zsh log (%U${xtrace//\%/%%}%u):"
print -Pru2 -- '%F{yellow}' print -Pru2 -- '%F{yellow}'
>&2 awk '{print " " $0}' <$xtrace print -lru2 -- "${(@)${(@f)$(<$xtrace)}/#/ }"
print -Pru2 -- "%F{red} ^ this command failed ($err)%f" print -Pru2 -- " %F{red}^ this command failed ($err)%f"
fi fi
if [[ -s $daemon_log ]]; then if [[ -s $daemon_log ]]; then
print -ru2 -- '' print -ru2 -- ''
print -ru2 -- " The content of ${(q-)daemon_log} (gitstatus daemon log):" print -Pru2 -- " Daemon log (%U${daemon_log//\%/%%}%u):"
print -Pru2 -- '%F{yellow}' print -Pru2 -- '%F{yellow}'
>&2 awk '{print " " $0}' <$daemon_log print -lru2 -- "${(@)${(@f)$(<$daemon_log)}/#/ }"
print -Pnru2 -- '%f' print -Pnru2 -- '%f'
fi fi
if [[ $GITSTATUS_LOG_LEVEL == DEBUG ]]; then if [[ $GITSTATUS_LOG_LEVEL == DEBUG ]]; then
print -ru2 -- '' print -ru2 -- ''
print -ru2 -- ' Your system information:' print -ru2 -- ' System information:'
print -Pru2 -- '%F{yellow}' print -Pru2 -- '%F{yellow}'
print -ru2 -- " zsh: $ZSH_VERSION" print -ru2 -- " zsh: $ZSH_VERSION"
print -ru2 -- " uname -a: $(uname -a)" print -ru2 -- " uname -a: $(uname -a)"
print -Pru2 -- '%f' print -Pru2 -- '%f'
print -ru2 -- ' If you need help, open an issue and attach this whole error message to it:' print -ru2 -- ' If you need help, open an issue and attach this whole error message to it:'
print -ru2 -- '' print -ru2 -- ''
print -Pru2 -- ' %F{green}https://github.com/romkatv/gitstatus/issues/new%f' print -Pru2 -- ' %Uhttps://github.com/romkatv/gitstatus/issues/new%u'
else else
print -ru2 -- '' print -ru2 -- ''
print -ru2 -- ' Run the following command to retry with extra diagnostics:' local home=~
print -Pru2 -- '%F{green}' local zshrc=${${${(q)${ZDOTDIR:-~}}/#${(q)home}/'~'}//\%/%%}/.zshrc
local env="GITSTATUS_LOG_LEVEL=DEBUG" print -Pru2 -- " Add the following parameter to %U$zshrc%u for extra diagnostics on error:"
if [[ -n $GITSTATUS_NUM_THREADS ]]; then
env+=" GITSTATUS_NUM_THREADS=${(q)GITSTATUS_NUM_THREADS}"
fi
if [[ -n $GITSTATUS_DAEMON ]]; then
env+=" GITSTATUS_DAEMON=${(q)GITSTATUS_DAEMON}"
fi
if [[ -n $GITSTATUS_AUTO_INSTALL ]]; then
env+=" GITSTATUS_AUTO_INSTALL=${(q)GITSTATUS_AUTO_INSTALL}"
fi
if [[ -n $GITSTATUS_CACHE_DIR ]]; then
env+=" GITSTATUS_CACHE_DIR=${(q)GITSTATUS_CACHE_DIR}"
fi
print -nru2 -- " ${env} gitstatus_start ${(@q-)*}"
print -Pru2 -- '%f'
print -ru2 -- '' print -ru2 -- ''
local zshrc=${(D)ZDOTDIR:-~}/.zshrc print -Pru2 -- ' %BGITSTATUS_LOG_LEVEL=DEBUG%b'
print -ru2 -- " If this command produces no output, add the following parameter to $zshrc:"
print -ru2 -- '' print -ru2 -- ''
print -Pru2 -- '%F{green} GITSTATUS_LOG_LEVEL=DEBUG%f' print -ru2 -- ' Restart Zsh to retry gitstatus initialization:'
print -ru2 -- '' print -ru2 -- ''
print -ru2 -- ' With this parameter gitstatus will print additional information on error.' print -Pru2 -- ' %F{green}%Uexec%u zsh%f'
fi fi
} }
} }

20
mbuild
View File

@ -151,7 +151,7 @@ done
shift $((OPTIND - 1)) shift $((OPTIND - 1))
(( $# )) || set -- ${(k)assets} (( $# )) || set -- ${(ko)assets}
set -- ${(u)@} set -- ${(u)@}
local platform local platform
@ -200,15 +200,22 @@ function build-windows() {
local tmp env bin intro flags=(-w) local tmp env bin intro flags=(-w)
case $2 in case $2 in
msys_nt-10.0-i686) bin='msys32/usr/bin';|
msys_nt-10.0-x86_64) bin='msys64/usr/bin';|
cygwin_nt-10.0-i686) bin='cygwin32/bin' ;| cygwin_nt-10.0-i686) bin='cygwin32/bin' ;|
cygwin_nt-10.0-x86_64) bin='cygwin64/bin' ;| cygwin_nt-10.0-x86_64) bin='cygwin64/bin' ;|
msys_nt-10.0-i686) bin='msys32/usr/bin';|
msys_nt-10.0-x86_64) bin='msys64/usr/bin';|
cygwin_nt-10.0-*)
tmp='/cygdrive/c/tmp'
;|
msys_nt-10.0-*) msys_nt-10.0-*)
flags+=(-s) flags+=(-s)
tmp='/c/tmp' tmp='/c/tmp'
env='MSYSTEM=MSYS' env='MSYSTEM=MSYS'
intro='pacman -Syu --noconfirm; pacman -S --needed --noconfirm git; '
intro+='PATH="$PATH:/usr/bin/site_perl:/usr/bin/vendor_perl:/usr/bin/core_perl"'
while true; do while true; do
# TODO: run autorebase only when getting an error that can be fixed by autorebasing.
break
local out local out
out="$(ssh $1 cmd.exe "$c/${bin%%/*}/autorebase.bat" 2>&1)" out="$(ssh $1 cmd.exe "$c/${bin%%/*}/autorebase.bat" 2>&1)"
[[ $out == *"The following DLLs couldn't be rebased"* ]] || break [[ $out == *"The following DLLs couldn't be rebased"* ]] || break
@ -243,12 +250,7 @@ function build-windows() {
} }
done done
} "$@" } "$@"
intro='pacman -Syu --noconfirm; pacman -S --needed --noconfirm git; ' ;|
intro+='PATH="$PATH:/usr/bin/site_perl:/usr/bin/vendor_perl:/usr/bin/core_perl"'
;;
cygwin_nt-10.0-*)
tmp='/cygdrive/c/tmp'
;;
esac esac
ssh $1 $c/$bin/env.exe $env c:/$bin/bash.exe -l <<<" ssh $1 $c/$bin/env.exe $env c:/$bin/bash.exe -l <<<"