Commit: runtime(go): add section movement mappings to ftplugin

3 views
Skip to first unread message

Christian Brabandt

unread,
Jul 2, 2025, 1:00:22 PM7/2/25
to vim...@googlegroups.com
runtime(go): add section movement mappings to ftplugin

Commit: https://github.com/vim/vim/commit/5ecee30dcdc1e8c731a69aa04729f07edd57fc27
Author: Rob B <git...@0x7e.net>
Date: Wed Jul 2 18:46:44 2025 +0200

runtime(go): add section movement mappings to ftplugin

closes: https://github.com/vim/vim/issues/17641

Signed-off-by: Rob B <git...@0x7e.net>
Signed-off-by: Christian Brabandt <c...@256bit.org>

diff --git a/runtime/ftplugin/go.vim b/runtime/ftplugin/go.vim
index f3cae0206..e3f947c09 100644
--- a/runtime/ftplugin/go.vim
+++ b/runtime/ftplugin/go.vim
@@ -6,6 +6,7 @@
" 2025 Mar 07 by Vim Project (add formatprg and keywordprg option #16804)
" 2025 Mar 18 by Vim Project (use :term for 'keywordprg' #16911)
" 2025 Apr 16 by Vim Project (set 'cpoptions' for line continuation, #17121)
+" 2025 Jul 02 by Vim Project (add section movement mappings #17641)

if exists('b:did_ftplugin')
finish
@@ -29,10 +30,10 @@ let b:undo_ftplugin = 'setl fo< com< cms< fp< kp<'

if get(g:, 'go_recommended_style', 1)
setlocal noexpandtab softtabstop=0 shiftwidth=0
- let b:undo_ftplugin ..= ' | setl et< sts< sw<'
+ let b:undo_ftplugin .= ' | setl et< sts< sw<'
endif

-if !exists('*' .. expand('<SID>') .. 'GoKeywordPrg')
+if !exists('*' . expand('<SID>') . 'GoKeywordPrg')
func! s:GoKeywordPrg()
let temp_isk = &l:iskeyword
setl iskeyword+=.
@@ -49,6 +50,35 @@ if !exists('*' .. expand('<SID>') .. 'GoKeywordPrg')
endfunc
endif

+if !exists("no_plugin_maps") && !exists("no_go_maps")
+ noremap <silent> <buffer> ]] <Cmd>call <SID>GoFindSection('next_start', v:count1)<CR>
+ noremap <silent> <buffer> ][ <Cmd>call <SID>GoFindSection('next_end', v:count1)<CR>
+ noremap <silent> <buffer> [[ <Cmd>call <SID>GoFindSection('prev_start', v:count1)<CR>
+ noremap <silent> <buffer> [] <Cmd>call <SID>GoFindSection('prev_end', v:count1)<CR>
+ let b:undo_ftplugin .= ''
+ \ . '| unmap <buffer> ]]'
+ \ . '| unmap <buffer> ]['
+ \ . '| unmap <buffer> [['
+ \ . '| unmap <buffer> []'
+endif
+
+function! <SID>GoFindSection(dir, count)
+ mark '
+ let c = a:count
+ while c > 0
+ if a:dir == 'next_start'
+ keepjumps call search('^\(type\|func\)\>', 'W')
+ elseif a:dir == 'next_end'
+ keepjumps call search('^}', 'W')
+ elseif a:dir == 'prev_start'
+ keepjumps call search('^\(type\|func\)\>', 'bW')
+ elseif a:dir == 'prev_end'
+ keepjumps call search('^}', 'bW')
+ endif
+ let c -= 1
+ endwhile
+endfunction
+
let &cpo = s:cpo_save
unlet s:cpo_save

Reply all
Reply to author
Forward
0 new messages