写过shell脚本的人都知道,即便出现一些简单的语法错误,运行的时候也可能没有办法发现。有些看似运行正确的脚本,实际上可能在某些分支,某些场景下仍然出现错误,而有的写法可能运行正常,但是却不符合POSIX标准,不具备可移植性。
诚然,shell脚本是解释运行,没有办法向C/C++那样严格检查,但是我们仍然可以借助一些工具帮助我们提前发现一些错误。
shellcheck
shellcheck就是这样的一个工具。它可以在多种场景下使用,包括在线,命令行检查,编辑器配置,下面逐一介绍。
在线使用
顾名思义,它提供了一个在线的检查地址,https://www.shellcheck.net/,进入网址即可使用。
例如,你输入你的脚本内容:
#!/bin/shfornin{1..$RANDOM}dostr= if((n%3==0))thenstr= fizz fiif[$[n%5]==0]thenstr= $strbuzz fiif[[!$str]]thenstr= $n fiecho $str done
shell
它会给出错误提示或者建议:
Line2:fornin{1..$RANDOM}^--SC2039:InPOSIXsh,braceexpansionisundefined.^--SC2039:InPOSIXsh,RANDOMisundefined.Line5:if((n%3==0))^--SC2039:InPOSIXsh,standalone((..))isundefined.Line9:if[$[n%5]==0]^--SC2039:InPOSIXsh,$[..]inplaceof$((..))isundefined.^--SC2007:Use$((..))insteadofdeprecated$[..]^--SC2039:InPOSIXsh,==inplaceof=isundefined.Line11:str= $strbuzz ^--SC2154:strbuzzisreferencedbutnotassigned.Line13:if[[!$str]]^--SC2039:InPOSIXsh,[[]]isundefined.
怎么样,是不是很给力,每个可能的错误都提示了。新手写shell出现莫名的报错时,可以尝试使用奥。当然例子中很多并不是真的错误,而是某种写法不符合POSIX标准,这种情况也应该避免。
命令行使用
命令行安装也很简单(记得使用root权限),ubuntu下:
$apt-getinstallshellcheck
centos下:
$yum-yinstallepel-release
Fedora下:
$dnfinstallShellCheck
使用方法也很简单了:
$shellcheckmyscript.sh
举个例子,下面的写法是新手最容易出错的地方之一:
//来源:公众号【编程珠玑】//作者:守望先生#!/bin/bashif[$#-eq0]thenecho nopara elseecho $#para fiexit0
看运行报错:
./test.sh:line4:if[0-eq0]:commandnotfound./test.sh:line5:syntaxerrornearunexpectedtoken`then\'./test.sh:line5:`then\'
只是告诉你在then附近有语法问题,到底什么问题呢?我们用shellcheck看看:
$shellchecktest.shIntest.shline4:if[$#-eq0]^--SC1069:Youneedaspacebeforethe[.
这么一看,就很清楚了,原来[前面少了空格。
编辑器中使用
当然也可以把它安装到你熟悉的编辑器中,虽然它们本身都有语法高亮的功能,但是并没有直接的信息提示,安装shellcheck类工具,达到编写即提示的效果。
Emacs, 可以使用 Flycheck. Sublime,可以使用 SublimeLinter. Atom,可以使用 Linter. vim ,可以使用ale或者syntastic当然了,现代很多IDE都有这样检查功能,这里只说编辑器。
这里以syntastic为例,实际上它支持多种语言的语法检查。
安装过程:
1.安装pathogen.vim
$mkdir-p~/.vim/autoload~/.vim/bundle \\curl-LSso~/.vim/autoload/pathogen.vimhttps://tpo.pe/pathogen.vim
并且在vimrc文件中配置以下内容:
executepathogen#infect()
2.安装 Install syntastic
cd~/.vim/bundle \\gitclone--depth=1https://github.com/vim-syntastic/syntastic.git
3.测试安装情况
打开vim,输入以下内容
:Helptags
如果没有报错,说明安装正常。
在vimrc中配置以下内容:
setstatusline+=%#warningmsg#setstatusline+=%{SyntasticStatuslineFlag()}setstatusline+=%*letg:syntastic_always_populate_loc_list=1letg:syntastic_auto_loc_list=1letg:syntastic_check_on_open=1
常用:
:Errors显示错误面板:lnext到下一个错误:lprevious到上一个错误
更多安装详情也可以参考https://github.com/vim-syntastic/syntastic。
以上是官网推荐的安装方式,也可以在安装了Vundle(这是一种老旧的插件管理方式,你可以尝试vim-plug等其他插件管理工具)的前提下,通过在配置文件中加入:
Plugin\'scrooloose/syntastic\'
打开vim输入:
:PluginInstall
即可安装。
使用效果:
shell检查:
C语言语法检查:
实际上它可以支持几乎所有常见编程语言的语法检查。
不知道vimrc文件在哪里?
打开vim,输入:
:version
就可以看到啦:
systemvimrcfile: $VIM/vimrc uservimrcfile: $HOME/.vimrc 2nduservimrcfile: ~/.vim/vimrc userexrcfile: $HOME/.exrc systemgvimrcfile: $VIM/gvimrc usergvimrcfile: $HOME/.gvimrc 2ndusergvimrcfile: ~/.vim/gvimrc systemmenufile: $VIMRUNTIME/menu.vim
它们区别在于生效范围不一样,对于用户的vimrc,自然只是对特定用户生效。
总结
工欲善其事必先利其器,有好的工具,自然就该用起来。欢迎分享更多的方法或工具。
【编辑推荐】
本文链接: http://syntastic.immuno-online.com/view-771097.html