您好,登錄后才能下訂單哦!
小編給大家分享一下linux中shellcheck怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
shellcheck
shellcheck就是這樣的一個(gè)工具。它可以在多種場(chǎng)景下使用,包括在線(xiàn),命令行檢查,編輯器配置,下面逐一介紹。
在線(xiàn)使用
顧名思義,它提供了一個(gè)在線(xiàn)的檢查地址,https://www.shellcheck.net/,進(jìn)入網(wǎng)址即可使用。
例如,你輸入你的腳本內(nèi)容:
#!/bin/sh for n in {1..$RANDOM} do str="" if (( n % 3 == 0 )) then str="fizz" fi if [ $[n%5] == 0 ] then str="$strbuzz" fi if [[ ! $str ]] then str="$n" fi echo "$str" done
shell
它會(huì)給出錯(cuò)誤提示或者建議:
Line 2: for n in {1..$RANDOM} ^-- SC2039: In POSIX sh, brace expansion is undefined. ^-- SC2039: In POSIX sh, RANDOM is undefined. Line 5: if (( n % 3 == 0 )) ^-- SC2039: In POSIX sh, standalone ((..)) is undefined. Line 9: if [ $[n%5] == 0 ] ^-- SC2039: In POSIX sh, $[..] in place of $((..)) is undefined. ^-- SC2007: Use $((..)) instead of deprecated $[..] ^-- SC2039: In POSIX sh, == in place of = is undefined. Line 11: str="$strbuzz" ^-- SC2154: strbuzz is referenced but not assigned. Line 13: if [[ ! $str ]] ^-- SC2039: In POSIX sh, [[ ]] is undefined.
怎么樣,是不是很給力,每個(gè)可能的錯(cuò)誤都提示了。新手寫(xiě)shell出現(xiàn)莫名的報(bào)錯(cuò)時(shí),可以嘗試使用奧。當(dāng)然例子中很多并不是真的錯(cuò)誤,而是某種寫(xiě)法不符合POSIX標(biāo)準(zhǔn),這種情況也應(yīng)該避免。
命令行使用
命令行安裝也很簡(jiǎn)單(記得使用root權(quán)限),ubuntu下:
$ apt-get install shellcheck
centos下:
$ yum -y install epel-release
Fedora下:
$ dnf install ShellCheck
使用方法也很簡(jiǎn)單了:
$ shellcheck myscript.sh
舉個(gè)例子,下面的寫(xiě)法是新手最容易出錯(cuò)的地方之一:
//來(lái)源:公眾號(hào)【編程珠璣】 //作者:守望先生 #!/bin/bash if[ $# -eq 0 ] then echo "no para" else echo "$# para" fi exit 0
看運(yùn)行報(bào)錯(cuò):
./test.sh: line 4: if[ 0 -eq 0 ]: command not found ./test.sh: line 5: syntax error near unexpected token `then' ./test.sh: line 5: `then'
只是告訴你在then附近有語(yǔ)法問(wèn)題,到底什么問(wèn)題呢?我們用shellcheck看看:
$ shellcheck test.sh In test.sh line 4: if[ $# -eq 0 ] ^-- SC1069: You need a space before the [.
這么一看,就很清楚了,原來(lái)[前面少了空格。
編輯器中使用
當(dāng)然也可以把它安裝到你熟悉的編輯器中,雖然它們本身都有語(yǔ)法高亮的功能,但是并沒(méi)有直接的信息提示,安裝shellcheck類(lèi)工具,達(dá)到編寫(xiě)即提示的效果。
Emacs, 可以使用 Flycheck.
Sublime,可以使用 SublimeLinter.
Atom,可以使用 Linter.
vim ,可以使用ale或者syntastic
當(dāng)然了,現(xiàn)代很多IDE都有這樣檢查功能,這里只說(shuō)編輯器。
這里以syntastic為例,實(shí)際上它支持多種語(yǔ)言的語(yǔ)法檢查。
安裝過(guò)程:
1.安裝pathogen.vim
$ mkdir -p ~/.vim/autoload ~/.vim/bundle && \ curl -LSso ~/.vim/autoload/pathogen.vim https://tpo.pe/pathogen.vim
并且在vimrc文件中配置以下內(nèi)容:
execute pathogen#infect()
2.安裝 Install syntastic
cd ~/.vim/bundle && \ git clone --depth=1 https://github.com/vim-syntastic/syntastic.git
3.測(cè)試安裝情況
打開(kāi)vim,輸入以下內(nèi)容
:Helptags
如果沒(méi)有報(bào)錯(cuò),說(shuō)明安裝正常。
在vimrc中配置以下內(nèi)容:
set statusline+=%#warningmsg# set statusline+=%{SyntasticStatuslineFlag()} set statusline+=%* let g:syntastic_always_populate_loc_list = 1 let g:syntastic_auto_loc_list = 1 let g:syntastic_check_on_open = 1
常用:
:Errors 顯示錯(cuò)誤面板 :lnext 到下一個(gè)錯(cuò)誤 :lprevious 到上一個(gè)錯(cuò)誤
更多安裝詳情也可以參考https://github.com/vim-syntastic/syntastic。
以上是官網(wǎng)推薦的安裝方式,也可以在安裝了Vundle(這是一種老舊的插件管理方式,你可以嘗試vim-plug等其他插件管理工具)的前提下,通過(guò)在配置文件中加入:
Plugin 'scrooloose/syntastic'
打開(kāi)vim輸入:
:PluginInstall
即可安裝。
使用效果:
shell檢查:
C語(yǔ)言語(yǔ)法檢查:
實(shí)際上它可以支持幾乎所有常見(jiàn)編程語(yǔ)言的語(yǔ)法檢查。
不知道vimrc文件在哪里?
打開(kāi)vim,輸入:
:version
就可以看到啦:
system vimrc file: "$VIM/vimrc" user vimrc file: "$HOME/.vimrc" 2nd user vimrc file: "~/.vim/vimrc" user exrc file: "$HOME/.exrc" system gvimrc file: "$VIM/gvimrc" user gvimrc file: "$HOME/.gvimrc" 2nd user gvimrc file: "~/.vim/gvimrc" system menu file: "$VIMRUNTIME/menu.vim"
它們區(qū)別在于生效范圍不一樣,對(duì)于用戶(hù)的vimrc,自然只是對(duì)特定用戶(hù)生效。
以上是“l(fā)inux中shellcheck怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。