From: Jim Zhou Date: Thu, 26 Dec 2024 09:30:37 +0000 (+0100) Subject: runtime(vim): update indentation plugin for Vim script X-Git-Tag: v9.1.0962~1 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=6d2efd492010cc12e9eeec3ad2bb2645106e0087;p=thirdparty%2Fvim.git runtime(vim): update indentation plugin for Vim script Make the indent script aware of enums and ensure those will be correctly indented. fixes: #16289 closes: #16293 Co-authored-by: Aliaksei Budavei <0x000c70@gmail.com> Signed-off-by: Jim Zhou Signed-off-by: Christian Brabandt --- diff --git a/runtime/autoload/dist/vimindent.vim b/runtime/autoload/dist/vimindent.vim index 727e98352c..0681496ae9 100644 --- a/runtime/autoload/dist/vimindent.vim +++ b/runtime/autoload/dist/vimindent.vim @@ -2,11 +2,12 @@ vim9script # Language: Vim script # Maintainer: github user lacygoill -# Last Change: 2024 Nov 08 +# Last Change: 2024 Dec 26 # # Includes changes from The Vim Project: # - 2024 Feb 09: Fix indent after literal Dict (A. Radev via #13966) # - 2024 Nov 08: Fix indent after :silent! function (D. Kearns via #16009) +# - 2024 Dec 26: Fix indent for enums (Jim Zhou via #16293) # NOTE: Whenever you change the code, make sure the tests are still passing: # @@ -172,6 +173,7 @@ const MODIFIERS: dict = { def: ['export', 'static'], class: ['export', 'abstract', 'export abstract'], interface: ['export'], + enum: ['export'], } # ... # class: ['export', 'abstract', 'export abstract'], @@ -634,6 +636,7 @@ def Offset( # {{{2 elseif !line_A.isfirst && (line_B->EndsWithLineContinuation() || line_A.text =~ LINE_CONTINUATION_AT_SOL) + && !(line_B->EndsWithComma() && line_A.lnum->IsInside('EnumBlock')) return shiftwidth() endif @@ -1051,6 +1054,22 @@ def ContinuesBelowBracketBlock( # {{{3 enddef def IsInside(lnum: number, syntax: string): bool # {{{3 + if syntax == 'EnumBlock' + var cur_pos = getpos('.') + cursor(lnum, 1) + var enum_pos = search('^\C\s*\%(export\s\)\=\s*enum\s\+\S\+', 'bnW') + var endenum_pos = search('^\C\s*endenum\>', 'bnW') + setpos('.', cur_pos) + + if enum_pos == 0 && endenum_pos == 0 + return false + endif + if (enum_pos > 0 && (endenum_pos == 0 || enum_pos > endenum_pos)) + return true + endif + return false + endif + if !exists('b:vimindent') || !b:vimindent->has_key($'is_{syntax}') return false diff --git a/runtime/indent/testdir/vim.in b/runtime/indent/testdir/vim.in index ae52f3a947..431528ee27 100644 --- a/runtime/indent/testdir/vim.in +++ b/runtime/indent/testdir/vim.in @@ -947,6 +947,20 @@ Black endenum " END_INDENT +" START_INDENT +enum Digits +INVALID(v:numbermax), # The null value. +ZERO(0 * v:numbermin), ONE(2 - 1), +TWO(1 + 1), THREE(9 / 3), FOUR(1 * 4), +FIVE(1 + 2 + 2), SIX(36 / 3 / 2), SEVEN(7), EIGHT(2 * 2 * 2), +NINE(3 + 3 + 3) +const value: number +def new(value: number) +this.value = value +enddef +endenum +" END_INDENT + " START_INDENT call prop_type_add('indent_after_literal_dict', #{ foo: 'bar' }) call prop_type_delete('indent_after_literal_dict') diff --git a/runtime/indent/testdir/vim.ok b/runtime/indent/testdir/vim.ok index 2ab4f39c0c..03001d525c 100644 --- a/runtime/indent/testdir/vim.ok +++ b/runtime/indent/testdir/vim.ok @@ -940,10 +940,24 @@ endinterface " START_INDENT enum Color White, - Red, - Green, - Blue, - Black + Red, + Green, + Blue, + Black +endenum +" END_INDENT + +" START_INDENT +enum Digits + INVALID(v:numbermax), # The null value. + ZERO(0 * v:numbermin), ONE(2 - 1), + TWO(1 + 1), THREE(9 / 3), FOUR(1 * 4), + FIVE(1 + 2 + 2), SIX(36 / 3 / 2), SEVEN(7), EIGHT(2 * 2 * 2), + NINE(3 + 3 + 3) + const value: number + def new(value: number) + this.value = value + enddef endenum " END_INDENT