From 045b66a6ab3ab5c66698b44e51ccf4c3d97513c7 Mon Sep 17 00:00:00 2001 From: Kien N Date: Thu, 5 Apr 2012 23:59:54 +0700 Subject: [PATCH] Remix when MRU list changes --- autoload/ctrlp/mixed.vim | 8 +++++--- autoload/ctrlp/mrufiles.vim | 18 +++++++++--------- 2 files changed, 14 insertions(+), 12 deletions(-) diff --git a/autoload/ctrlp/mixed.vim b/autoload/ctrlp/mixed.vim index f7fdcfa..c46cc6c 100644 --- a/autoload/ctrlp/mixed.vim +++ b/autoload/ctrlp/mixed.vim @@ -28,7 +28,8 @@ let s:id = g:ctrlp_builtins + len(g:ctrlp_ext_vars) fu! s:newcache(cwd) if g:ctrlp_newmix || !has_key(g:ctrlp_allmixes, 'data') | retu 1 | en retu g:ctrlp_allmixes['cwd'] != a:cwd - \ || g:ctrlp_allmixes['time'] < getftime(ctrlp#utils#cachefile()) + \ || g:ctrlp_allmixes['filtime'] < getftime(ctrlp#utils#cachefile()) + \ || g:ctrlp_allmixes['mrutime'] < getftime(ctrlp#mrufiles#cachefile()) \ || g:ctrlp_allmixes['bufs'] < len(ctrlp#mrufiles#mrufs()) endf @@ -59,8 +60,9 @@ fu! s:getnewmix(cwd, clim) if len(g:ctrlp_lines) <= a:clim cal sort(g:ctrlp_lines, 'ctrlp#complen') en - let g:ctrlp_allmixes = { 'time': getftime(ctrlp#utils#cachefile()), - \ 'cwd': a:cwd, 'bufs': len(ctrlp#mrufiles#mrufs()), 'data': g:ctrlp_lines } + let g:ctrlp_allmixes = { 'filtime': getftime(ctrlp#utils#cachefile()), + \ 'mrutime': getftime(ctrlp#mrufiles#cachefile()), 'cwd': a:cwd, + \ 'bufs': len(ctrlp#mrufiles#mrufs()), 'data': g:ctrlp_lines } endf " Public {{{1 fu! ctrlp#mixed#init(clim) diff --git a/autoload/ctrlp/mrufiles.vim b/autoload/ctrlp/mrufiles.vim index 2af5e04..9fee6f8 100644 --- a/autoload/ctrlp/mrufiles.vim +++ b/autoload/ctrlp/mrufiles.vim @@ -26,7 +26,7 @@ fu! s:excl(fn) endf fu! s:mergelists() - let diskmrufs = s:readcache() + let diskmrufs = ctrlp#utils#readfile(ctrlp#mrufiles#cachefile()) cal filter(diskmrufs, 'index(s:mrufs, v:val) < 0') let mrufs = s:mrufs + diskmrufs if v:version < 702 | cal filter(mrufs, 'count(mrufs, v:val) == 1') | en @@ -38,14 +38,6 @@ fu! s:chop(mrufs) retu a:mrufs endf -fu! s:readcache() - if !exists('s:cadir') || !exists('s:cafile') - let s:cadir = ctrlp#utils#cachedir().ctrlp#utils#lash().'mru' - let s:cafile = s:cadir.ctrlp#utils#lash().'cache.txt' - en - retu ctrlp#utils#readfile(s:cafile) -endf - fu! s:reformat(mrufs) if s:re let cwd = exists('+ssl') ? tr(getcwd(), '/', '\') : getcwd() @@ -109,6 +101,14 @@ fu! ctrlp#mrufiles#mrufs() retu s:mrufs endf +fu! ctrlp#mrufiles#cachefile() + if !exists('s:cadir') || !exists('s:cafile') + let s:cadir = ctrlp#utils#cachedir().ctrlp#utils#lash().'mru' + let s:cafile = s:cadir.ctrlp#utils#lash().'cache.txt' + en + retu s:cafile +endf + fu! ctrlp#mrufiles#init() if !has('autocmd') | retu | en let s:locked = 0