Ian*_*ait 1 bash eval status environment-variables subshell
我曾尝试寻找与此类似的问题来为我提供解决方案,但我找不到一个能完全回答我的确切问题的问题。
我想在 eval 调用中的子 shell 中运行命令,并获取子 shell 中调用的函数返回的状态代码。
例如,我调用这样的命令:
eval "$(some_command)"
if [ "${?}" -ne 0 ]
then
# do stuff if `some_command` returned status code not equal to zero
fi
Run Code Online (Sandbox Code Playgroud)
该some_command函数返回环境变量及其分配的列表,如下所示:
$ some_command # Execute some_command in a standard fashion without eval or subshell
some_env_variable='some_value'
another_env_variable='another value'
Run Code Online (Sandbox Code Playgroud)
目标是运行这个命令将这些环境变量添加到当前环境。唯一的方法是some_command在子 shell 中调用,并让 eval 评估结果输出。如果我在没有子 shell 的情况下执行此操作,eval 将简单地运行some_command,但不会评估其输出以将环境变量添加到当前环境。
这有效:
$ eval "some_command"
-bash: some_command: command not found
$ echo $?
127
Run Code Online (Sandbox Code Playgroud)
这有效:
$ $(some_command)
-bash: some_command: command not found
$ echo $?
127
Run Code Online (Sandbox Code Playgroud)
但这不起作用:
$ eval "$(some_command)"
-bash: some_command: command not found
$ echo $?
0
Run Code Online (Sandbox Code Playgroud)
必须有某种方法可以从 some_command 获取结果状态代码,但我无法确定如何获取。任何帮助表示赞赏!
如果您确实担心退出状态,请不要eval立即使用。
if envvars=$(some_command); then
eval "$envvars"
else
# do something else
fi
Run Code Online (Sandbox Code Playgroud)
如果您需要确切的错误代码,而不仅仅是区分 0 和非零:
envvars=$(some_command)
rv=$? # save it for later if necessary
case $rv in
0) eval "$envvars" ;;
1) ... ;;
2) ... ;;
# etc
*) printf 'Some other error %d\n' "$rv" >&2 ;;
esac
Run Code Online (Sandbox Code Playgroud)