我一直在寻找一种在shell脚本出错时打印行号的方法。
我遇到了' -x'选项,在运行shell脚本时打印行,但这不是我想要的。也许我可以在每个退出代码之前做$ LINENO?有更清洁的方法吗?
我只想要行号,这样我就可以打开shell脚本并直接转到解释器实现错误的地方。
答案 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