diff --git a/internal/worker.zsh b/internal/worker.zsh index a3d69f21..ead2b6b1 100644 --- a/internal/worker.zsh +++ b/internal/worker.zsh @@ -203,7 +203,7 @@ function _p9k_worker_receive() { _p9k__worker_pid=$arg sysopen -w -o cloexec -u _p9k__worker_req_fd $_p9k__worker_file_prefix.fifo || return { - print -r -- " + local init=" zmodload zsh/datetime zmodload zsh/mathfunc zmodload zsh/parameter @@ -218,7 +218,8 @@ function _p9k_worker_receive() { function _p9k_worker_main() { $functions[_p9k_worker_main] } function _p9k_worker_reply() { $functions[_p9k_worker_reply_remote] } function _p9k_worker_send_params() { $functions[_p9k_worker_send_params_remote] } - _p9k_worker_main"$'\x1e' || return + _p9k_worker_main" + print -r -- ${init//$'\n'/$'\x1e'} || return if (( $#_p9k__worker_params )); then print -rn -- $'\x1f' || return typeset -pm -- ${(j.|.)${(b)_p9k__worker_params}} || return @@ -236,6 +237,7 @@ function _p9k_worker_receive() { done _p9k__worker_request_queue=() } >&$_p9k__worker_req_fd + echo shit sent >>/tmp/log ;; *) return 1 @@ -281,7 +283,7 @@ function _p9k_worker_start() { echo -n "s$sysparams[pid]\x1e" && exec 0<$fifo || exit } always { rm -f -- $fifo } - IFS= read -rd $'"'\\x1e'"' && eval $REPLY + IFS= read -r && eval ${REPLY//$'"'\x1e'"'/$'"'\n'"'} } &! exec true' sysopen -r -o cloexec -u _p9k__worker_resp_fd <(