6

如果带有 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)替换未绑定变量的行,则该退出值会按照我的意愿传播。

4

2 回答 2

7

shell 以最后执行的命令的结果退出。在您的陷阱情况下,那是echo,通常会成功返回。

传播你的价值,只需exit用它。

#!/bin/bash

set -eu

die() {
  echo "Dying!!"
  exit "$1"
}

trap 'die $?' EXIT

echo yeah
echo $unbound
echo boo

另请注意,这set -e被认为是有害的——它使您认为如果命令失败,脚本将退出,但并非总是如此。

于 2014-07-31T16:35:03.503 回答
3

此行为与不同的 Bash 版本有关。原始脚本在 Bash 4.2 上按预期工作,但在 3.2 上没有。将容易出错的代码放在单独的脚本文件中并在子 shell 中运行它可以解决早期 Bash 版本中的问题:

#!/bin/bash

$BASH sub.sh
RETVAL=$?

if [[ "$RETVAL" != "0" ]]; then
  echo "Dying!! Exit code: $RETVAL"
fi

子目录:

set -eu

echo yeah
echo $UNBOUND_VARIABLE
echo boo
于 2014-08-07T08:48:59.747 回答