如果带有EXIT陷阱的Bash脚本中出现语法错误,是否可以将退出代码传播给调用者?例如,如果我有:
#! /bin/bash
set -eu
trap "echo dying!!" EXIT
echo yeah
echo $UNBOUND_VARIABLE
echo boo
然后,即使脚本没有真正成功结束,运行它也会提供退出代码0:
$ bash test.sh
yeah
test.sh: line 8: UNBOUND_VARIABLE: unbound variable
dying!!
$ echo $?
0
但是如果我注释掉退出陷阱,脚本将返回1.或者,如果我使用返回非零的命令(例如/bin/false
)替换未绑定变量的行,则该退出值将传播为I我希望如此。
答案 0 :(得分:6)
shell以最后执行的命令的结果退出。在你的陷阱案例中,那是echo
,通常会成功返回。
要宣传您的价值,只需exit
即可。
#!/bin/bash
set -eu
die() {
echo "Dying!!"
exit "$1"
}
trap 'die $?' EXIT
echo yeah
echo $unbound
echo boo
另请注意,set -e
被认为是有害的 - 它会让您认为如果命令失败,脚本将会退出,而这并不总是如此。
答案 1 :(得分:1)
此行为与不同的Bash版本有关。原始脚本在Bash 4.2上按预期工作,但在3.2上没有。将容易出错的代码放在一个单独的脚本文件中并在子shell中运行它可以解决早期Bash版本中的问题:
#!/bin/bash
$BASH sub.sh
RETVAL=$?
if [[ "$RETVAL" != "0" ]]; then
echo "Dying!! Exit code: $RETVAL"
fi
sub.sh:
set -eu
echo yeah
echo $UNBOUND_VARIABLE
echo boo