Skip to content

Commit

Permalink
Remember fmt failure on a per-buffer basis
Browse files Browse the repository at this point in the history
Fixes #720
  • Loading branch information
cespare committed Feb 11, 2016
1 parent af1c4dd commit c11975b
Showing 1 changed file with 4 additions and 6 deletions.
10 changes: 4 additions & 6 deletions autoload/go/fmt.vim
Original file line number Diff line number Diff line change
Expand Up @@ -43,8 +43,6 @@ if !exists("g:go_fmt_experimental")
let g:go_fmt_experimental = 0
endif

let s:got_fmt_error = 0

" we have those problems :
" http://stackoverflow.com/questions/12741977/prevent-vim-from-updating-its-undo-tree
" http://stackoverflow.com/questions/18532692/golang-formatter-and-vim-how-to-destroy-history-record?rq=1
Expand Down Expand Up @@ -120,12 +118,12 @@ function! go#fmt#Format(withGoimport)
let &syntax = &syntax

" clean up previous location list, but only if it's due fmt
if s:got_fmt_error
let s:got_fmt_error = 0
if exists('b:got_fmt_error') && b:got_fmt_error
let b:got_fmt_error = 0
call go#list#Clean()
call go#list#Window()
endif
elseif g:go_fmt_fail_silently == 0
elseif g:go_fmt_fail_silently == 0
let splitted = split(out, '\n')
"otherwise get the errors and put them to location list
let errors = []
Expand All @@ -146,7 +144,7 @@ function! go#fmt#Format(withGoimport)
echohl Error | echomsg "Gofmt returned error" | echohl None
endif

let s:got_fmt_error = 1
let b:got_fmt_error = 1
call go#list#Window(len(errors))

" We didn't use the temp file, so clean up
Expand Down

0 comments on commit c11975b

Please sign in to comment.