使用簡單的vim腳本,我們可以輕鬆編譯和運行任何C程式碼,而無需離開Vim!我們將為此使用 vim9script。
vim9script 中的函數是用 def 關鍵字定義的。由於 Vim 使用類似 algol 的語法,enddef 將表示該函數的結束。
我們將使用 var 關鍵字定義多個變量,因為 vim9script 不使用 let。
vim9script def CompileAndRun() var current_file = expand('%') var file_name = fnamemodify(current_file, ':t:r')
與每個 vim9script 一樣,我們先告訴 vim 這其實就是 vim9script!
然後我們使用 Expand() 取得目前檔案的名稱,然後使用 fnamemodifty() 和 :t:t 我們將去掉路徑和副檔名,只保留基本名稱。
如果您直接使用vim filename.extension 開啟文件,但如果文件是從相對路徑開啟的,例如vim ~/some/path,則Expand('%') 通常會傳回filename.extension /filename.extension 它也會返迴路徑,所以我們必須清理它。
我們需要另一個變數來儲存我們的編譯指令,一個簡單的 gcc 編譯指令應該適合初學者:
var compile_cmd = 'gcc ' .. current_file .. ' -o ' .. file_name
.. 是我們連接字串的方式,類似於 php 和其他一些語言。您可能還注意到,我們正在使用提取的檔案名稱作為輸出二進位檔案。
之後我們可以簡單地編譯並執行輸出二進位。
var compile_result = systemlist(compile_cmd) execute 'terminal ./' .. file_name
那麼在一起:
def CompileAndRun() var current_file = expand('%') var file_name = fnamemodify(current_file, ':t:r') var compile_cmd = 'gcc ' .. current_file .. ' -o ' .. file_name var compile_result = systemlist(compile_cmd) execute 'terminal ./' .. file_name enddef defcompile
defcompile 指令最終正如其所言,編譯我們的函式。
由於 vim9script 函數的作用域與舊版 vimscript 不同,我們需要定義一個指令來存取它們。
command! CompileAndRun call CompileAndRun()
現在我們可以運行:CompileAndRun。
好吧,那沒問題,但是如果出現錯誤怎麼辦?警告?我們需要那些!所以讓我們把它做得更好。
讓我們新增一個檢查 v:shell_error 的條件,請參考 :h v:shell_error。
if v:shell_error != 0 || !empty(compile_result) botright new +setlocal\ buftype=nofile\ noswapfile\ bufhidden=wipe call setline(1, compile_result) return endif
這裡有一個總結,botright new 建立一個水平分割,setlocal 選項確保它是一個臨時緩衝區,systemlist() 在正確處理換行符的同時執行二進位文件,setline() 將結果放在分割緩衝區的第一行。
我們也將 -Wall 加入編譯指令中,並在簡單的測試 C 程式碼中建立一個未使用的變數。
var compile_cmd = 'gcc -Wall ' .. current_file .. ' -o ' .. file_name
還不錯吧?我們還可以做得更好!
使用 systemlist() 的另一個好處是它已經為我們捕獲了 2>&1 又名 stdout 和 stderr,因此我們不需要執行重定向。
我們可以在警告和錯誤中加入語法高亮嗎?是的!只需在呼叫 setline() 之前新增 set filetype=c 即可。
我們可以自動關閉此分割嗎?是的!但它需要更多的程式碼。
我們將為我們的分割緩衝區命名,然後使用 augroup 在離開時自動關閉它。
vim9script def CompileAndRun() var current_file = expand('%') var file_name = fnamemodify(current_file, ':t:r')
這確保了當我們從名為 CompileErrors 的緩衝區更改焦點時,該緩衝區將被刪除,因此分割將被關閉。
但是,有時我們可能希望在工作時保持分割打開,因此我們可以建立一個布林值在運行時將其設為 1 或 0。
var compile_cmd = 'gcc ' .. current_file .. ' -o ' .. file_name
我們將修改 augroup 並將其格式化:
var compile_result = systemlist(compile_cmd) execute 'terminal ./' .. file_name
我們也將對運行命令套用相同的檢查和細節。因此,我們可以執行以下操作,而不是簡單地運行二進位檔案:
def CompileAndRun() var current_file = expand('%') var file_name = fnamemodify(current_file, ':t:r') var compile_cmd = 'gcc ' .. current_file .. ' -o ' .. file_name var compile_result = systemlist(compile_cmd) execute 'terminal ./' .. file_name enddef defcompile
您可能已經注意到,這次我們也在決定分割的大小。
讓我們加入最後一點,也就是在執行時間定義編譯標誌的能力。為此,我們必須添加一個條件來檢查 g:custom_compile_flag 並首先將其設為空,因為 vim9script 對空變數很挑剔。
command! CompileAndRun call CompileAndRun()
當然,我們也必須修改compile_cmd:
if v:shell_error != 0 || !empty(compile_result) botright new +setlocal\ buftype=nofile\ noswapfile\ bufhidden=wipe call setline(1, compile_result) return endif
現在我們可以在運行時更改編譯標誌,只是不要忘記在末尾添加空格!
讓我們來測試一下:
如您所見,我們可以在運行時更改編譯標誌,不會出現任何問題!
整個腳本如下:
var compile_cmd = 'gcc -Wall ' .. current_file .. ' -o ' .. file_name
我們還添加了 F8 鍵綁定以更輕鬆地存取我們的命令。
Vim 已經擁有編譯器和 make 命令,您應該將它們添加到您的武器庫中。本文只是嘗試教一些 vim9 腳本以及一些你可以用它輕鬆實現的事情。
我希望您喜歡這篇文章,如果您喜歡,請發表評論或做出反應。
以上是如何寫 vimript 或如何從 Vim 編譯和執行 C 程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!