Karena saya sering melakukan ini, saya membuat skrip (yang tidak bisa diperbaiki).
Anda atau orang lain mungkin menganggapnya berguna.
Penjelasan singkat:
Pada dasarnya mencari daftar buffer dan menunjukkan hasil di jendela perbaikan cepat.
Dua perintah dasar ditambahkan.
Search <pattern>
: Cari semua buffer untuk <pattern>
.
Search1 <pattern>
: Cari semua buffer <pattern>
, tetapi hanya tampilkan hasil pertama untuk setiap buffer. Biasanya berguna untuk membuat daftar semua buffer di mana fungsi, variabel foo
digunakan, (atau apa pun).
Gunakan bang ( :Search! foo
) untuk menambahkan hasil.
Selain itu GSearch
dan GSearch1
ditambahkan di mana perbedaannya adalah dengan Search
skrip tambahkan regex delimiter, misalnya:
foo -> /foo/
Dimana seperti yang GSearch
diharapkan untuk dilampirkan.
The j
flag selalu ditambahkan untuk mencegah melompat.
Kode:
Ada beberapa peretasan untuk mencegah daftar kesalahan sementara pada saat yang sama menjaga kode pendek. try / catch
sedikit rumit bufdo
.
let s:not_idents = split("/!#$%&\"`´¨'¯()*+,-.:;<=>?¿@[\]^{|}µ¶·¸~±×÷®©«»¬ª°º¹²³¼½¾", '\zs')
" Create a delimited pattern. "
fun! s:Parse_pat(pat)
for c in s:not_idents
if stridx(a:pat, c) == -1
return c . a:pat . c
endif
endfor
echohl Error
echom "Could not delimit pattern '". a:pat ."'"
echohl None
return ''
endfun
fun! s:AllBufSearch(pat, bang, uno, isg)
if a:isg
let pat = a:pat
else
let pat = s:Parse_pat(a:pat)
endif
if pat == ''
return
endif
cclose
let [_buf, _view] = [bufnr("%"), winsaveview()]
let _foldenable = &foldenable
set nofoldenable
" Copy of current qflist. "
let qfc = getqflist()
" Hack to prevent error if no matches. "
call setqflist([{}])
silent execute "bufdo vimgrepadd! " . pat . "j %"
" Restore "
exec "buffer " . _buf
let &foldenable = _foldenable
call winrestview(_view)
" Fix "
let qf = getqflist()
call remove(qf, 0)
" Only one listing per buffer. "
if a:uno
let bn = {}
let i = 0
for m in qf
if has_key(bn, m["bufnr"])
call remove(qf, i)
else
let bn[m["bufnr"]] = 1
call remove(qf[i], "valid")
let i += 1
endif
endfor
endif
if a:bang == "!"
let qf = qfc + qf
endif
" If any matches, copen. "
if len(qf)
call setqflist(qf)
copen
endif
endfun
command! -nargs=1 -bang Search call s:AllBufSearch(<q-args>, "<bang>", 0, 0)
command! -nargs=1 -bang Search1 call s:AllBufSearch(<q-args>, "<bang>", 1, 0)
command! -nargs=1 -bang GSearch call s:AllBufSearch(<q-args>, "<bang>", 0, 1)
command! -nargs=1 -bang GSearch1 call s:AllBufSearch(<q-args>, "<bang>", 1, 1)