From 23e8921b8d88a1699e5b1920f4da8efa127cd5d0 Mon Sep 17 00:00:00 2001 From: romkatv Date: Sun, 19 Jan 2020 13:14:58 +0100 Subject: [PATCH] further simplify worker bootstrap --- internal/worker.zsh | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/internal/worker.zsh b/internal/worker.zsh index 96d731ef..ac9773da 100644 --- a/internal/worker.zsh +++ b/internal/worker.zsh @@ -261,18 +261,19 @@ function _p9k_worker_start() { local zsh=${${:-/proc/self/exe}:A} [[ -x $zsh ]] || zsh=zsh local bootstrap=( - '"emulate" "-L" "zsh" "-o" "no_aliases"' - '{ mkfifo '${(q)fifo}' && exec >&4 && echo -n "s$$\x1e" && exec 0<'${(q)fifo}' || exit } always { rm -f '${(q)fifo}' }' + '"emulate" "zsh" "-o" "no_aliases"' + '{ zmodload zsh/system && mkfifo '${(q)fifo}' && exec >&4 && echo -n "s$sysparams[pid]\x1e" && exec 0<'${(q)fifo}' || exit } always { rm -f '${(q)fifo}' }' 'IFS= read -rd $'\''\x1e'\'' && eval $REPLY') local child='"eval" "$_p9k_worker_bootstrap" &!' local parent=( '"emulate" "-L" "zsh" "-o" "no_aliases" "-o" "no_bgnice"' - ${(qqq)zsh}' -'${trace}'dfc '${(qqq)child} + 'echo PARENT $$ >>/tmp/log' + '{ eval $_p9k_worker_bootstrap } &!' + 'command true' ) sysopen -r -o cloexec -u _p9k__worker_resp_fd <( _p9k_worker_bootstrap=${(j:; :)bootstrap} \ - &1 &>>$log_file $zsh -${trace}dfmc \ - ${(j:; :)parent}) || return + $zsh -${trace}dfmc ${(j:; :)parent} &1 &>>$log_file) || return zle -F $_p9k__worker_resp_fd _p9k_worker_receive _p9k__worker_shell_pid=$sysparams[pid] add-zsh-hook zshexit _p9k_worker_cleanup