2019-04-21 11:42:15 +00:00
|
|
|
" order of EOL detection
|
|
|
|
set fileformats=unix,dos,mac
|
|
|
|
|
|
|
|
set wildignore+=.git,.svn,.hg,.DS_Store,*~
|
|
|
|
|
2019-05-18 08:23:30 +00:00
|
|
|
" arguably one of the most useful mappings
|
|
|
|
nnoremap <silent><expr> <CR> &buftype is# '' ? ":write\<CR>" : "\<CR>"
|
|
|
|
|
|
|
|
|
2019-04-21 11:42:15 +00:00
|
|
|
" ripgrep (rg) {{{
|
|
|
|
if executable('rg')
|
|
|
|
let s:rg_cmd = "rg --hidden --follow"
|
|
|
|
let s:rg_ignore = split(&wildignore, ',') + [
|
|
|
|
\ 'node_modules', 'target', 'build', 'dist', '.stack-work'
|
|
|
|
\ ]
|
|
|
|
let s:rg_cmd .= " --glob '!{'" . shellescape(join(s:rg_ignore, ',')) . "'}'"
|
|
|
|
|
|
|
|
let &grepprg = s:rg_cmd . ' --vimgrep'
|
|
|
|
let $FZF_DEFAULT_COMMAND = s:rg_cmd . ' --files'
|
|
|
|
command! -bang -nargs=* Rg call fzf#vim#grep(s:rg_cmd . ' --column --line-number --no-heading --fixed-strings --smart-case --color always ' . shellescape(<q-args>), 1, <bang>0)
|
|
|
|
command! -bang -nargs=* Find Rg<bang> <args>
|
|
|
|
endif
|
|
|
|
" }}}
|
|
|
|
|
|
|
|
|
|
|
|
" Netrw {{{
|
|
|
|
" disable most of the Netrw functionality (because I use Ranger) except its
|
|
|
|
" helper functions (which I use in my dotfiles)
|
|
|
|
let g:loaded_netrwPlugin = 1
|
|
|
|
" re-add Netrw's gx mappings since we've disabled them
|
2019-05-01 14:40:25 +00:00
|
|
|
nnoremap <silent> gx <Cmd>call netrw#BrowseX(expand('<cfile>'),netrw#CheckIfRemote())<CR>
|
2019-04-22 10:03:25 +00:00
|
|
|
xnoremap <silent> gx :<C-u>call netrw#BrowseXVis()<CR>
|
2019-04-21 11:42:15 +00:00
|
|
|
" }}}
|
|
|
|
|
|
|
|
|
|
|
|
" Ranger {{{
|
|
|
|
let g:ranger_replace_netrw = 1
|
|
|
|
let g:ranger_map_keys = 0
|
2019-05-01 14:40:25 +00:00
|
|
|
nnoremap <silent> <Leader>o <Cmd>Ranger<CR>
|
2019-04-21 11:42:15 +00:00
|
|
|
" ranger.vim relies on the Bclose.vim plugin, but I use Bbye.vim, so this
|
|
|
|
" command is here just for compatitabilty
|
|
|
|
command! -bang -complete=buffer -nargs=? Bclose Bdelete<bang> <args>
|
|
|
|
" }}}
|
|
|
|
|
|
|
|
|
|
|
|
" Commands {{{
|
|
|
|
|
|
|
|
" DiffWithSaved {{{
|
|
|
|
" Compare current buffer with the actual (saved) file on disk
|
|
|
|
function s:DiffWithSaved()
|
|
|
|
let l:filetype = &filetype
|
|
|
|
diffthis
|
|
|
|
vnew | read # | normal! ggdd
|
|
|
|
diffthis
|
|
|
|
setlocal buftype=nofile bufhidden=wipe nobuflisted noswapfile readonly nomodifiable
|
|
|
|
let &filetype = l:filetype
|
|
|
|
endfunction
|
|
|
|
command DiffWithSaved call s:DiffWithSaved()
|
|
|
|
" }}}
|
|
|
|
|
|
|
|
" Reveal {{{
|
|
|
|
" Reveal file in the system file explorer
|
|
|
|
function s:Reveal(path)
|
|
|
|
if has('macunix')
|
|
|
|
" only macOS has functionality to really 'reveal' a file, that is, to open
|
|
|
|
" its parent directory in Finder and select this file
|
|
|
|
call system('open -R ' . fnamemodify(a:path, ':S'))
|
|
|
|
else
|
|
|
|
" for other systems let's not reinvent the bicycle, instead we open file's
|
|
|
|
" parent directory using netrw's builtin function (don't worry, netrw is
|
|
|
|
" always bundled with Nvim)
|
|
|
|
call s:Open(a:path)
|
|
|
|
endif
|
|
|
|
endfunction
|
|
|
|
command Reveal call s:Reveal(expand('%'))
|
|
|
|
" }}}
|
|
|
|
|
|
|
|
" Open {{{
|
|
|
|
" opens file with a system program
|
|
|
|
function s:Open(path)
|
|
|
|
" HACK: 2nd parameter of this function is called 'remote', it tells
|
|
|
|
" whether to open a remote (1) or local (0) file. However, it doesn't work
|
|
|
|
" as expected in this context, because it uses the 'gf' command if it's
|
|
|
|
" opening a local file (because this function was designed to be called
|
|
|
|
" from the 'gx' command). BUT, because this function only compares the
|
|
|
|
" value of the 'remote' parameter to 1, I can pass any other value, which
|
|
|
|
" will tell it to open a local file and ALSO this will ignore an
|
|
|
|
" if-statement which contains the 'gf' command.
|
|
|
|
call netrw#BrowseX(a:path, 2)
|
|
|
|
endfunction
|
|
|
|
command Open call s:Open(expand('%'))
|
|
|
|
" }}}
|
|
|
|
|
|
|
|
" }}}
|
|
|
|
|
|
|
|
|
|
|
|
" on save (BufWritePre) {{{
|
|
|
|
|
|
|
|
" create directory {{{
|
|
|
|
" Creates the parent directory of the file if it doesn't exist
|
|
|
|
function s:CreateDirOnSave()
|
|
|
|
" <afile> is the filename of the buffer where the autocommand is executed
|
|
|
|
let l:file = expand('<afile>')
|
|
|
|
" check if this is a regular file and its path is not a URL
|
|
|
|
if empty(&buftype) && l:file !~# '\v^\w+://'
|
|
|
|
let l:dir = fnamemodify(l:file, ':h')
|
|
|
|
if !isdirectory(l:dir) | call mkdir(l:dir, 'p') | endif
|
|
|
|
endif
|
|
|
|
endfunction
|
|
|
|
" }}}
|
|
|
|
|
|
|
|
" fix whitespace {{{
|
|
|
|
function s:FixWhitespaceOnSave()
|
|
|
|
let l:pos = getpos('.')
|
|
|
|
" remove trailing whitespace
|
|
|
|
%s/\s\+$//e
|
|
|
|
" remove trailing newlines
|
|
|
|
%s/\($\n\s*\)\+\%$//e
|
|
|
|
call setpos('.', l:pos)
|
|
|
|
endfunction
|
|
|
|
" }}}
|
|
|
|
|
2019-04-22 19:54:45 +00:00
|
|
|
" auto-format with Coc.nvim {{{
|
|
|
|
let g:coc_format_on_save_ignore = []
|
|
|
|
function s:FormatOnSave()
|
|
|
|
if index(g:coc_format_on_save_ignore, &filetype) < 0 && IsCocEnabled()
|
|
|
|
silent CocFormat
|
|
|
|
endif
|
|
|
|
endfunction
|
|
|
|
" }}}
|
|
|
|
|
2019-04-21 11:42:15 +00:00
|
|
|
function s:OnSave()
|
|
|
|
call s:FixWhitespaceOnSave()
|
2019-04-22 19:54:45 +00:00
|
|
|
call s:FormatOnSave()
|
2019-04-21 11:42:15 +00:00
|
|
|
call s:CreateDirOnSave()
|
|
|
|
endfunction
|
|
|
|
augroup vimrc-on-save
|
|
|
|
autocmd!
|
|
|
|
autocmd BufWritePre * call s:OnSave()
|
|
|
|
augroup END
|
|
|
|
|
|
|
|
" }}}
|
|
|
|
|
|
|
|
|
|
|
|
" CtrlSF {{{
|
|
|
|
nmap <leader>/ <Plug>CtrlSFPrompt
|
|
|
|
nmap <leader>* <Plug>CtrlSFCwordPath
|
|
|
|
xmap <leader>* <Plug>CtrlSFVwordPath
|
|
|
|
" }}}
|