1
0

changes.vim 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  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 fnamet = fnamemodify(bufname(each), ':t')
  58. cal extend(lines, s:process(s:changelist(each), each, fnamet))
  59. endfo
  60. sil! exe 'noa hid b' a:original_bufnr
  61. let &swb = swb
  62. cal ctrlp#syntax()
  63. cal s:syntax()
  64. retu lines
  65. endf
  66. fu! ctrlp#changes#accept(mode, str)
  67. let info = matchlist(a:str, '\t|\(\d\+\):[^|]\+|\(\d\+\):\(\d\+\)|$')
  68. if info == [] | retu | en
  69. let bufnr = str2nr(get(info, 1))
  70. if bufnr
  71. cal ctrlp#acceptfile(a:mode, fnamemodify(bufname(bufnr), ':p'))
  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:bufnr = bufnr('^'.fnamemodify(a:1, ':p').'$')
  80. en
  81. retu s:id
  82. endf
  83. fu! ctrlp#changes#exit()
  84. unl! s:clmode s:bufnr
  85. endf
  86. "}}}
  87. " vim:fen:fdm=marker:fmr={{{,}}}:fdl=0:fdc=1:ts=2:sw=2:sts=2