From 51f5139ff5dc7dd4ab173beb70d7b6262fd54901 Mon Sep 17 00:00:00 2001 From: Marco Hinz Date: Fri, 8 Mar 2013 09:54:42 +0100 Subject: [PATCH] better handling of calls to s:remove_signs() Improving by removing! Closes #2. --- plugin/signify.vim | 36 ++++++++++++++++-------------------- 1 file changed, 16 insertions(+), 20 deletions(-) diff --git a/plugin/signify.vim b/plugin/signify.vim index 0fdf229..f7d0e4b 100644 --- a/plugin/signify.vim +++ b/plugin/signify.vim @@ -94,7 +94,6 @@ aug signify au ColorScheme * call s:set_colors() au BufWritePost,FocusGained * call s:start(expand(':p')) au BufEnter * let s:colors_set = 0 | call s:start(expand(':p')) - au BufDelete * call s:stop(expand(':p')) | call s:remove_from_buffer_list(expand(':p')) aug END com! -nargs=0 -bar SignifyToggle call s:toggle_signify() @@ -125,23 +124,28 @@ function! s:start(path) abort endfor endif + " Is a diff available? + let diff = s:get_diff(a:path) + if empty(diff) + return + endif + " New buffer.. add to list. if !has_key(s:sy, a:path) let s:sy[a:path] = { 'active': 1, 'ids': [], 'id_jump': s:id_top, 'id_top': s:id_top, 'last_jump_was_next': -1 } " Inactive buffer.. bail out. elseif s:sy[a:path].active == 0 return + " Update active buffer.. reset default values else + call s:remove_signs(a:path) let s:sy[a:path].id_top = s:id_top let s:sy[a:path].id_jump = s:id_top let s:sy[a:path].last_jump_was_next = -1 endif - " Is a diff available? - let diff = s:get_diff(a:path) - if empty(diff) - call s:remove_signs(a:path) - return + if s:sign_overwrite == 0 + call s:get_other_signs(a:path) endif " Set colors only for the first time or when a new colorscheme is set. @@ -150,12 +154,6 @@ function! s:start(path) abort let s:colors_set = 1 endif - call s:remove_signs(a:path) - - if s:sign_overwrite == 0 - call s:get_other_signs(a:path) - endif - " Use git's diff cmd to set our signs. call s:process_diff(diff) @@ -164,8 +162,13 @@ endfunction " Functions -> s:stop() {{{2 function! s:stop(path) abort - echom expand('%:p') + if !has_key(s:sy, a:path) + return + endif + call s:remove_signs(a:path) + call remove(s:sy, a:path) + aug signify au! * aug END @@ -428,13 +431,6 @@ function! s:jump_to_prev_hunk() let s:sy[path].last_jump_was_next = 0 endfunction -" Functions -> s:remove_from_buffer_list() {{{2 -function! s:remove_from_buffer_list(path) abort - if has_key(s:sy, a:path) - call remove(s:sy, a:path) - endif -endfunction - " Functions -> SignifyDebugListActiveBuffers() {{{2 function! SignifyDebugListActiveBuffers() abort if len(s:sy) == 0