2017-09-27 20:43:42 +02:00
|
|
|
if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'vim') == -1
|
|
|
|
|
|
|
|
" Vim indent file
|
|
|
|
" Language: Go
|
|
|
|
" Maintainer: David Barnett (https://github.com/google/vim-ft-go)
|
|
|
|
" Last Change: 2017 Jun 13
|
|
|
|
"
|
|
|
|
" TODO:
|
|
|
|
" - function invocations split across lines
|
|
|
|
" - general line splits (line ends in an operator)
|
|
|
|
|
|
|
|
if exists('b:did_indent')
|
|
|
|
finish
|
|
|
|
endif
|
|
|
|
let b:did_indent = 1
|
|
|
|
|
|
|
|
" C indentation is too far off useful, mainly due to Go's := operator.
|
|
|
|
" Let's just define our own.
|
|
|
|
setlocal nolisp
|
|
|
|
setlocal autoindent
|
|
|
|
setlocal indentexpr=GoIndent(v:lnum)
|
|
|
|
setlocal indentkeys+=<:>,0=},0=)
|
|
|
|
|
|
|
|
if exists('*GoIndent')
|
|
|
|
finish
|
|
|
|
endif
|
|
|
|
|
|
|
|
function! GoIndent(lnum)
|
|
|
|
let l:prevlnum = prevnonblank(a:lnum-1)
|
|
|
|
if l:prevlnum == 0
|
|
|
|
" top of file
|
|
|
|
return 0
|
|
|
|
endif
|
|
|
|
|
|
|
|
" grab the previous and current line, stripping comments.
|
|
|
|
let l:prevl = substitute(getline(l:prevlnum), '//.*$', '', '')
|
|
|
|
let l:thisl = substitute(getline(a:lnum), '//.*$', '', '')
|
|
|
|
let l:previ = indent(l:prevlnum)
|
|
|
|
|
|
|
|
let l:ind = l:previ
|
|
|
|
|
|
|
|
if l:prevl =~ '[({]\s*$'
|
|
|
|
" previous line opened a block
|
|
|
|
let l:ind += shiftwidth()
|
|
|
|
endif
|
|
|
|
if l:prevl =~# '^\s*\(case .*\|default\):$'
|
|
|
|
" previous line is part of a switch statement
|
|
|
|
let l:ind += shiftwidth()
|
|
|
|
endif
|
|
|
|
" TODO: handle if the previous line is a label.
|
|
|
|
|
|
|
|
if l:thisl =~ '^\s*[)}]'
|
|
|
|
" this line closed a block
|
|
|
|
let l:ind -= shiftwidth()
|
|
|
|
endif
|
|
|
|
|
|
|
|
" Colons are tricky.
|
|
|
|
" We want to outdent if it's part of a switch ("case foo:" or "default:").
|
|
|
|
" We ignore trying to deal with jump labels because (a) they're rare, and
|
|
|
|
" (b) they're hard to disambiguate from a composite literal key.
|
|
|
|
if l:thisl =~# '^\s*\(case .*\|default\):$'
|
|
|
|
let l:ind -= shiftwidth()
|
|
|
|
endif
|
|
|
|
|
|
|
|
return l:ind
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
" vim: sw=2 sts=2 et
|
|
|
|
|
|
|
|
endif
|
2015-07-18 23:05:45 +02:00
|
|
|
if !exists('g:polyglot_disabled') || index(g:polyglot_disabled, 'go') == -1
|
|
|
|
|
2014-08-13 00:55:50 +02:00
|
|
|
" Copyright 2011 The Go Authors. All rights reserved.
|
|
|
|
" Use of this source code is governed by a BSD-style
|
|
|
|
" license that can be found in the LICENSE file.
|
|
|
|
"
|
|
|
|
" indent/go.vim: Vim indent file for Go.
|
|
|
|
"
|
|
|
|
" TODO:
|
|
|
|
" - function invocations split across lines
|
|
|
|
" - general line splits (line ends in an operator)
|
|
|
|
|
|
|
|
if exists("b:did_indent")
|
2016-06-26 18:03:28 +02:00
|
|
|
finish
|
2014-08-13 00:55:50 +02:00
|
|
|
endif
|
|
|
|
let b:did_indent = 1
|
|
|
|
|
|
|
|
" C indentation is too far off useful, mainly due to Go's := operator.
|
|
|
|
" Let's just define our own.
|
|
|
|
setlocal nolisp
|
|
|
|
setlocal autoindent
|
|
|
|
setlocal indentexpr=GoIndent(v:lnum)
|
|
|
|
setlocal indentkeys+=<:>,0=},0=)
|
|
|
|
|
|
|
|
if exists("*GoIndent")
|
2016-06-26 18:03:28 +02:00
|
|
|
finish
|
2015-03-08 21:32:50 -07:00
|
|
|
endif
|
|
|
|
|
|
|
|
" use shiftwidth function only if it's available
|
|
|
|
if exists('*shiftwidth')
|
2016-06-26 18:03:28 +02:00
|
|
|
func s:sw()
|
|
|
|
return shiftwidth()
|
|
|
|
endfunc
|
2015-03-08 21:32:50 -07:00
|
|
|
else
|
2016-06-26 18:03:28 +02:00
|
|
|
func s:sw()
|
|
|
|
return &sw
|
|
|
|
endfunc
|
2014-08-13 00:55:50 +02:00
|
|
|
endif
|
|
|
|
|
|
|
|
function! GoIndent(lnum)
|
2016-06-26 18:03:28 +02:00
|
|
|
let prevlnum = prevnonblank(a:lnum-1)
|
|
|
|
if prevlnum == 0
|
|
|
|
" top of file
|
|
|
|
return 0
|
|
|
|
endif
|
2014-08-13 00:55:50 +02:00
|
|
|
|
2016-06-26 18:03:28 +02:00
|
|
|
" grab the previous and current line, stripping comments.
|
|
|
|
let prevl = substitute(getline(prevlnum), '//.*$', '', '')
|
|
|
|
let thisl = substitute(getline(a:lnum), '//.*$', '', '')
|
|
|
|
let previ = indent(prevlnum)
|
2014-08-13 00:55:50 +02:00
|
|
|
|
2016-06-26 18:03:28 +02:00
|
|
|
let ind = previ
|
2014-08-13 00:55:50 +02:00
|
|
|
|
2016-06-26 18:03:28 +02:00
|
|
|
if prevl =~ '[({]\s*$'
|
|
|
|
" previous line opened a block
|
|
|
|
let ind += s:sw()
|
|
|
|
endif
|
|
|
|
if prevl =~# '^\s*\(case .*\|default\):$'
|
|
|
|
" previous line is part of a switch statement
|
|
|
|
let ind += s:sw()
|
|
|
|
endif
|
|
|
|
" TODO: handle if the previous line is a label.
|
2014-08-13 00:55:50 +02:00
|
|
|
|
2016-06-26 18:03:28 +02:00
|
|
|
if thisl =~ '^\s*[)}]'
|
|
|
|
" this line closed a block
|
|
|
|
let ind -= s:sw()
|
|
|
|
endif
|
2014-08-13 00:55:50 +02:00
|
|
|
|
2016-06-26 18:03:28 +02:00
|
|
|
" Colons are tricky.
|
|
|
|
" We want to outdent if it's part of a switch ("case foo:" or "default:").
|
|
|
|
" We ignore trying to deal with jump labels because (a) they're rare, and
|
|
|
|
" (b) they're hard to disambiguate from a composite literal key.
|
|
|
|
if thisl =~# '^\s*\(case .*\|default\):$'
|
|
|
|
let ind -= s:sw()
|
|
|
|
endif
|
2014-08-13 00:55:50 +02:00
|
|
|
|
2016-06-26 18:03:28 +02:00
|
|
|
return ind
|
2014-08-13 00:55:50 +02:00
|
|
|
endfunction
|
2015-03-08 21:32:50 -07:00
|
|
|
|
2016-06-26 18:03:28 +02:00
|
|
|
" vim: sw=2 ts=2 et
|
2015-07-18 23:05:45 +02:00
|
|
|
|
|
|
|
endif
|