From 49c752b1f70a72000662f798bcff7ccf23b96e02 Mon Sep 17 00:00:00 2001 From: Junegunn Choi Date: Tue, 10 Mar 2015 12:13:11 +0900 Subject: [PATCH] [vim] up/down/left/right options to take boolean values When 1 is given, 50% of the screen width or height will be used as the default size of the pane. --- plugin/fzf.vim | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/plugin/fzf.vim b/plugin/fzf.vim index a3b6abd..076ab91 100644 --- a/plugin/fzf.vim +++ b/plugin/fzf.vim @@ -130,11 +130,20 @@ function! fzf#run(...) abort endif endfunction +function! s:present(dict, ...) + for key in a:000 + if !empty(get(a:dict, key, '')) + return 1 + endif + endfor + return 0 +endfunction + function! s:fzf_tmux(dict) let size = '' for o in ['up', 'down', 'left', 'right'] - if has_key(a:dict, o) - let size = '-'.o[0].a:dict[o] + if s:present(a:dict, o) + let size = '-'.o[0].(a:dict[o] == 1 ? '' : a:dict[o]) endif endfor return printf('LINES=%d COLUMNS=%d %s %s %s --', @@ -142,14 +151,11 @@ function! s:fzf_tmux(dict) endfunction function! s:tmux_splittable(dict) - return has_key(a:dict, 'up') || - \ has_key(a:dict, 'down') || - \ has_key(a:dict, 'left') || - \ has_key(a:dict, 'right') + return s:present(a:dict, 'up', 'down', 'left', 'right') endfunction function! s:pushd(dict) - if !empty(get(a:dict, 'dir', '')) + if s:present(a:dict, 'dir') let a:dict.prev_dir = getcwd() execute 'chdir '.s:escape(a:dict.dir) return 1