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
我一直在寻找一种在 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