From 5ecee30dcdc1e8c731a69aa04729f07edd57fc27 Mon Sep 17 00:00:00 2001 From: Rob B Date: Wed, 2 Jul 2025 18:46:44 +0200 Subject: [PATCH] runtime(go): add section movement mappings to ftplugin closes: #17641 Signed-off-by: Rob B Signed-off-by: Christian Brabandt --- runtime/ftplugin/go.vim | 34 ++++++++++++++++++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/runtime/ftplugin/go.vim b/runtime/ftplugin/go.vim index f3cae02065..e3f947c091 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('') .. 'GoKeywordPrg') +if !exists('*' . expand('') . 'GoKeywordPrg') func! s:GoKeywordPrg() let temp_isk = &l:iskeyword setl iskeyword+=. @@ -49,6 +50,35 @@ if !exists('*' .. expand('') .. 'GoKeywordPrg') endfunc endif +if !exists("no_plugin_maps") && !exists("no_go_maps") + noremap ]] call GoFindSection('next_start', v:count1) + noremap ][ call GoFindSection('next_end', v:count1) + noremap [[ call GoFindSection('prev_start', v:count1) + noremap [] call GoFindSection('prev_end', v:count1) + let b:undo_ftplugin .= '' + \ . '| unmap ]]' + \ . '| unmap ][' + \ . '| unmap [[' + \ . '| unmap []' +endif + +function! 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