mrufiles.vim 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  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. let [s:mrbs, s:mrufs] = [[], []]
  8. let s:mruf_map_string = '!stridx(v:val, cwd) ? strpart(v:val, idx) : v:val'
  9. fu! ctrlp#mrufiles#opts()
  10. let [pref, opts] = ['g:ctrlp_mruf_', {
  11. \ 'max': ['s:max', 250],
  12. \ 'include': ['s:in', ''],
  13. \ 'exclude': ['s:ex', ''],
  14. \ 'case_sensitive': ['s:cseno', 1],
  15. \ 'relative': ['s:re', 0],
  16. \ 'save_on_update': ['s:soup', 1],
  17. \ 'map_string': ['g:ctrlp_mruf_map_string', s:mruf_map_string],
  18. \ }]
  19. for [ke, va] in items(opts)
  20. let [{va[0]}, {pref.ke}] = [pref.ke, exists(pref.ke) ? {pref.ke} : va[1]]
  21. endfo
  22. endf
  23. cal ctrlp#mrufiles#opts()
  24. " Utilities {{{1
  25. fu! s:excl(fn)
  26. retu !empty({s:ex}) && a:fn =~# {s:ex}
  27. endf
  28. fu! s:mergelists()
  29. let diskmrufs = ctrlp#utils#readfile(ctrlp#mrufiles#cachefile())
  30. cal filter(diskmrufs, 'index(s:mrufs, v:val) < 0')
  31. let mrufs = s:mrufs + diskmrufs
  32. retu s:chop(mrufs)
  33. endf
  34. fu! s:chop(mrufs)
  35. if len(a:mrufs) > {s:max} | cal remove(a:mrufs, {s:max}, -1) | en
  36. retu a:mrufs
  37. endf
  38. fu! s:reformat(mrufs, ...)
  39. let cwd = getcwd()
  40. let cwd .= cwd !~ '[\/]$' ? ctrlp#utils#lash() : ''
  41. if {s:re}
  42. let cwd = exists('+ssl') ? tr(cwd, '/', '\') : cwd
  43. cal filter(a:mrufs, '!stridx(v:val, cwd)')
  44. en
  45. if a:0 && a:1 == 'raw' | retu a:mrufs | en
  46. let idx = strlen(cwd)
  47. if exists('+ssl') && &ssl
  48. let cwd = tr(cwd, '\', '/')
  49. cal map(a:mrufs, 'tr(v:val, "\\", "/")')
  50. en
  51. retu map(a:mrufs, g:ctrlp_mruf_map_string)
  52. endf
  53. fu! s:record(bufnr)
  54. if s:locked | retu | en
  55. let bufnr = a:bufnr + 0
  56. let bufname = bufname(bufnr)
  57. if bufnr > 0 && !empty(bufname)
  58. cal filter(s:mrbs, 'v:val != bufnr')
  59. cal insert(s:mrbs, bufnr)
  60. cal s:addtomrufs(bufname)
  61. en
  62. endf
  63. fu! s:addtomrufs(fname)
  64. let fn = fnamemodify(a:fname, get(g:, 'ctrlp_tilde_homedir', 0) ? ':p:~' : ':p')
  65. let fn = exists('+ssl') ? tr(fn, '/', '\') : fn
  66. let abs_fn = fnamemodify(fn,':p')
  67. if ( !empty({s:in}) && fn !~# {s:in} ) || ( !empty({s:ex}) && fn =~# {s:ex} )
  68. \ || !empty(getbufvar('^' . abs_fn . '$', '&bt')) || !filereadable(abs_fn)
  69. retu
  70. en
  71. let idx = index(s:mrufs, fn, 0, !{s:cseno})
  72. if idx
  73. cal filter(s:mrufs, 'v:val !='.( {s:cseno} ? '#' : '?' ).' fn')
  74. cal insert(s:mrufs, fn)
  75. if {s:soup} && idx < 0
  76. cal s:savetofile(s:mergelists())
  77. en
  78. en
  79. endf
  80. fu! s:savetofile(mrufs)
  81. cal ctrlp#utils#writecache(a:mrufs, s:cadir, s:cafile)
  82. endf
  83. " Public {{{1
  84. fu! ctrlp#mrufiles#refresh(...)
  85. let mrufs = s:mergelists()
  86. cal filter(mrufs, '!empty(ctrlp#utils#glob(v:val, 1)) && !s:excl(v:val)')
  87. if exists('+ssl')
  88. cal map(mrufs, 'tr(v:val, "/", "\\")')
  89. cal map(s:mrufs, 'tr(v:val, "/", "\\")')
  90. let cond = 'count(mrufs, v:val, !{s:cseno}) == 1'
  91. cal filter(mrufs, cond)
  92. cal filter(s:mrufs, cond)
  93. en
  94. cal s:savetofile(mrufs)
  95. retu a:0 && a:1 == 'raw' ? [] : s:reformat(mrufs)
  96. endf
  97. fu! ctrlp#mrufiles#remove(files)
  98. let mrufs = []
  99. if a:files != []
  100. let mrufs = s:mergelists()
  101. let cond = 'index(a:files, v:val, 0, !{s:cseno}) < 0'
  102. cal filter(mrufs, cond)
  103. cal filter(s:mrufs, cond)
  104. en
  105. cal s:savetofile(mrufs)
  106. retu s:reformat(mrufs)
  107. endf
  108. fu! ctrlp#mrufiles#add(fn)
  109. if !empty(a:fn)
  110. cal s:addtomrufs(a:fn)
  111. en
  112. endf
  113. fu! ctrlp#mrufiles#list(...)
  114. retu a:0 ? a:1 == 'raw' ? s:reformat(s:mergelists(), a:1) : 0
  115. \ : s:reformat(s:mergelists())
  116. endf
  117. fu! ctrlp#mrufiles#bufs()
  118. retu s:mrbs
  119. endf
  120. fu! ctrlp#mrufiles#tgrel()
  121. let {s:re} = !{s:re}
  122. endf
  123. fu! ctrlp#mrufiles#cachefile()
  124. if !exists('s:cadir') || !exists('s:cafile')
  125. let s:cadir = ctrlp#utils#cachedir().ctrlp#utils#lash().'mru'
  126. let s:cafile = s:cadir.ctrlp#utils#lash().'cache.txt'
  127. en
  128. retu s:cafile
  129. endf
  130. fu! ctrlp#mrufiles#init()
  131. if !has('autocmd') | retu | en
  132. let s:locked = 0
  133. aug CtrlPMRUF
  134. au!
  135. au BufWinEnter,BufWinLeave,BufWritePost * cal s:record(expand('<abuf>', 1))
  136. au QuickFixCmdPre *vimgrep* let s:locked = 1
  137. au QuickFixCmdPost *vimgrep* let s:locked = 0
  138. au VimLeavePre * cal s:savetofile(s:mergelists())
  139. aug END
  140. endf
  141. "}}}
  142. " vim:fen:fdm=marker:fmr={{{,}}}:fdl=0:fdc=1:ts=2:sw=2:sts=2