Shell 脚本出错时打印行号

Shell script print line number when it errors out

我一直在寻找一种在 shell 脚本出错时打印行号的方法。

我遇到了 '-x' 选项,它在 运行 shell 脚本时打印行,但这不是我想要的。也许我可以在每个退出代码之前执行 $LINENO?有更简洁的方法吗?

我只是想要行号,所以我可以打开 shell 脚本并直接转到解释器意识到错误的地方。

正在使用

PS4=':$LINENO+'

会将行号添加到 set -x 的输出。


如果您 想在出现错误时打印它,则 运行 在最近的解释器中存在一些错误的风险。但是,您可以尝试以下方法(首先在 this previous answer 中给出):

error() {
  local parent_lineno=""
  local message=""
  local code="${3:-1}"
  if [[ -n "$message" ]] ; then
    echo "Error on or near line ${parent_lineno}: ${message}; exiting with status ${code}"
  else
    echo "Error on or near line ${parent_lineno}; exiting with status ${code}"
  fi
  exit "${code}"
}
trap 'error ${LINENO}' ERR

同样,此 将无法在 bash 的一些最新版本中工作 ,它们并不总是在陷阱内正确设置 LINENO


另一种方法(适用于最近的shells;下面使用一些bash 4.0和4.1功能)是使用PS4 将每个命令的退出状态和行号发送到专用文件描述符,并使用 tail 仅打印在 shell 退出之前提供给该 FD 的最后一行:

exec {BASH_XTRACEFD}> >(tail -n 1) # send set -x output to tail -n 1
PS4=':At line $LINENO; prior command exit status $?+'
set -x