Shell脚本在出错时打印行号

时间:2015-03-16 16:06:17

标签: bash shell scripting

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

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

我只想要行号,这样我就可以打开shell脚本并直接转到解释器实现错误的地方。

1 个答案:

答案 0 :(得分:8)

使用

PS4=':$LINENO+'

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


如果想要在错误上打印出来,那么在最近的解释器中遇到错误会有一些风险。但是,您可以尝试以下操作(首先在this previous answer中提供):

error() {
  local parent_lineno="$1"
  local message="$2"
  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


另一种方法(在最近的shell上工作;下面使用一些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