coc-lists
coc-lists copied to clipboard
Common lists for coc.nvim
coc-lists
Some basic list sources for coc.nvim
Including:
- [x]
bufferscurrent buffer list. - [x]
changeschanges list. - [x]
cmdhistoryhistory of commands. - [x]
colorscolors schemes. - [x]
filessearch files from current cwd. - [x]
filetypesfile types. - [x]
grepgrep text from current cwd. - [x]
helptagshelptags of vim. - [x]
linessearch lines by regex patterns. - [x]
locationlistitems from vim's location list. - [x]
mapskey mappings. - [x]
marksmarks of vim. - [x]
mrumost recent used files. - [x]
quickfixitems from vim's quickfix list. - [x]
registersregisters of vim. - [x]
searchhistoryhistory of search. - [x]
sessionssession list. - [x]
tagssearch tag files. - [x]
vimcommandsavailable vim commands. - [x]
windowswindows of vim. - [x]
wordssearch word in current buffer.
For snippets list, use coc-snippets.
For git related list, use coc-git.
For yank history, use coc-yank.
Install
In your vim/neovim, run command:
:CocInstall coc-lists
Checkout :h coc-list for usage.
Options
Tip: type ? on normal mode to get detail help of current list.
Available options for coc-lists:
session.saveOnVimLeaveSave session on VimLeavePre., default totruesession.directorydirectory for session files, default to~/.vim/sessionssession.restartOnSessionLoadRestart vim with cwd changed on session load, support neovim on iTerm2 only.lists.disabledLists: List names to disable form load., default:[]list.source.files.command: Command used for search for files, default:""list.source.files.args: Arguments for search command, default:[]list.source.files.excludePatterns: Minimatch patterns that should be excluded., default:[]list.source.mru.maxLength: Max length of mru list., default:1000list.source.mru.ignoreGitIgnore: Ignore git ignored files., default:falselist.source.mru.excludePatterns: Minimatch patterns that should be excluded., default:["**/.git/*","/tmp/*"]list.source.grep.useLiteral: Use literal match unless specified regex options, default: true., default:truelist.source.grep.command: Command used for grep, default to 'rg'., default:"rg"could bergorag.list.source.grep.maxColumns: Don't print lines longer than this limit in bytes, ripgrep only..list.source.tags.command: Command used for generate tags., default:"ctags -R ."list.source.grep.args: Arguments for grep command, always used for grep, default:[]list.source.grep.excludePatterns: Minimatch patterns of files that should be excluded, use .ignore file is recommended., default:[]
Commands
mru.validateremove none exists files from mru list.tags.generategenerate tags of current project (in current cwd).session.savesave current vim state to session file.session.loadload exists session file.
F.A.Q
Q: Hidden files not exists using files source.
A: You have to pass --hidden to ripgrep by using configuration:
`list.source.files.args`: ['--hidden', '--files']
Q: How to ignore files using files/grep source.
A: You can add .ignore file in your project root, which would be respected by
ripgrep or use list.sourcefiles.excludePatterns configuration.
Q: How to make grep easier?
A: Create custom command like:
" grep word under cursor
command! -nargs=+ -complete=custom,s:GrepArgs Rg exe 'CocList grep '.<q-args>
function! s:GrepArgs(...)
let list = ['-S', '-smartcase', '-i', '-ignorecase', '-w', '-word',
\ '-e', '-regex', '-u', '-skip-vcs-ignores', '-t', '-extension']
return join(list, "\n")
endfunction
" Keymapping for grep word under cursor with interactive mode
nnoremap <silent> <Leader>cf :exe 'CocList -I --input='.expand('<cword>').' grep'<CR>
Q: How to grep by motion?
A: Create custom keymappings like:
vnoremap <leader>g :<C-u>call <SID>GrepFromSelected(visualmode())<CR>
nnoremap <leader>g :<C-u>set operatorfunc=<SID>GrepFromSelected<CR>g@
function! s:GrepFromSelected(type)
let saved_unnamed_register = @@
if a:type ==# 'v'
normal! `<v`>y
elseif a:type ==# 'char'
normal! `[v`]y
else
return
endif
let word = substitute(@@, '\n$', '', 'g')
let word = escape(word, '| ')
let @@ = saved_unnamed_register
execute 'CocList grep '.word
endfunction
Q: How to grep current word in current buffer?
A: Create kep-mapping like:
nnoremap <silent> <space>w :exe 'CocList -I --normal --input='.expand('<cword>').' words'<CR>
Q: How to grep word in a specific folder?
A: Pass -- /folder/to/search/from to CocList grep
:CocList grep word -- /folder/to/search/from
License
MIT