實用!開發者的 Vim 外掛(二)
導讀 | 毫無疑問,Vim 是一個開箱即用並能夠勝任程式設計任務的編輯器,但實際上是該編輯器中的外掛幫你實現這些方便的功能。在開發者的實用 Vim 外掛(一),我們已經討論兩個程式設計相關的 Vim 外掛——標籤側邊欄(Tagbar)和定界符自動補齊(delimitMate)。作為相同系列,我們在本文討論另一個非常有用、專門為軟體開發正定製的外掛——語法高亮外掛。 |
請注意:本教程中列舉的所有例示、 和說明都是在 Ubuntu 16.04 環境下進行測試的,並且,我們使用的 Vim 版本是 7.4。
假如你的軟體開發工作涉及到 C/C++ 語言,毫無疑問的說,遇到編譯錯誤也是你每天工作中的一部分。很多時候,編譯錯誤是由原始碼之中的語法不正確造成的,因為開發者在瀏覽原始碼的時候很少能夠一眼就看出所有這些錯誤。
那麼 Vim 中是否存在一種外掛可以讓你不經編譯原始碼就可以顯示出語法錯誤呢?當然是有這樣一種外掛的,其名字就是 Syntastic。
“Syntastic 是 Vim 用來檢驗語法的外掛,透過外部語法校驗器校驗檔案並將錯誤呈現給使用者。該過程可以在需要時進行,或者在檔案儲存的時候自動進行。”該外掛官方文件如是說。“如果檢測到語法錯誤就會提示使用者,因為不用編譯程式碼或者執行 就可以知道語法錯誤,使用者也就樂享與此了。”
安裝過程和第一部分提到的方法類似,你只需要執行下列 即可:
cd ~/.vim/bundle/ git clone
一旦你成功安裝這個外掛(即上述命令執行成功),你就不需要進行任何配置了——當 Vim 啟動時會自動載入這個外掛。
現在,開啟一個原始碼檔案並用":w" Vim 命令儲存即可使用這個外掛了。等待片刻之後,如果在原始碼中有語法錯誤的好,就會高亮顯示出來。比如,看看一下截圖你就會明白該外掛是如何高亮顯示語法錯誤的:
在每行之前的 ">>" 表示該行中有語法錯誤。瞭解確切的錯誤或者想知道是什麼東西錯了,將游標移到該行——錯誤描述就會展示在 Vim 視窗的最底下。
這樣,不用進行編譯你就能夠修復大多數語法相關的錯誤。
再往下,如果你執行 ":Errors" 命令,就會展現當前原始檔中所有語法相關錯誤的描述。比如,我執行
:Errors
命令就是下圖的效果:
請記住,":Errors" 展現的語法錯誤是不會自動更新的,這意味著在你修復錯誤之後,你需要重新執行 ":Errors" 命令,編輯器底部的錯誤描述才會消除。
值得一提的是,還有許多配置選項能夠使得 Syntastic 外掛使用起來更加友好。比如,你可以在你的 ".vimrc" 中新增下列內容,然後 ":Errors" 就可以在修復錯誤之後自動更新它的底部描述。
let g:syntastic_always_populate_loc_list = 1
新增以下內容,以確保在你開啟檔案時 Syntastic 外掛自動高亮顯示錯誤。
let g:syntastic_check_on_open = 1
類似的,你也可以在儲存或開啟檔案時讓游標跳轉到檢測到的第一個問題處,將下列行放到你的 ".vimrc" 檔案之中:
let g:syntastic_auto_jump = 1
這個值也可以指定為其它兩個值: 2 和 3,其官方文件的解釋如下:
“如果設定為 2 的話,游標就會跳到檢測到的第一個問題,當然,只有這個問題是一個錯誤的時候才跳轉;設定為 3 的話,如果存在錯誤,則會跳到第一個錯誤。所有檢測到的問題都會有警告,但游標不會跳轉。”
以下資訊可能對你有幫助:
“使用 ":SyntasticCheck" 來手動檢測錯誤。使用 ":Errors" 開啟錯誤位置列表並使用 ":lclose" 來關閉。使用 ":SyntasticReset" 可以清除掉錯誤列表,使用 ":SyntasticToggleMode" 來切換啟用(在寫到 buffer 時檢測)和被動(即手動檢測)檢測錯誤。”
注意:Syntastic並不侷限於C/C++所寫的程式碼,它同時也支援很多的程式語言——瞭解更多相關資訊(")。
毫無疑問的,Syntastic 是一個非常有用的 Vim 外掛,因為在出現語法相關錯誤時候,它至少能夠讓免去頻繁編譯的麻煩,而且不用說,同時也節約了你不少的時間。
正如你所看到的一樣,配置好幾個主要選項之後,Syntastic 變得非常好用了。為了幫助你瞭解這些設定,官方文件中包含了一份“推薦設定”——跟著文件進行設定即可。加入你遇到一些錯誤、有些疑問或者問題,你也可以查詢一下 FAQ。
原文來自: https://www.linuxprobe.com/vim-plug-in-developers02.html
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69955379/viewspace-2933051/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 實用!開發者的 Vim 外掛(一)
- 5 個好用的開發者 Vim 外掛
- 關於vim的實用外掛
- Grafana的Datasource外掛開發實踐二Grafana
- Vim 外掛管理
- 用ts開發hbuilderx的外掛?UI
- vim外掛之Taglist
- vim實戰:外掛安裝(Vundle,NerdTree)
- ThinkSDK SNS通用開發者外掛
- 開發Koa 必須用的外掛
- [20220316]完善vim gdb.vim外掛.txt
- 用Python分析WordPress官網所有外掛的開發者資訊Python
- Electron 外掛開發實踐
- 如何安裝 Vim 外掛
- VS Code外掛開發介紹(二)
- [20190909]完善vim的bccacl外掛.txt
- Android開發實用必備的幾款外掛,提高你的開發速度Android
- 【IDEA】(3)---非常實用提高開發效率和水平的外掛Idea
- [20200424]vim visSum.vim合計外掛.txt
- Grafana的Datasource外掛開發實踐一Grafana
- VSCode外掛開發全攻略(二)HelloWordVSCode
- aspnetcore外掛開發dll熱載入 二NetCore
- 手把手教你開發jquery外掛(二)jQuery
- PyCharm外掛開發實踐-PyGetterAndSetterPyCharm
- AppDomain實現【外掛式】開發APPAI
- vim外掛 NERDTree安裝使用
- python vim外掛是什麼Python
- Vim-plug:極簡 Vim 外掛管理器
- vim外掛管理器,我選vim-pluginPlugin
- [Jenkins 外掛開發] Jenkins 外掛二次開發 - 設計一個程式碼 diff 的小工具Jenkins
- 從頭開發一個Flutter外掛(二)高德地圖定位外掛Flutter地圖
- AndroidStudio外掛GsonFormat解析及二次開發AndroidORM
- IDEA Web渲染外掛開發(二)— 自定義JsDialogIdeaWebJS
- 30 個極大提高開發效率超級實用的 VSCode 外掛VSCode
- [20190913]完善vim的bccacl外掛2.txt
- [20191031]完善vim的bccalc外掛7.txt
- [20191101]完善vim的bccalc外掛8.txt
- 10種JavaScript開發者必備的VS Code外掛JavaScript