由于某些原因,当quickfix文件类型插件的内容发生变化时,它的包含保护不起作用。
在~/.vim/ftplugin/qf.vim上插入以下内容
if exists("b:did_ftplugin")
finish
endif
call input("qf.vim!")在发出:copen之后,可以看到来自input()的消息。
但是,尽管从$VIMRUMTIME上的默认文件类型插件设置了包含保护,如:echo b:did_ftplugin和:1verbose setlocal stl所示,发出:copen、:cold、:cnew或:helpg helpg也会导致显示消息。
这不需要额外的插件,也不需要filetype plugin indent on和set nocompatible之外的任何设置。
我的第一个猜测是,任何刷新快速修复窗口的命令都会关闭现有的缓冲区,并打开一个新的缓冲区。但是,在上面的endif后面包含let b:did_ftplugin = 1可以避免重新加载文件类型插件,因为在第一个:copen之后不会显示任何消息(但是会完全跳过默认的文件类型插件,因为不再设置'stl' )。
在默认文件类型插件上设置的b:did_ftplugin和在我的主目录中设置的有什么不同?
发布于 2014-01-30 19:41:21
quickfix窗口主要是一个视图( window ),尽管(出于实现原因)它是由Vim buffer支持的。当我:cclose一个quickfix窗口,然后再次:copen它时,:ls!命令显示一个递增的缓冲区编号。我想这就解释了你所看到的行为。
https://stackoverflow.com/questions/21455281
复制相似问题