Shell脚本在出错时打印行号

use*_*441 5 bash shell scripting

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

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

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

Cha*_*ffy 9

运用

PS4=':$LINENO+'
Run Code Online (Sandbox Code Playgroud)

将添加行号到输出set -x.


如果你想要打印的错误,有运行到错误在最近口译一定的风险.但是,您可以尝试以下操作(首先在上一个答案中给出):

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
Run Code Online (Sandbox Code Playgroud)

同样,这不适用于最近的一些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
Run Code Online (Sandbox Code Playgroud)