1
0

mrufiles.vim 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. " =============================================================================
  2. " File: autoload/ctrlp/mrufiles.vim
  3. " Description: Most Recently Used Files extension
  4. " Author: Kien Nguyen <github.com/kien>
  5. " =============================================================================
  6. " Static variables {{{1
  7. fu! ctrlp#mrufiles#opts()
  8. let [pref, opts] = ['g:ctrlp_mruf_', {
  9. \ 'max': ['s:max', 250],
  10. \ 'include': ['s:in', ''],
  11. \ 'exclude': ['s:ex', ''],
  12. \ 'case_sensitive': ['s:cseno', 1],
  13. \ 'relative': ['s:re', 0],
  14. \ }]
  15. for [ke, va] in items(opts)
  16. let {va[0]} = exists(pref.ke) ? {pref.ke} : va[1]
  17. endfo
  18. let [s:csen, s:mrbs, s:mrufs] = [s:cseno ? '#' : '?', [], []]
  19. if exists('s:locked') | cal ctrlp#mrufiles#init() | en
  20. endf
  21. cal ctrlp#mrufiles#opts()
  22. " Utilities {{{1
  23. fu! s:excl(fn)
  24. retu !empty(s:ex) && a:fn =~# s:ex
  25. endf
  26. fu! s:mergelists()
  27. let diskmrufs = ctrlp#utils#readfile(ctrlp#mrufiles#cachefile())
  28. cal filter(diskmrufs, 'index(s:mrufs, v:val) < 0')
  29. let mrufs = s:mrufs + diskmrufs
  30. retu s:chop(mrufs)
  31. endf
  32. fu! s:chop(mrufs)
  33. if len(a:mrufs) > s:max | cal remove(a:mrufs, s:max, -1) | en
  34. retu a:mrufs
  35. endf
  36. fu! s:reformat(mrufs)
  37. if s:re
  38. let cwd = exists('+ssl') ? tr(getcwd(), '/', '\') : getcwd()
  39. cal filter(a:mrufs, '!stridx(v:val, cwd)')
  40. en
  41. retu map(a:mrufs, 'fnamemodify(v:val, ":.")')
  42. endf
  43. fu! s:record(bufnr)
  44. if s:locked | retu | en
  45. let bufnr = a:bufnr + 0
  46. if bufnr <= 0 | retu | en
  47. let bufname = bufname(bufnr)
  48. if empty(bufname) | retu | en
  49. let fn = fnamemodify(bufname, ':p')
  50. let fn = exists('+ssl') ? tr(fn, '/', '\') : fn
  51. cal filter(s:mrbs, 'v:val !='.s:csen.' fn')
  52. cal insert(s:mrbs, fn)
  53. if ( !empty(s:in) && fn !~# s:in ) || ( !empty(s:ex) && fn =~# s:ex )
  54. \ || !empty(&bt) || !filereadable(fn) | retu
  55. en
  56. cal filter(s:mrufs, 'v:val !='.s:csen.' fn')
  57. cal insert(s:mrufs, fn)
  58. endf
  59. fu! s:savetofile(mrufs)
  60. cal ctrlp#utils#writecache(a:mrufs, s:cadir, s:cafile)
  61. endf
  62. " Public {{{1
  63. fu! ctrlp#mrufiles#refresh(...)
  64. let s:mrufs = s:mergelists()
  65. cal filter(s:mrufs, '!empty(ctrlp#utils#glob(v:val, 1)) && !s:excl(v:val)')
  66. if exists('+ssl')
  67. cal map(s:mrufs, 'tr(v:val, "/", "\\")')
  68. cal filter(s:mrufs, 'count(s:mrufs, v:val) == 1')
  69. en
  70. cal s:savetofile(s:mrufs)
  71. retu a:0 && a:1 == 'raw' ? [] : s:reformat(copy(s:mrufs))
  72. endf
  73. fu! ctrlp#mrufiles#remove(files)
  74. let s:mrufs = []
  75. if a:files != []
  76. let s:mrufs = s:mergelists()
  77. cal filter(s:mrufs, 'index(a:files, v:val, 0, '.(!s:cseno).') < 0')
  78. en
  79. cal s:savetofile(s:mrufs)
  80. retu s:reformat(copy(s:mrufs))
  81. endf
  82. fu! ctrlp#mrufiles#list(...)
  83. retu a:0 ? a:1 == 'raw' ? s:mergelists() : 0 : s:reformat(s:mergelists())
  84. endf
  85. fu! ctrlp#mrufiles#bufs()
  86. retu s:mrbs
  87. endf
  88. fu! ctrlp#mrufiles#cachefile()
  89. if !exists('s:cadir') || !exists('s:cafile')
  90. let s:cadir = ctrlp#utils#cachedir().ctrlp#utils#lash().'mru'
  91. let s:cafile = s:cadir.ctrlp#utils#lash().'cache.txt'
  92. en
  93. retu s:cafile
  94. endf
  95. fu! ctrlp#mrufiles#init()
  96. if !has('autocmd') | retu | en
  97. let s:locked = 0
  98. aug CtrlPMRUF
  99. au!
  100. au BufAdd,BufEnter,BufUnload * cal s:record(expand('<abuf>', 1))
  101. au QuickFixCmdPre *vimgrep* let s:locked = 1
  102. au QuickFixCmdPost *vimgrep* let s:locked = 0
  103. au VimLeavePre * cal s:savetofile(s:mergelists())
  104. aug END
  105. endf
  106. "}}}
  107. " vim:fen:fdm=marker:fmr={{{,}}}:fdl=0:fdc=1:ts=2:sw=2:sts=2