]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
runtime(comment): consider &tabstop in lines after whitespace indent
authorKonfekt <Konfekt@users.noreply.github.com>
Sat, 5 Oct 2024 14:17:04 +0000 (16:17 +0200)
committerChristian Brabandt <cb@256bit.org>
Sat, 5 Oct 2024 14:19:40 +0000 (16:19 +0200)
The count `strlen()` in

```vim
line = printf(indent_start .. substitute(cms, '%s\@!', '%%', 'g'),
                       strpart(getline(lnum), strlen(indent_start)))
```

is too large if the block of lines to be operated on contains different
whitespace indenting (tab vs. spaces).

Considering using `2gcc` on the first line with 4 spaces as indenting
and on the next line using a single tab character (with &tabstop value
of 8):

Using `strlen(indent_start) = 4` for an initial indent of 4 spaces is
correct for the first line, but wrong for the next line and will
therefore wrongly comment out the tab-indented line (and possibly
deleting some content).

The new check is still too simple because it assumes that as soon as
there's a tab the whole indent is made of tabs; it's a start of entering
the mixed tab and whitespace indent rabbit hole.

fixes: #15797
closes: #15805

Signed-off-by: Konfekt <Konfekt@users.noreply.github.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
runtime/pack/dist/opt/comment/autoload/comment.vim

index c758a7d40323d3b72bba0aa8532460cbe3947cbd..d78b69b2a3ae92c1472be4d55459f7a7d29e247c 100644 (file)
@@ -1,7 +1,7 @@
 vim9script
 
 # Maintainer: Maxim Kim <habamax@gmail.com>
-# Last Update: 2024-09-30
+# Last Update: 2024 Oct 05
 #
 # Toggle comments
 # Usage:
@@ -58,9 +58,13 @@ export def Toggle(...args: list<string>): string
                 # handle % with substitute
                 line = printf(substitute(cms, '%s\@!', '%%', 'g'), getline(lnum))
             else
-                # handle % with substitute
+                line = getline(lnum)
+                var indent_start_len = strlen(indent_start)
+                # handle % with substitute,
+                # consider different whitespace indenting
                 line = printf(indent_start .. substitute(cms, '%s\@!', '%%', 'g'),
-                        strpart(getline(lnum), strlen(indent_start)))
+                    strpart(line, (line[0 : strlen(indent_start_len) - 1] =~ '\t' ?
+                    indent_start_len / &tabstop : indent_start_len)))
             endif
         else
             line = substitute(getline(lnum), $'^\s*\zs{cms_l[0]} \?\| \?{cms_l[1]}$', '', 'g')