使用简单的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中文网其他相关文章!