我又开始编写 shell 脚本了,我发现自己经常不得不编写调试回显来跟踪脚本在做什么。我用来做这件事的简单方法是写这样的东西:
#!/bin/bash
myVar = 'Erractic Nonesense'
echo "myVar: $myVar"
==>myVar: Erractic Nonesense
这很好用,而且相当简单,但是必须为我希望跟踪的每个变量编写这个很累,作为一个认为用更少的代码做更多的事情很棒的人,我给自己写了一个函数:
#!/bin/bash
dbg() # $msg
{
echo "$@: ${!@}"
}
myVar = 'Erractic Nonesense'
dbg myVar
==>myVar: Erractic Nonesense
这对常规变量非常有效,但对于脚本参数($1、$2 等)则不起作用。为什么?
==>$ ./myScript 123
#!/bin/bash
...
dbg 1 # This is the bugger in question.
==>1: 1
还有,如何规避这种情况?
编辑
感谢 Barmar,我现在明白了它为什么会这样,但是第二个问题仍然存在。
编辑 2
使用 koodawg 的想法,这就是结果。有用。更新,见编辑 4
编辑 3
我认为EDIT 2的混合set +-x
将是一个可行的解决方案。
编辑 4
更新了基于论点的逻辑,因为前一个并不总是有效。添加了精美的标签。
RX_INTEGER='^[0-9]+$'
DBG_SCRIPT_ARGS=( "$0" "$@" )
DBG_PADDING=" " # tabs of 8 spaces
dbg() # $msg | OUT$args OUT$res
{
args=$@
[[ $args =~ $RX_INTEGER ]] && res="${DBG_SCRIPT_ARGS[args]}" || res="${!@}"
printf "%s%s\`%s\`\n" "$args:" "${DBG_PADDING:$(((${#args}-1)%${#DBG_PADDING}))}"
}