zsh:在函数中设置选择并使其粘住
Posted
技术标签:
【中文标题】zsh:在函数中设置选择并使其粘住【英文标题】:zsh: setopt in function and make it stick 【发布时间】:2014-11-26 00:28:24 【问题描述】:我正在尝试将分析添加到函数内部的 .zshrc:
# via http://***.com/a/4351664/329700
profile_startup()
PS4='+$(/usr/local/bin/gdate "+%s:%N") %N:%i> '
echo "profiling away"
typeset -g PS4='%D%. %N:%i> '
exec 3>&2 2>$HOME/tmp/startlog.$$
setopt xtrace prompt_subst
profile_startup
当我这样运行它时,/tmp/startlog 是空的(没有记录任何内容)。但是,当我在函数之外运行它时,在裸 zshrc 中:
PS4='+$(/usr/local/bin/gdate "+%s:%N") %N:%i> '
echo "profiling away"
typeset -g PS4='%D%. %N:%i> '
exec 3>&2 2>$HOME/tmp/startlog.$$
setopt xtrace prompt_subst
这会在日志中添加大量分析数据。
为什么在函数内部运行命令时没有记录任何日志数据? setopt 命令不粘吗?我尝试将setopt no_local_options
添加到profile_startup
命令的末尾,然后只将一个日志命令写入文件 - 添加setopt no_local_options
的行。
【问题讨论】:
【参考方案1】:根据zsh documentation:
LOCAL_OPTIONS <K>
如果在从 shell 函数返回时设置了此选项,则在进入函数时生效的大多数选项(包括此选项)将被恢复;未恢复的选项是
PRIVILEGED
和RESTRICTED
。 否则,只有这个选项,以及LOCAL_LOOPS
、XTRACE
和PRINT_EXIT_VALUE
选项被恢复。
有一个clever way to work around this:
profile_startup()
# do whatever ...
trap 'setopt xtrace' EXIT
【讨论】:
以上是关于zsh:在函数中设置选择并使其粘住的主要内容,如果未能解决你的问题,请参考以下文章
javascript - 检查函数执行计数并使其执行不超过一次
如何在 Intellij-IDEA 的 zsh shell 中设置 CHROME_EXECUTABLE