runtime(csh): Update ftplugin, improve matchit behaviour

Commit: 
https://github.com/vim/vim/commit/09a48056c775074e0c29aaaf252ccea918f42bbc
Author: Doug Kearns <[email protected]>
Date:   Fri Jan 23 19:07:21 2026 +0000

    runtime(csh): Update ftplugin, improve matchit behaviour
    
    - Allow for an unparenthesised expression argument to the 'if',
      'if-then', and 'while' commands.  This is undocumented, and probably
      unintended, behaviour but is frequently seen in the wild.
    - Allow for a continued-line expression argument to the 'if-then'
      command.
    
    related: #19172 (csh: Support negated if in matchit)
    closes:  #19190
    
    Signed-off-by: Doug Kearns <[email protected]>
    Signed-off-by: Christian Brabandt <[email protected]>

diff --git a/runtime/ftplugin/csh.vim b/runtime/ftplugin/csh.vim
index 6f8201b99..7603d0556 100644
--- a/runtime/ftplugin/csh.vim
+++ b/runtime/ftplugin/csh.vim
@@ -3,9 +3,8 @@
 " Maintainer:          Doug Kearns <[email protected]>
 " Previous Maintainer: Dan Sharp
 " Contributor:         Johannes Zellner <[email protected]>
-" Last Change:         2024 Jan 14
-"                      2024 May 23 by Riley Bruins ('commentstring')
-"                      2026 Jan 15 improved matchit support
+"                      Riley Bruins <[email protected]>
+" Last Change:         2026 Jan 16
 
 if exists("b:did_ftplugin")
   finish
@@ -22,29 +21,52 @@ setlocal formatoptions+=crql
 
 let b:undo_ftplugin = "setlocal com< cms< fo<"
 
-" Csh: thanks to Johannes Zellner
-" - Both foreach and end must appear alone on separate lines.
-" - The words else and endif must appear at the beginning of input lines;
-"   the if must appear alone on its input line or after an else.
-" - Each case label and the default label must appear at the start of a
-"   line.
-" - while and end must appear alone on their input lines.
 if exists("loaded_matchit") && !exists("b:match_words")
-  let s:line_start = '\%(^\s*\)\@<='
-  let b:match_words =
-       \ s:line_start .. 'if\s*!\?\s*(.*)\s*then\>:' ..
-       \   s:line_start .. 'else\s\+if\s*(.*)\s*then\>:' .. s:line_start .. 
'else\>:' ..
-       \   s:line_start .. 'endif\>,' ..
-       \ s:line_start .. '\%(\<foreach\s\+\h\w*\|while\)\s*(:' ..
-       \   '\<break\>:\<continue\>:' ..
-       \   s:line_start .. 'end\>,' ..
-       \ s:line_start .. 'switch\s*(:' ..
-       \   s:line_start .. 'case\s\+:' .. s:line_start .. 
'default\>:\<breaksw\>:' ..
-       \   s:line_start .. 'endsw\>'
-  unlet s:line_start
-  let b:undo_ftplugin ..= " | unlet! b:match_words"
+  let b:match_ignorecase = 0
+  let b:match_words = "CshMatchWords()"
+  let b:match_skip = "CshMatchSkip()"
+  let b:undo_ftplugin ..= " | unlet! b:match_ignorecase b:match_skip 
b:match_words"
 endif
 
+" skip single line 'if' commands
+function CshMatchSkip()
+  return getline(".") =~# '^\s*if\>' && !s:CshIsIfThenCommand()
+endfunction
+
+function CshMatchWords()
+  let line_start = '\%(^\s*\)\@<='
+  let match_words =
+       \ line_start .. '\%(foreach\s\+\h\w*\s*(\|while\>\):' ..
+       \   '\<break\>:\<continue\>:' ..
+       \   line_start .. 'end\>,' ..
+       \ line_start .. 'switch\s*(:' ..
+       \   line_start .. 'case\s\+:' .. line_start .. 'default\>:\<breaksw\>:' 
..
+       \   line_start .. 'endsw\>'
+
+  if expand("<cword>") =~# '\<if\>' && !s:CshIsIfThenCommand()
+    return match_words
+  else
+    return match_words .. "," ..
+       \ line_start .. 'if\>:' ..
+       \   line_start .. 'else\s\+if\>:' .. line_start .. 'else\>:' ..
+       \   line_start .. 'endif\>'
+  endif
+endfunction
+
+function s:CshIsIfThenCommand()
+  let lnum = line(".")
+  let line = getline(lnum)
+
+  " join continued lines
+  while lnum < line("$") && line =~ '^\%([^\]\|\\\)*\$'
+    let lnum += 1
+    let line = substitute(line, '\$', '', '') .. getline(lnum)
+  endwhile
+
+  " TODO: confirm with syntax checks when the highlighting is more accurate
+  return line =~# '^\s*if\>.*\<then\s*\%(#.*\)\=$'
+endfunction
+
 if (has("gui_win32") || has("gui_gtk")) && !exists("b:browsefilter")
   let b:browsefilter = "csh Scripts (*.csh)    *.csh
"
   if has("win32")

-- 
-- 
You received this message from the "vim_dev" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php

--- 
You received this message because you are subscribed to the Google Groups 
"vim_dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
To view this discussion visit 
https://groups.google.com/d/msgid/vim_dev/E1vjMcc-00AFyx-Kz%40256bit.org.

Raspunde prin e-mail lui