我目前使用此函数来包装执行命令并记录它们的执行,并返回代码,并在非零返回代码的情况下退出.
然而,这是有问题的,因为它显然是双插值,使得带有单引号或双引号的命令会破坏脚本.
你能推荐一个更好的方法吗?
这是功能:
do_cmd() { eval $* if [[ $? -eq 0 ]] then echo "Successfully ran [ $1 ]" else echo "Error: Command [ $1 ] returned $?" exit $? fi }
Douglas Leed.. 25
"$@"
来自http://www.gnu.org/software/bash/manual/bashref.html#Special-Parameters:
@
从1开始扩展到位置参数.当扩展发生在双引号内时,每个参数都会扩展为单独的单词.也就是说,"$ @"相当于"$ 1""$ 2"....如果双引号扩展发生在一个单词中,则第一个参数的扩展与原始单词的开头部分连接,并且最后一个参数的扩展与原始单词的最后一部分连接在一起.当没有位置参数时,"$ @"和$ @扩展为空(即,它们被删除).
这意味着参数中的空格被正确地重新引用.
do_cmd() { "$@" ret=$? if [[ $ret -eq 0 ]] then echo "Successfully ran [ $@ ]" else echo "Error: Command [ $@ ] returned $ret" exit $ret fi }
Johannes Sch.. 7
除了"$@"
道格拉斯所说的,我会用
return $?
而不是exit
.它会退出你的shell而不是从函数返回.如果在出现问题时你想退出shell,你可以在调用者中执行此操作:
do_cmd false i will fail executing || exit # commands in a row. exit as soon as the first fails do_cmd one && do_cmd && two && do_cmd three || exit
(这样,您可以处理故障,然后优雅地退出).
"$@"
来自http://www.gnu.org/software/bash/manual/bashref.html#Special-Parameters:
@
从1开始扩展到位置参数.当扩展发生在双引号内时,每个参数都会扩展为单独的单词.也就是说,"$ @"相当于"$ 1""$ 2"....如果双引号扩展发生在一个单词中,则第一个参数的扩展与原始单词的开头部分连接,并且最后一个参数的扩展与原始单词的最后一部分连接在一起.当没有位置参数时,"$ @"和$ @扩展为空(即,它们被删除).
这意味着参数中的空格被正确地重新引用.
do_cmd() { "$@" ret=$? if [[ $ret -eq 0 ]] then echo "Successfully ran [ $@ ]" else echo "Error: Command [ $@ ] returned $ret" exit $ret fi }
除了"$@"
道格拉斯所说的,我会用
return $?
而不是exit
.它会退出你的shell而不是从函数返回.如果在出现问题时你想退出shell,你可以在调用者中执行此操作:
do_cmd false i will fail executing || exit # commands in a row. exit as soon as the first fails do_cmd one && do_cmd && two && do_cmd three || exit
(这样,您可以处理故障,然后优雅地退出).