1
0

dir.vim 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. " =============================================================================
  2. " File: autoload/ctrlp/dir.vim
  3. " Description: Directory extension
  4. " Author: Kien Nguyen <github.com/kien>
  5. " =============================================================================
  6. " Init {{{1
  7. if exists('g:loaded_ctrlp_dir') && g:loaded_ctrlp_dir
  8. fini
  9. en
  10. let [g:loaded_ctrlp_dir, g:ctrlp_newdir] = [1, 0]
  11. let s:ars = ['s:maxdepth', 's:maxfiles', 's:compare_lim', 's:glob', 's:caching']
  12. cal add(g:ctrlp_ext_vars, {
  13. \ 'init': 'ctrlp#dir#init('.join(s:ars, ', ').')',
  14. \ 'accept': 'ctrlp#dir#accept',
  15. \ 'lname': 'dirs',
  16. \ 'sname': 'dir',
  17. \ 'type': 'path',
  18. \ 'specinput': 1,
  19. \ })
  20. let s:id = g:ctrlp_builtins + len(g:ctrlp_ext_vars)
  21. let s:dircounts = {}
  22. " Utilities {{{1
  23. fu! s:globdirs(dirs, depth)
  24. let entries = split(globpath(a:dirs, s:glob), "\n")
  25. let [dirs, depth] = [ctrlp#dirnfile(entries)[0], a:depth + 1]
  26. cal extend(g:ctrlp_alldirs, dirs)
  27. let nr = len(g:ctrlp_alldirs)
  28. if !empty(dirs) && !s:max(nr, s:maxfiles) && depth <= s:maxdepth
  29. sil! cal ctrlp#progress(nr)
  30. cal map(dirs, 'ctrlp#utils#fnesc(v:val, "g", ",")')
  31. cal s:globdirs(join(dirs, ','), depth)
  32. en
  33. endf
  34. fu! s:max(len, max)
  35. retu a:max && a:len > a:max
  36. endf
  37. fu! s:nocache()
  38. retu !s:caching || ( s:caching > 1 && get(s:dircounts, s:cwd) < s:caching )
  39. endf
  40. " Public {{{1
  41. fu! ctrlp#dir#init(...)
  42. let s:cwd = getcwd()
  43. for each in range(len(s:ars))
  44. let {s:ars[each]} = a:{each + 1}
  45. endfo
  46. let cadir = ctrlp#utils#cachedir().ctrlp#utils#lash().'dir'
  47. let cafile = cadir.ctrlp#utils#lash().ctrlp#utils#cachefile('dir')
  48. if g:ctrlp_newdir || s:nocache() || !filereadable(cafile)
  49. let [s:initcwd, g:ctrlp_alldirs] = [s:cwd, []]
  50. if !ctrlp#igncwd(s:cwd)
  51. cal s:globdirs(ctrlp#utils#fnesc(s:cwd, 'g', ','), 0)
  52. en
  53. cal ctrlp#rmbasedir(g:ctrlp_alldirs)
  54. if len(g:ctrlp_alldirs) <= s:compare_lim
  55. cal sort(g:ctrlp_alldirs, 'ctrlp#complen')
  56. en
  57. cal ctrlp#utils#writecache(g:ctrlp_alldirs, cadir, cafile)
  58. let g:ctrlp_newdir = 0
  59. el
  60. if !( exists('s:initcwd') && s:initcwd == s:cwd )
  61. let s:initcwd = s:cwd
  62. let g:ctrlp_alldirs = ctrlp#utils#readfile(cafile)
  63. en
  64. en
  65. cal extend(s:dircounts, { s:cwd : len(g:ctrlp_alldirs) })
  66. retu g:ctrlp_alldirs
  67. endf
  68. fu! ctrlp#dir#accept(mode, str)
  69. let path = a:mode == 'h' ? getcwd() : s:cwd.ctrlp#call('s:lash', s:cwd).a:str
  70. if a:mode =~ 't\|v\|h'
  71. cal ctrlp#exit()
  72. en
  73. cal ctrlp#setdir(path, a:mode =~ 't\|h' ? 'chd!' : 'lc!')
  74. if a:mode == 'e'
  75. sil! cal ctrlp#statusline()
  76. cal ctrlp#setlines(s:id)
  77. cal ctrlp#recordhist()
  78. cal ctrlp#prtclear()
  79. en
  80. endf
  81. fu! ctrlp#dir#id()
  82. retu s:id
  83. endf
  84. "}}}
  85. " vim:fen:fdm=marker:fmr={{{,}}}:fdl=0:fdc=1:ts=2:sw=2:sts=2