changes.vim 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. " =============================================================================
  2. " File: autoload/ctrlp/changes.vim
  3. " Description: Change list extension
  4. " Author: Kien Nguyen <github.com/kien>
  5. " =============================================================================
  6. " Init {{{1
  7. if exists('g:loaded_ctrlp_changes') && g:loaded_ctrlp_changes
  8. fini
  9. en
  10. let g:loaded_ctrlp_changes = 1
  11. cal add(g:ctrlp_ext_vars, {
  12. \ 'init': 'ctrlp#changes#init(s:bufnr, s:crbufnr)',
  13. \ 'accept': 'ctrlp#changes#accept',
  14. \ 'lname': 'changes',
  15. \ 'sname': 'chs',
  16. \ 'exit': 'ctrlp#changes#exit()',
  17. \ 'type': 'tabe',
  18. \ 'sort': 0,
  19. \ 'nolim': 1,
  20. \ })
  21. let s:id = g:ctrlp_builtins + len(g:ctrlp_ext_vars)
  22. " Utilities {{{1
  23. fu! s:changelist(bufnr)
  24. sil! exe 'noa hid b' a:bufnr
  25. redi => result
  26. sil! changes
  27. redi END
  28. retu map(split(result, "\n")[1:], 'tr(v:val, " ", " ")')
  29. endf
  30. fu! s:process(clines, ...)
  31. let [clines, evas] = [[], []]
  32. for each in a:clines
  33. let parts = matchlist(each, '\v^.\s*\d+\s+(\d+)\s+(\d+)\s(.*)$')
  34. if !empty(parts)
  35. if parts[3] == '' | let parts[3] = ' ' | en
  36. cal add(clines, parts[3].' |'.a:1.':'.a:2.'|'.parts[1].':'.parts[2].'|')
  37. en
  38. endfo
  39. retu reverse(filter(clines, 'count(clines, v:val) == 1'))
  40. endf
  41. fu! s:syntax()
  42. if !ctrlp#nosy()
  43. cal ctrlp#hicheck('CtrlPBufName', 'Directory')
  44. cal ctrlp#hicheck('CtrlPTabExtra', 'Comment')
  45. sy match CtrlPBufName '\t|\d\+:\zs[^|]\+\ze|\d\+:\d\+|$'
  46. sy match CtrlPTabExtra '\zs\t.*\ze$' contains=CtrlPBufName
  47. en
  48. endf
  49. " Public {{{1
  50. fu! ctrlp#changes#init(original_bufnr, bufnr)
  51. let bufnr = exists('s:bufnr') ? s:bufnr : a:bufnr
  52. let bufs = exists('s:clmode') && s:clmode ? ctrlp#buffers('id') : [bufnr]
  53. cal filter(bufs, 'v:val > 0')
  54. let [swb, &swb] = [&swb, '']
  55. let lines = []
  56. for each in bufs
  57. let bname = bufname(each)
  58. let fnamet = fnamemodify(bname == '' ? '[No Name]' : bname, ':t')
  59. cal extend(lines, s:process(s:changelist(each), each, fnamet))
  60. endfo
  61. sil! exe 'noa hid b' a:original_bufnr
  62. let &swb = swb
  63. cal ctrlp#syntax()
  64. cal s:syntax()
  65. retu lines
  66. endf
  67. fu! ctrlp#changes#accept(mode, str)
  68. let info = matchlist(a:str, '\t|\(\d\+\):[^|]\+|\(\d\+\):\(\d\+\)|$')
  69. let bufnr = str2nr(get(info, 1))
  70. if bufnr
  71. cal ctrlp#acceptfile(a:mode, bufnr)
  72. cal cursor(get(info, 2), get(info, 3))
  73. sil! norm! zvzz
  74. en
  75. endf
  76. fu! ctrlp#changes#cmd(mode, ...)
  77. let s:clmode = a:mode
  78. if a:0 && !empty(a:1)
  79. let s:clmode = 0
  80. let bname = a:1 =~# '^%$\|^#\d*$' ? expand(a:1) : a:1
  81. let s:bufnr = bufnr('^'.fnamemodify(bname, ':p').'$')
  82. en
  83. retu s:id
  84. endf
  85. fu! ctrlp#changes#exit()
  86. unl! s:clmode s:bufnr
  87. endf
  88. "}}}
  89. " vim:fen:fdm=marker:fmr={{{,}}}:fdl=0:fdc=1:ts=2:sw=2:sts=2