]> git.ipfire.org Git - thirdparty/vim.git/log
thirdparty/vim.git
8 weeks agopatch 9.2.0325: runtime(tar): bug in zstd handling v9.2.0325
Aaron Burrow [Thu, 9 Apr 2026 19:06:13 +0000 (19:06 +0000)] 
patch 9.2.0325: runtime(tar): bug in zstd handling

Problem:  patch 9.2.0325: runtime(tar): bug in zstd handling
Solution: use correct --zstd argument, separated from other arguments,
          rework testing framework (Aaron Burrow).

The tar.vim plugin allows vim to read and manipulate zstd archives,
but it had a bug that caused extraction attempts to fail.
Specifically, if the archive has a .tar.zst or .tzst extension, then
the code was generating invalid extraction commands that looked like
this:

  tar --zstdpxf foo.tar.zst foo

When they should be like this:

  tar --zstd -pxf foo.tar.zst foo

This patch changes the flag manipulation logic so that --zstd isn't
glued to pxf.

The labor for this change was divided between ChatGPT 5.4 and me.
ChatGPT 5.4 identified the issue (from a code scan?), and I wrote
the patch and tested vim.

related: #19930

Signed-off-by: Aaron Burrow <burrows@fastmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agopatch 9.2.0324: 0x9b byte not unescaped in <Cmd> mapping v9.2.0324
zeertzjq [Thu, 9 Apr 2026 18:55:02 +0000 (18:55 +0000)] 
patch 9.2.0324: 0x9b byte not unescaped in <Cmd> mapping

Problem:  0x9b byte not unescaped in <Cmd> mapping (BenYip).
Solution: Translate K_CSI to CSI like what is done in vgetc().
          (zeertzjq).

fixes:  #19936
closes: #19937

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agoruntime(doc): Tweak documentation style a bit
Hirohito Higashi [Thu, 9 Apr 2026 18:49:43 +0000 (18:49 +0000)] 
runtime(doc): Tweak documentation style a bit

closes: #19939

Signed-off-by: Hirohito Higashi <h.east.727@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agoruntime(org): Link to generic bold/Italic highlighting groups
Maxim Kim [Thu, 9 Apr 2026 18:41:47 +0000 (18:41 +0000)] 
runtime(org): Link to generic bold/Italic highlighting groups

fixes: #19933

Signed-off-by: Maxim Kim <habamax@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agoruntime(help): support highlighting groups in translated syntax doc
Hirohito Higashi [Thu, 9 Apr 2026 18:38:35 +0000 (18:38 +0000)] 
runtime(help): support highlighting groups in translated syntax doc

closes: #19942

Signed-off-by: Hirohito Higashi <h.east.727@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agoruntime(vimball): detect more path traversal attacks
Christian Brabandt [Thu, 9 Apr 2026 18:35:39 +0000 (18:35 +0000)] 
runtime(vimball): detect more path traversal attacks

Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agopatch 9.2.0323: filetype: buf.lock files are not recognized v9.2.0323
Stefan VanBuren [Wed, 8 Apr 2026 18:28:08 +0000 (18:28 +0000)] 
patch 9.2.0323: filetype: buf.lock files are not recognized

Problem:  filetype: buf.lock files are not recognized
Solution: Detect buf.lock files as yaml filetype
          (Stefan VanBuren)

Reference:
https://buf.build/docs/configuration/v2/buf-lock/

closes: #19935

Signed-off-by: Stefan VanBuren <svanburen@buf.build>
Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agopatch 9.2.0322: tests: test_popupwin fails v9.2.0322
Yasuhiro Matsumoto [Wed, 8 Apr 2026 18:18:53 +0000 (18:18 +0000)] 
patch 9.2.0322: tests: test_popupwin fails

Problem:  tests: test_popupwin fails (after v9.2.0319)
Solution: Regenerate the dump file (Yasuhiro Matsumoto).

The reference dump for Test_popupwin_opacity_wide_2 was not updated
when patch 9.2.0319 changed the blending behavior for double-width
characters at popup padding boundaries. The covered half of a
double-width character now correctly shows a space instead of the
full character.

related: #19881
closes:  #19934

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agopatch 9.2.0321: MS-Windows: No OpenType font support v9.2.0321
Yasuhiro Matsumoto [Tue, 7 Apr 2026 21:07:46 +0000 (21:07 +0000)] 
patch 9.2.0321: MS-Windows: No OpenType font support

Problem:  MS-Windows: No OpenType font support
Solution: Allow specifying OpenType font features directly in 'guifont'
          (Yasuhiro Matsumoto).

Allow specifying OpenType font features directly in 'guifont' using
the ':f' option (e.g., :set guifont=Cascadia_Code:h14:fss19=1:fcalt=0).
Each ':fXXXX=N' sets a single OpenType feature tag with a parameter
value.  Multiple features can be specified by repeating the ':f' option.

This only takes effect when 'renderoptions' is set to use DirectWrite
(type:directx).  Default features (calt, liga, clig, rlig, kern) are
preserved unless explicitly overridden.

closes: #19857

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agopatch 9.2.0320: several bugs with text properties v9.2.0320
Hirohito Higashi [Tue, 7 Apr 2026 20:46:10 +0000 (20:46 +0000)] 
patch 9.2.0320: several bugs with text properties

Problem:  several bugs with text properties
Solution: Fix the bugs, rework the text properties work

related: #19685
fixes:   #19680
fixes:   #19681
fixes:   #12568
fixes:   #19256
closes:  #19869

Co-Authored-By: Paul Ollis <paul@cleversheep.org>
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Signed-off-by: Hirohito Higashi <h.east.727@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agopatch 9.2.0319: popup: rendering issues with partially transparent popups v9.2.0319
Yasuhiro Matsumoto [Tue, 7 Apr 2026 20:26:17 +0000 (20:26 +0000)] 
patch 9.2.0319: popup: rendering issues with partially transparent popups

Problem:  popup: rendering issues with partially transparent popups.
Solution: Redraw the area under the old popup position on move or
          resize. Apply the background blend only to the covered half of
          a double-width character. (Yasuhiro Matsumoto)

closes: #19881

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agopatch 9.2.0318: cannot configure opacity for popup menu v9.2.0318
Yasuhiro Matsumoto [Tue, 7 Apr 2026 19:51:20 +0000 (19:51 +0000)] 
patch 9.2.0318: cannot configure opacity for popup menu

Problem:  cannot configure opacity for popup menu
Solution: Add the 'pumopt' option, consolidate existing pum options into
          the pumopt option (Yasuhiro Matsumoto)

closes: #19931

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agoruntime(doc): document gitcommit_summary_length
Christian Brabandt [Tue, 7 Apr 2026 19:37:14 +0000 (19:37 +0000)] 
runtime(doc): document gitcommit_summary_length

related: #19905

Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agoruntime(bitbake): Update syntax script
Antonin Godard [Tue, 7 Apr 2026 19:28:27 +0000 (19:28 +0000)] 
runtime(bitbake): Update syntax script

1) add syntax for include_all

The include_all directive was introduced in [1]. It uses the same syntax
as include or require, taking one or more paths as argument.

2) add syntax for inherit_defer

The inherit_defer directive was introduced in [2]. It uses the same syntax
as inherit, taking one or more class name as argument.

3) add syntax for addpylib

The addpylib directive was introduced in [3]. It uses a syntax similar
to addtask or addhandler, taking a directory and python namespace as
argument.

[1]: https://git.openembedded.org/bitbake/commit/?id=d01d5593e7829ac60f37bc23cb87dc6917026471
[2]: https://git.openembedded.org/bitbake/commit/?id=5c2e840eafeba1f0f754c226b87bfb674f7bea29
[3]: https://git.openembedded.org/bitbake/commit/?id=afb8478d3853f6edf3669b93588314627d617d6b

Signed-off-by: Antonin Godard <antonin@godard.cc>
Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agopatch 9.2.0317: listener functions do not check secure flag v9.2.0317
Christian Brabandt [Tue, 7 Apr 2026 18:57:04 +0000 (18:57 +0000)] 
patch 9.2.0317: listener functions do not check secure flag

Problem:  listener functions do not check secure flag
          (syndicate)
Solution: Call check_secure()

Signed-off-by: Christian Brabandt <cb@256bit.org>
8 weeks agopatch 9.2.0316: [security]: command injection in netbeans interface via defineAnnoType v9.2.0316
Christian Brabandt [Tue, 7 Apr 2026 17:32:02 +0000 (17:32 +0000)] 
patch 9.2.0316: [security]: command injection in netbeans interface via defineAnnoType

Problem:  [security]: The netbeans defineAnnoType command passes typeName, fg and bg
          unsanitized to coloncmd(), allowing a malicious server to inject
          arbitrary Ex commands via '|'. Similarly, specialKeys does not
          validate key tokens before building a map command.
Solution: Validate typeName, fg and bg against an allowlist of safe
          characters before passing them to coloncmd()

Github Advisory:
https://github.com/vim/vim/security/advisories/GHSA-mr87-rhgv-7pw6

Supported by AI

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(doc): clarify incsearch feature and typed chars
Christian Brabandt [Mon, 6 Apr 2026 14:01:20 +0000 (14:01 +0000)] 
runtime(doc): clarify incsearch feature and typed chars

fixes: #19886

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0315: missing bound-checks v9.2.0315
Yasuhiro Matsumoto [Mon, 6 Apr 2026 13:53:31 +0000 (13:53 +0000)] 
patch 9.2.0315: missing bound-checks

Problem:  missing bound-checks
Solution: Add defensive guards against potential buffer overflow
          (Yasuhiro Matsumoto)

Add bounds checking and integer overflow guards across multiple files
as a defensive measure. While these code paths are unlikely to be
exploitable in practice, the guards prevent undefined behavior in
edge cases.

- libvterm/vterm.c: use heap tmpbuffer instead of stack buffer in
  vsprintf() fallback path
- channel.c: validate len in channel_consume() before mch_memmove()
- spell.c: use long instead of int for addlen to avoid signed overflow
  in size_t subtraction
- alloc.c: add SIZE_MAX overflow check in ga_grow_inner() before
  itemsize multiplication
- list.c: add overflow check before count * sizeof(listitem_T)
- popupwin.c: add overflow check before width * height allocation
- insexpand.c: add overflow check before compl_num_bests multiplication
- regexp_bt.c: replace sprintf() with vim_snprintf() in regprop()
- spellfile.c: use SIZE_MAX instead of LONG_MAX for allocation overflow
  check

closes: #19904

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0314: channel: can bind to all network interfaces v9.2.0314
Zdenek Dohnal [Mon, 6 Apr 2026 13:42:42 +0000 (13:42 +0000)] 
patch 9.2.0314: channel: can bind to all network interfaces

Problem:  channel: can bind to all network interfaces in ch_listen()
          (after v9.2.0153)
Solution: Restrict to a valid hostname, do not allow to bind on all
          network interfaces (Zdenek Dohnal).

This will prevent unintentional binding the process to public network
interfaces, and opening Vim to communication from outside network if
firewall allows it.

related: #19231
closes:  #19799

Signed-off-by: Zdenek Dohnal <zdohnal@redhat.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0313: Callback channel not registered in GUI v9.2.0313
Foxe Chen [Mon, 6 Apr 2026 13:35:27 +0000 (13:35 +0000)] 
patch 9.2.0313: Callback channel not registered in GUI

Problem:  Callback channel not registered in GUI
Solution: Call channel_gui_register_one() in GUI mode
          (Foxe Chen).

closes: #19858

Signed-off-by: Foxe Chen <chen.foxe@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0312: C-type names are marked as translatable v9.2.0312
Eisuke Kawashima [Mon, 6 Apr 2026 13:27:31 +0000 (13:27 +0000)] 
patch 9.2.0312: C-type names are marked as translatable

Problem:  C-type names are marked as translatable
Solution: Use them as-is, do not translate them
          (Eisuke Kawashima)

closes: #19861

Signed-off-by: Eisuke Kawashima <e-kwsm@users.noreply.github.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0311: redrawing logic with text properties can be improved v9.2.0311
Yasuhiro Matsumoto [Mon, 6 Apr 2026 13:19:04 +0000 (13:19 +0000)] 
patch 9.2.0311: redrawing logic with text properties can be improved

Problem:  redrawing logic with text properties can be improved in
          win_line()
Solution: Avoid repeated sorts, use stack storage for small
          properties, pre-compute whether trailing virtual text follows
          (Yasuhiro Matsumoto)

closes: #19880

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0310: unnecessary work in vim_strchr() and find_term_bykeys() v9.2.0310
Yasuhiro Matsumoto [Mon, 6 Apr 2026 13:12:39 +0000 (13:12 +0000)] 
patch 9.2.0310: unnecessary work in vim_strchr() and find_term_bykeys()

problem:  unnecessary work in vim_strchr() and find_term_bykeys()
Solution: Redirect vim_strchr() to vim_strbyte() for ASCII input
          Add an early exit to find_term_bykeys() using the terminal
          leader table, mirroring check_termcode(). Reduces instruction
          count on startup by about 27%. (Yasuhiro Matsumoto)

closes: #19902

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0309: Missing out-of-memory check to may_get_cmd_block() v9.2.0309
John Marriott [Mon, 6 Apr 2026 13:07:31 +0000 (13:07 +0000)] 
patch 9.2.0309: Missing out-of-memory check to may_get_cmd_block()

Problem:  Missing out-of-memory check to may_get_cmd_block()
Solution: Return p unchanged in case of out-of-memory (John Marriott)

closes: #19906

Signed-off-by: John Marriott <basilisk@internode.on.net>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(log): clean up and modernize log syntax
Mao-Yining [Mon, 6 Apr 2026 13:02:04 +0000 (13:02 +0000)] 
runtime(log): clean up and modernize log syntax

- Rename groups to consistent log* naming (LogString→logString, etc.)
- Remove redundant logOperator/logBrackets, use logSymbol for special chars
- Simplify level keywords by removing case variants
- Consolidate syslog column patterns into logSysColumn
- Move custom highlights to portable ctermfg/guifg names
- Update maintainer email address

closes: #19917

Signed-off-by: Mao-Yining <mao.yining@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0308: Error message E1547 is wrong v9.2.0308
Mao-Yining [Mon, 6 Apr 2026 12:54:33 +0000 (12:54 +0000)] 
patch 9.2.0308: Error message E1547 is wrong

Problem:  Error message E1547 is wrong
Solution: Fix error message, re-generate Chinese translations
          (Mao-Yining).

closes: #19920

Signed-off-by: Mao-Yining <mao.yining@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0307: more mismatches between return types and documentation v9.2.0307
Hirohito Higashi [Mon, 6 Apr 2026 12:49:53 +0000 (12:49 +0000)] 
patch 9.2.0307: more mismatches between return types and documentation

Problem:  more mismatches between return types and documentation
Solution: Update documentation, fix return type for remote_foreground()
          and test_mswin_event() (Hirohito Higashi)

Doc summary table fixes:
- ch_info: String -> Dict
- spellbadword: String -> List
- undotree: List -> Dict
- test_getvalue: any -> Number
- instanceof, popup_filter_menu, popup_filter_yesno: Number -> Bool
- remote_foreground: Number -> none
- test_mswin_event: bool -> Bool

evalfunc.c fixes:
- remote_foreground: ret_string -> ret_void
- test_mswin_event: ret_number -> ret_bool

Detail "Return type:" fixes:
- instanceof: Number -> vim9-boolean
- remote_foreground: Number -> void
- popup_filter_menu, popup_filter_yesno: Number -> vim9-boolean

related: #19922
closes:  #19923

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Signed-off-by: Hirohito Higashi <h.east.727@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0306: runtime(tar): some issues with lz4 support v9.2.0306
Aaron Burrow [Mon, 6 Apr 2026 12:46:40 +0000 (12:46 +0000)] 
patch 9.2.0306: runtime(tar): some issues with lz4 support

Problem:  runtime(tar): some issues with lz4 support
Solution: Fix bugs (see below) (Aaron Burrow)

The tar plugin allows users to extract files from tar archives that are
compressed with lz4. But, tar#Extract() builds malformed extraction commands
for lz4-compressed tar archives. This commit fixes three issues in that code.
The first affects archives with a .tlz4 extension and the other two affect
archives with .tar.lz4 extension (but one of these is symmetric to the issue
that .tlz4 archives had).

(1) When trying to extract .tlz4 archives the command created by
tar#Extract looked like this:

    tar -I lz4pxf foo.tlz4 foo

This isn't right.  It should be something like this:

    tar -I lz4 -pxf foo.tlz4 foo

This was happening because tar.plugin is just substituting on the
first - in "tar -pxf".  This works fine if we just add a simple flag for
extraction (eg, z for .tgz), but for lz4 we need to add "-I lz4".

I don't believe that there is an obvious good way to fix this without
reworking the way the command is generated.  Probably we should collect
the command and flags separately and the flags should be stored in a
set. Then put everything together into a string just before issuing it
as an extraction command.  Unfortunately, this might break things for users
because they have access to tar_extractcmd.

This patch just makes the substitution a little bit more clever so that it
does the right thing when substituting on a string like "tar -pxf".

(2) .tar.lz4 extractions had the same issue, which my patch fixes in
the same way.

(3) .tar.lz4 extractions had another issue.  There was a space missing
in the command generated by tar#Extract.  This meant that commands
looked like this (notice the lack of space between the archive and output
file names):

    tar -I lz4pxf foo.tar.lz4foo

This patch just puts a space where it should be.

Finally, I should note that ChatGPT 5.4 initially identified this issue
in the code and generated the test cases.  I reviewed the test cases,
wrote the patch, and actually ran vim against the tests (both with and
without the patch).

closes: #19925

Signed-off-by: Aaron Burrow <burrows@fastmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(vim9): Fix dist#vim9#Open() spaced paths and SIGPIPE crashes
Furkan Sahin [Mon, 6 Apr 2026 12:43:07 +0000 (12:43 +0000)] 
runtime(vim9): Fix dist#vim9#Open() spaced paths and SIGPIPE crashes

Problem:    dist#vim9#Open() fails to open files with spaces on Linux
            because Launch() splits the command string. Also,
            background GUI viewers (e.g., xdg-open) crash with SIGPIPE
            when Vim destroys the default job_start() IO pipes.
Solution:   Use job_start() with 'sh -c' to let the POSIX shell parse
            the shellescaped quotes safely. Set 'in_io', 'out_io', and
            'err_io' to 'null' to completely detach the background
            process and prevent pipe crashes. Unify the Launch()
            execution block across all operating systems.

closes: #19928
fixes:  #19916

Signed-off-by: Furkan Sahin <furkan-dev@proton.me>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0305: mismatch between return types and documentation v9.2.0305
Hirohito Higashi [Sun, 5 Apr 2026 16:53:52 +0000 (16:53 +0000)] 
patch 9.2.0305: mismatch between return types and documentation

Problem:  mismatch between return types and documentation
Solution: Fix documentation, update f_err_teapot() return type to void
          (Hirohito Higashi)

- Fix summary table in builtin.txt: feedkeys, foreground, setcharsearch,
  term_wait, test_void, wildtrigger, ch_sendraw from non-none to none;
  listener_remove and prop_add from none to Number
- Fix err_teapot in evalfunc.c: ret_number_bool to ret_void
- Fix "Return type:" in detailed doc sections (64 functions across builtin.txt,
  channel.txt, terminal.txt, popup.txt, testing.txt, textprop.txt) from wrong
  types to void
- Add missing "Return type: void" for prompt_setcallback and prop_add_list

closes: #19922

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Signed-off-by: Hirohito Higashi <h.east.727@gmail.com>
Signed-off-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0304: tests: test for 9.2.0285 doesn't always fail without the fix v9.2.0304
zeertzjq [Sun, 5 Apr 2026 16:45:29 +0000 (16:45 +0000)] 
patch 9.2.0304: tests: test for 9.2.0285 doesn't always fail without the fix

Problem:  When the terminal is very large, test for 9.2.0285 doesn't
          trigger an ASAN error without the fix.
Solution: Use a window with fixed height (zeertzjq)

closes: #19924

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0303: tests: zip plugin tests don't check for warning message properly v9.2.0303
zeertzjq [Sun, 5 Apr 2026 16:41:15 +0000 (16:41 +0000)] 
patch 9.2.0303: tests: zip plugin tests don't check for warning message properly

Problem:  zip plugin tests may match messages from previous test cases
          when checking for warning message.
Solution: Clear messages at the start of these tests (zeertzjq).

closes: #19926

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0302: runtime(netrw): RFC2396 decoding double escaping spaces v9.2.0302
Christian Brabandt [Sun, 5 Apr 2026 16:34:24 +0000 (16:34 +0000)] 
patch 9.2.0302: runtime(netrw): RFC2396 decoding double escaping spaces

Problem:  runtime(netrw): RFC2396 decoding double escaping spaces
          (lilydjwg, after 3e60f03d942d6bb0f7eac)
Solution: Remove escape() call, since we are using fnameescape() anyhow

fixes: #19913

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0301: Vim9: void function return value inconsistent v9.2.0301
Hirohito Higashi [Sun, 5 Apr 2026 16:17:58 +0000 (16:17 +0000)] 
patch 9.2.0301: Vim9: void function return value inconsistent

Problem:  Vim9: void function return value inconsistent between
          script and :def
Solution: Make void built-in functions like bufload() return void
          consistently (Hirohito Higashi)

In Vim9 script, calling a void built-in function (e.g. bufload()) at the
script level did not set rettv to VAR_VOID, making it appear to return
0. Inside :def it correctly returned VAR_VOID and raised E1031.  Set
rettv to VAR_VOID after calling a ret_void built-in function in Vim9
script so the behavior is consistent.

Also fix the documentation for bufload() and ch_logfile() to correctly
state that the return type is void.

closes: #19919

Signed-off-by: Hirohito Higashi <h.east.727@gmail.com>
Signed-off-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0300: The vimball plugin needs some love v9.2.0300
Christian Brabandt [Sun, 5 Apr 2026 16:08:12 +0000 (16:08 +0000)] 
patch 9.2.0300: The vimball plugin needs some love

Problem:  The vimball plugin needs some love
          (syndicate)
Solution: Clean-up, refactor and update the plugin,
          in particular, catch path traversal attacks

This change does the following
- Clean up Indentation and remove calls to Decho
- Increase minimum Vim version to 7.4 for mkdir()
- Use mkdir() consistently
- Update Metadata Header
- Remove check for fnameescape()
- Catch path traversal attacks
- Add vimball basic tests
- Remove mentioning of g:vimball_mkdir in documentation

closes: #19921

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0299: runtime(zip): may write using absolute paths v9.2.0299
Christian Brabandt [Sun, 5 Apr 2026 15:58:00 +0000 (15:58 +0000)] 
patch 9.2.0299: runtime(zip): may write using absolute paths

Problem:  runtime(zip): may write using absolute paths
          (syndicate)
Solution: Detect this case and abort on Unix, warn in the documentation
          about possible issues

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(zathurarc): Update page-padding, wrap the zathurarcOption keywords
Carlo Klapproth [Sat, 4 Apr 2026 09:22:50 +0000 (09:22 +0000)] 
runtime(zathurarc): Update page-padding, wrap the zathurarcOption keywords

page-padding was split in page-v-padding and page-h-padding

closes: #19899

Signed-off-by: Carlo Klapproth <6682561+elcarlosIII@users.noreply.github.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0298: Some internal variables are not modified v9.2.0298
Hirohito Higashi [Sat, 4 Apr 2026 09:09:13 +0000 (09:09 +0000)] 
patch 9.2.0298: Some internal variables are not modified

Problem:  Some internal variables are not modified
Solution: Add const qualifier to static table data
          (Hirohito Higashi).

Several static arrays that are never modified at runtime were missing the
const qualifier. Add const to move them from .data to .rodata section.

closes: #19901

Signed-off-by: Hirohito Higashi <h.east.727@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0297: libvterm: can improve CSI overflow code v9.2.0297
Yasuhiro Matsumoto [Sat, 4 Apr 2026 09:04:34 +0000 (09:04 +0000)] 
patch 9.2.0297: libvterm: can improve CSI overflow code

Problem:  libvterm: can improve CSI overflow code
Solution: Handle overflow cases better (Yasuhiro Matsumoto)

closes: #19903

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0296: Redundant and incorrect integer pointer casts in drawline.c v9.2.0296
zeertzjq [Sat, 4 Apr 2026 08:55:59 +0000 (08:55 +0000)] 
patch 9.2.0296: Redundant and incorrect integer pointer casts in drawline.c

Problem:  Currently `colnr_T` and `int` and the same type, so casting
          `int *` to `colnr_T *` is redundant. Additionally, even if
          they are changed to different types in the future, these casts
          are incorrect as they won't work on big-endian platforms.
Solution: Remove the casts. Also fix two cases of passing false instead
          of 0 to an integer argument (zeertzjq).

related: #19672
closes:  #19907

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0295: 'showcmd' shows wrong Visual block size with 'linebreak' v9.2.0295
zeertzjq [Sat, 4 Apr 2026 08:50:46 +0000 (08:50 +0000)] 
patch 9.2.0295: 'showcmd' shows wrong Visual block size with 'linebreak'

Problem:  'showcmd' shows wrong Visual block size with 'linebreak' after
          end char (after 7.4.467).
Solution: Exclude 'linebreak' from end position. Also fix confusing test
          function names.

closes: #19908

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0294: if_lua: lua interface does not work with lua 5.5 v9.2.0294
Yee Cheng Chin [Sat, 4 Apr 2026 08:37:47 +0000 (08:37 +0000)] 
patch 9.2.0294: if_lua: lua interface does not work with lua 5.5

Problem:  if_lua: lua interface does not work with lua 5.5
          (Lyderic Landry)
Solution: Use the new lua API `luaL_openselectedlibs()`
          (Yee Cheng Chin)

Lua 5.5 removed the API function `openlibs` with `openselectedlibs`,
with `luaL_openlibs` replaced by a macro that just calls the new
`luaL_openselectedlibs` in the headers (see lua/lua@d738c8d18). This
broke Vim's dynamic Lua build as we try to redefine `luaL_openlibs`
ourselves and also this function can no longer be loaded from the lib.
Update the code to use the new API call instead to fix the issue.

fixes:  #19814
closes: #19842
closes: #19909

Signed-off-by: Yee Cheng Chin <ychin.git@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoCI: Bump codecov/codecov-action
dependabot[bot] [Sat, 4 Apr 2026 08:35:52 +0000 (08:35 +0000)] 
CI: Bump codecov/codecov-action

Bumps the github-actions group with 1 update in the / directory: [codecov/codecov-action](https://github.com/codecov/codecov-action).

Updates `codecov/codecov-action` from 5 to 6
- [Release notes](https://github.com/codecov/codecov-action/releases)
- [Changelog](https://github.com/codecov/codecov-action/blob/main/CHANGELOG.md)
- [Commits](https://github.com/codecov/codecov-action/compare/v5...v6)

---
updated-dependencies:
- dependency-name: codecov/codecov-action
  dependency-version: '6'
  dependency-type: direct:production
  update-type: version-update:semver-major
  dependency-group: github-actions
...

closes: #19910

Signed-off-by: dependabot[bot] <support@github.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0293: :packadd may lead to heap-buffer-overflow v9.2.0293
zeertzjq [Sat, 4 Apr 2026 08:32:33 +0000 (08:32 +0000)] 
patch 9.2.0293: :packadd may lead to heap-buffer-overflow

Problem:  :packadd may lead to heap-buffer-overflow when all entries in
          'runtimepath' have the same length (after 9.2.0291).
Solution: Check for comma after current entry properly (zeertzjq).

related: #19854
closes:  #19911

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0292: E340 internal error when using method call on void value v9.2.0292
Hirohito Higashi [Sat, 4 Apr 2026 08:27:46 +0000 (08:27 +0000)] 
patch 9.2.0292: E340 internal error when using method call on void value

Problem:  E340 internal error when using method call on void value
          (Peter Kenny)
Solution: Check for void value (Hirohito Higashi)

Using a method call on a void return value (e.g. "echo F()->empty()"
where F() returns void) caused an internal error E340. Now it properly
reports E1031 or E1186 depending on the context.

Changes:
- eval.c: check for void value before -> method call at runtime
- vim9expr.c: check for void type before -> method call at compile time
- vim9execute.c: check for void value in builtin function arguments and in
  ISN_STORE

fixes:  #19897
closes: #19912

Signed-off-by: Hirohito Higashi <h.east.727@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0291: too many strlen() calls v9.2.0291
John Marriott [Fri, 3 Apr 2026 15:08:48 +0000 (15:08 +0000)] 
patch 9.2.0291: too many strlen() calls

Problem:  too many strlen() calls
Solution: refactor concat_fname() and remove calls to strlen()
          (John Marriott)

Function `concat_fnames()` can make up to 5 calls to `STRLEN()` (either
directly or indirectly via `STRCAT()`). In many cases the lengths of
arguments `fname1` and/or `fname2` are either known or can simply be
calculated.

This Commit refactors this function to accept the lengths of arguments
`fname1` and `fname2` as arguments. It also adds new argument `ret` to
return the resulting string as a `string_T`.

Additionally:
- function `add_pack_dir_to_rtp()` in `scriptfile.c`:
   Use a `string_T` to store local variables `new_rtp` and `afterdir`.
   Replace calls to `STRCAT()` with calls to `STRCPY()`.
   Change type of variable `keep` to `size_t` for consistency with
   other lengths.

- function `qf_get_fnum()` in `quickfix.c`:
  Use a `string_T` to store local variables `ptr` and `bufname`
- function `qf_push_dir()` in `quickfix.c`:
  Use a `string_T` to store local variable `dirname`.
  Replace call to `vim_strsave()` with `vim_strnsave()`.

- function `qf_guess_filepath()` in `quickfix.c`:
  Use a `string_T` to store local variable `fullname`.

- function `make_percent_swname()` in `memline.c`:
  Rename some variables to better reflect their use.
  Use a `string_T` to store local variables `d` and `fixed_name`.
  Slightly refactor to remove need to create an extra string.
- function `get_file_in_dir()` in `memline.c`:
  Use a `string_T` to store local variables `tail` and `retval`.
  Move some variables closer to where they are used.

- function `cs_resolve_file()` in `if_cscope.c`:
  Use a `string_T` to store local variable `csdir`.
  Remove one call to `STRLEN()`.

- function `add_pathsep()` in `filepath.c`:
  Refactor and remove 1 call to `STRLEN()`

- function `set_init_xdg_rtp()` in `option.c`:
  Use a `string_T` to store local variable `vimrc_xdg`.

closes: #19854

Co-authored-by: Christian Brabandt <cb@256bit.org>
Signed-off-by: John Marriott <basilisk@internode.on.net>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0290: Amiga: no support for AmigaOS 3.x v9.2.0290
Duncan Bowring [Fri, 3 Apr 2026 14:50:07 +0000 (14:50 +0000)] 
patch 9.2.0290: Amiga: no support for AmigaOS 3.x

Problem:  Amiga: no support for AmigaOS 3.x
Solution: Add support for building Vim on classic AmigaOS 3.x with the
          bebbo cross-compiler and libnix (-noixemul) runtime
          (Duncan Bowring).

The existing Make_ami.mak targets AmigaOS 4 (clib2), AROS, and MorphOS.
This patch adds a fourth target for classic 68k AmigaOS 3.x systems
(A1200, A4000, accelerated A500/A2000) using:
```
  make -f Make_ami.mak UNM=AmigaOS3 BUILD=normal
```

Changes:

os_amiga.c:
- Add 256 KiB __stack cookie for OS3 (conservative for limited RAM)
- Add safe_Lock() wrapper to suppress "Please insert volume" system
  requesters during path probing (benefits all Amiga targets)
- Suppress system requesters globally in mch_init() via pr_WindowPtr=-1
  (Vim probes many paths at startup; Lock()/Open() on non-existent
  volume names triggers blocking system requesters)
- Fix mch_get_host_name() for OS3 (libnix has no gethostname)
- Fix Delay() prototype for non-LATTICE compilers
- Fix nilfh file handle leak on error exit in mch_check_win()

os_amiga.h:
- Add fchown/fchmod/ftruncate no-op stubs for OS3/libnix

os_amiga_stubs.c (new):
- IM function stubs (referenced by optiondefs.h, no X11 on Amiga)
- mch_rmdir() via AmigaDOS DeleteFile()
- getpwuid()/getgrgid()/getuid() stubs (single-user system)

Make_ami.mak:
- Add AmigaOS3 target with -noixemul, -std=gnu99, -DWORDS_BIGENDIAN

blowfish.c:
- Accept WORDS_BIGENDIAN or AMIGA without requiring HAVE_CONFIG_H

xdiff/xmacros.h:
- Make SIZE_MAX fallback unconditional (not just hpux/VMS)

All OS3-specific changes are guarded by:
  #if defined(__GNUC__) && defined(AMIGA) && !defined(__amigaos4__)

Tested on FS-UAE with Workbench 3.1: 23 automated tests passing.
Binary size: 2.2 MiB with -Os -m68020 -DFEAT_NORMAL.

This is the first modern Vim build for classic 68k AmigaOS since
Vim 5.8 circa 1998.  Vim was originally released on the Amiga
(Fred Fish Disk 591, 1991).

closes: #19840

Signed-off-by: Duncan Bowring <duncan@bowring.us>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0289: 'linebreak' may lead to wrong Visual block highlighting v9.2.0289
zeertzjq [Fri, 3 Apr 2026 09:48:49 +0000 (09:48 +0000)] 
patch 9.2.0289: 'linebreak' may lead to wrong Visual block highlighting

Problem:  'linebreak' may lead to wrong Visual block highlighting when
          end char occupies multiple cells (after 7.4.467).
Solution: Exclude 'linebreak' from the ending column instead of setting
          'virtualedit' temporarily (zeertzjq).

fixes:  #19898
closes: #19900

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(doc): adjust :h 'autowrite' and :h 'autowriteall'
zeertzjq [Fri, 3 Apr 2026 09:40:23 +0000 (09:40 +0000)] 
runtime(doc): adjust :h 'autowrite' and :h 'autowriteall'

- Don't go over 78 columns.
- Change the first "and" to "or", as "or" is used below.
- Change "takes one" to "switches", as "one" may be mistaken as
  referring to the command instead of the user.
- Use backticks in :h 'autowriteall' like in :h 'autowrite'.

closes: #19859

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0288: libvterm: signed integer overflow parsing long CSI args v9.2.0288
Christian Brabandt [Fri, 3 Apr 2026 09:36:56 +0000 (09:36 +0000)] 
patch 9.2.0288: libvterm: signed integer overflow parsing long CSI args

Problem:  Accumulating CSI argument digits without an upper bound causes
          signed integer overflow when the argument exceeds LONG_MAX.
Solution: Clamp CSI argument accumulation to CSI_ARG_MISSING to prevent
          signed integer overflow (Yasuhiro Matsumoto).

closes: #19894

Co-authored-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0287: filetype: not all ObjectScript routines are recognized v9.2.0287
Hannah [Fri, 3 Apr 2026 09:10:09 +0000 (09:10 +0000)] 
patch 9.2.0287: filetype: not all ObjectScript routines are recognized

Problem:  filetype: not all ObjectScript routines are recognized
Solution: Also detect "%RO" and "iris" patterns inside *.rtn files
          (Hannah Kimura)

closes: #19873

Signed-off-by: Hannah Kimura <hannah.kimura@intersystems.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agotranslation(it): Update Italian translation
Antonio Giovanni Colombo [Fri, 3 Apr 2026 08:47:51 +0000 (08:47 +0000)] 
translation(it): Update Italian translation

Signed-off-by: Antonio Giovanni Colombo <azc100@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(swayconfig): add additional criteria and hdr
Felix Pehla [Fri, 3 Apr 2026 08:43:53 +0000 (08:43 +0000)] 
runtime(swayconfig): add additional criteria and hdr

Sway 1.11 added `security_context_v1` metadata as criteria:
 - `sandbox_engine`
 - `sandbox_app_id`
 - `sandbox_instance_id`

Sway 1.12 will add the `tag` criteria for `xdg_toplevel_tag_v1`, as
well as the `hdr` output option (with options `on`, `off`, and
`toggle`).

closes: #19884

Signed-off-by: Felix Pehla <29adc1fd92@gmail.com>
Signed-off-by: James Eapen <james.eapen@vai.org>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0286: still some unnecessary (int) casts in alloc() v9.2.0286
Yasuhiro Matsumoto [Fri, 3 Apr 2026 08:39:11 +0000 (08:39 +0000)] 
patch 9.2.0286: still some unnecessary (int) casts in alloc()

Problem:  still some unnecessary (int) casts in alloc()
Solution: Remove more unnecessary (int) casts before alloc() calls
          (Yasuhiro Matsumoto).

Follow-up to patch 9.2.0283. Remove remaining (int) casts in
vim9script.c and netbeans.c.

vim9script.c: lengths are derived from STRLEN() on file paths,
bounded by PATH_MAX. netbeans.c: all operands are already int,
so the (int) cast is redundant and no truncation can occur.

related: #19888
closes:  #19893

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0285: :syn sync grouphere may go beyond end of line v9.2.0285
zeertzjq [Fri, 3 Apr 2026 08:30:40 +0000 (08:30 +0000)] 
patch 9.2.0285: :syn sync grouphere may go beyond end of line

Problem:  :syn sync grouphere may go beyond end of line.
Solution: Start searching for the end of region at the end of match
          instead of a possibly invalid position (zeertzjq).

closes: #19896

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(doc): Various fixes for ft_rust.txt (tw78, grammar, spaces)
Peter Kenny [Fri, 3 Apr 2026 08:28:00 +0000 (08:28 +0000)] 
runtime(doc): Various fixes for ft_rust.txt (tw78, grammar, spaces)

closes: #19887

Signed-off-by: Peter Kenny <github.com@k1w1.cyou>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(preproc_indent): Ignore Swapfiles when loading buffers
Christian Brabandt [Thu, 2 Apr 2026 17:52:49 +0000 (17:52 +0000)] 
runtime(preproc_indent): Ignore Swapfiles when loading buffers

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0284: tabpanel: crash when tabpanel expression returns variable line count v9.2.0284
Christian Brabandt [Thu, 2 Apr 2026 17:37:58 +0000 (17:37 +0000)] 
patch 9.2.0284: tabpanel: crash when tabpanel expression returns variable line count

Problem:  When a tabpanel expression returns a different number of lines on
          successive evaluations, the computed row offset can become negative,
          causing screen_fill() to receive an invalid start_row and crash
          (after v9.1.1391).
Solution: Clamp the row argument in screen_fill_tailing_area() to zero,
          add a safety check in screen_fill() for negative start_row
          (Michał Majchrowicz)

Supported by AI

Co-authored-by: Michał Majchrowicz <mmajchrowicz@afine.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(sh): Keep function name patterns engine neutral
Aliaksei Budavei [Thu, 2 Apr 2026 16:59:28 +0000 (16:59 +0000)] 
runtime(sh): Keep function name patterns engine neutral

Request less backtracking to function-name candidates for
nonlinear patterns with any regexp engine BUT force using
the old engine with these patterns to avoid incurring an
additional penalty, according to ":syntime report", when the
new regexp engine is preferred.

fixes:  #19847
closes: #19849

Signed-off-by: Aliaksei Budavei <0x000c70@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0283: unnecessary (int) casts before alloc() calls v9.2.0283
Yasuhiro Matsumoto [Thu, 2 Apr 2026 16:41:01 +0000 (16:41 +0000)] 
patch 9.2.0283: unnecessary (int) casts before alloc() calls

Problem:  unnecessary (int) casts before alloc() calls, can cause
          truncation and heap overflows (sgInnora)
Solution: Remove casts (Yasuhiro Matsumoto)

alloc() already accepts size_t, so (int) casts on size_t values are
redundant and could theoretically cause truncation on values > INT_MAX.

Remove the casts and change alloc_cmdbuff() signature from int to
size_t to match.

Note: list_alloc_with_items() keeps its int parameter since lv_len and
lv_with_items are int, and the call site already has an INT_MAX guard.

fixes:  #19888
closes: #19889

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(doc): clarify term_start() I/O behavior for Unix pty and MS-Windows ConPTY
Hirohito Higashi [Thu, 2 Apr 2026 16:36:48 +0000 (16:36 +0000)] 
runtime(doc): clarify term_start() I/O behavior for Unix pty and MS-Windows ConPTY

Explain how stdin/stdout/stderr are connected in term_start():
- On Unix, they default to pty; only "err_cb" switches stderr to a pipe,
  which may cause output order differences due to buffering.
- On MS-Windows with ConPTY, they are always pipes and stdout/stderr
  share the same pipe, so "err_cb" cannot separate them.

related: #16354

Co-authored-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Hirohito Higashi <h.east.727@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0282: tests: Test_viminfo_len_overflow() fails v9.2.0282
Yasuhiro Matsumoto [Thu, 2 Apr 2026 16:30:05 +0000 (16:30 +0000)] 
patch 9.2.0282: tests: Test_viminfo_len_overflow() fails

Problem:  tests: Test_viminfo_len_overflow() fails
Solution: Catch E342 (Yasuhiro Matsumoto).

Test_viminfo_len_overflow tries to allocate ~4GB, which may throw E342
(out of memory) depending on the platform's memory allocation behavior.
This is an acceptable outcome since the test's purpose is to verify
that Vim does not crash on a crafted viminfo entry.

closes: #19891

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0281: tests: Test_netrw_FileUrlEdit.. fails on Windows v9.2.0281
Yasuhiro Matsumoto [Thu, 2 Apr 2026 16:22:42 +0000 (16:22 +0000)] 
patch 9.2.0281: tests: Test_netrw_FileUrlEdit.. fails on Windows

Problem:  tests: Test_netrw_FileUrlEdit.. fails on Windows
          (after 3e60f03d942d6bb0f7)
Solution: Skip the test on Windows (Yasuhiro Matsumoto).

The Test_netrw_FileUrlEdit_pipe_injection() test fails on Windows with
E303 because '|' is not a valid filename character on Windows.  Since
the pipe character cannot appear in a Windows filename, the command
injection vector this test guards against does not apply on Windows.

closes: #19890

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0280: [security]: path traversal issue in zip.vim v9.2.0280
Christian Brabandt [Wed, 1 Apr 2026 16:23:49 +0000 (16:23 +0000)] 
patch 9.2.0280: [security]: path traversal issue in zip.vim

Problem:  [security]: path traversal issue in zip.vim
          (Michał Majchrowicz)
Solution: Detect more such attacks and warn the user.

Github Advisory:
https://github.com/vim/vim/security/advisories/GHSA-jc86-w7vm-8p24

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0279: terminal: out-of-bounds write with overlong CSI argument list v9.2.0279
Christian Brabandt [Wed, 1 Apr 2026 15:27:51 +0000 (15:27 +0000)] 
patch 9.2.0279: terminal: out-of-bounds write with overlong CSI argument list

Problem:  libvterm CSI parser does not bounds-check argi against
          CSI_ARGS_MAX, allowing excess ';'-separated arguments to
          write past the end of the args array (sentinel404).
Solution: Drop excess arguments.

Supported by AI

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0278: viminfo: heap buffer overflow when reading viminfo file v9.2.0278
Christian Brabandt [Wed, 1 Apr 2026 15:03:58 +0000 (15:03 +0000)] 
patch 9.2.0278: viminfo: heap buffer overflow when reading viminfo file

Problem:  Reading a crafted viminfo file can cause a heap buffer
          overflow because the length value from getdigits() is cast to
          int, truncating large size_t values
Solution: Remove the (int) cast when calling alloc() (sentinel404)

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(netrw): use fnameescape() with FileUrlEdit()
Christian Brabandt [Wed, 1 Apr 2026 14:28:53 +0000 (14:28 +0000)] 
runtime(netrw): use fnameescape() with FileUrlEdit()

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoSECURITY.md: clarify the use of AI
Christian Brabandt [Wed, 1 Apr 2026 10:33:42 +0000 (10:33 +0000)] 
SECURITY.md: clarify the use of AI

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(racket): Make visual K mapping more robust for shell injection
Christian Brabandt [Wed, 1 Apr 2026 08:10:15 +0000 (08:10 +0000)] 
runtime(racket): Make visual K mapping more robust for shell injection

fyi @benknoble

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0277: tests: test_modeline.vim fails v9.2.0277
zeertzjq [Wed, 1 Apr 2026 07:33:46 +0000 (07:33 +0000)] 
patch 9.2.0277: tests: test_modeline.vim fails

Problem:  tests: test_modeline.vim fails (after v9.2.0276)
Solution: Rewrite the tests to use the existing s:modeline_fails()
          function, update documentation (zeertzjq).

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agotranslation(cleanup): squeeze successive empty lines and remove stray comments
Eisuke Kawashima [Tue, 31 Mar 2026 19:12:36 +0000 (19:12 +0000)] 
translation(cleanup): squeeze successive empty lines and remove stray comments

closes: #19860

Signed-off-by: Eisuke Kawashima <e-kwsm@users.noreply.github.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0276: [security]: modeline security bypass v9.2.0276
Christian Brabandt [Tue, 31 Mar 2026 18:29:00 +0000 (18:29 +0000)] 
patch 9.2.0276: [security]: modeline security bypass

Problem:  [security]: modeline security bypass
Solution: disallow mapset() from secure mode, set the P_MLE flag for the
          'complete', 'guitabtooltip' and 'printheader' options.

Github Advisory:
https://github.com/vim/vim/security/advisories/GHSA-8h6p-m6gr-mpw9

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0275: tests: test_options.vim fails v9.2.0275
Christian Brabandt [Tue, 31 Mar 2026 17:44:00 +0000 (17:44 +0000)] 
patch 9.2.0275: tests: test_options.vim fails

Problem:  tests: test_options.vim fails
          (after v9.2.0273)
Solution: allow column value of 0

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0274: BSU/ESU are output directly to the terminal v9.2.0274
Yasuhiro Matsumoto [Tue, 31 Mar 2026 16:34:23 +0000 (16:34 +0000)] 
patch 9.2.0274: BSU/ESU are output directly to the terminal

Problem:  BSU/ESU are output directly to the terminal
Solution: Route them through out_buf() and flush the output directly,
          increase the OUT_SIZE terminal buffer (Yasuhiro Matsumoto)

Route synchronized-output control sequences through out_buf and flush
explicitly at protocol boundaries, instead of forcing BSU/ESU through
ui_write() directly.

Also increase the terminal output buffer from 2047 to 8191 bytes so
large redraws are emitted in fewer writes.

The important guarantee here is terminal-visible ordering: BSU must
reach the terminal before the batched redraw bytes, ESU must reach the
terminal after them, and FLUSH must emit ESU and BSU together, then
flush immediately.

Benchmark: PTY redraw workload with TERM=xterm-256color, long wrapped
lines, cursorline, listchars, horizontal scrolling, and repeated redraw!.

write syscalls: 8514 -> 5094 (-40.2%)
wall time: 0.568s -> 0.495s (-12.9%) on valid runs in this environment

closes: #19862

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0273: tabpanel: undefined behaviour with large tabpanelop columns v9.2.0273
Christian Brabandt [Tue, 31 Mar 2026 16:13:25 +0000 (16:13 +0000)] 
patch 9.2.0273: tabpanel: undefined behaviour with large tabpanelop columns

Problem:  tabpanel: undefined behaviour with large tabpanelop columns
          (Michał Majchrowicz)
Solution: Error out for too large column values

Co-authored-by: Michał Majchrowicz <mmajchrowicz@afine.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agotranslation(ru): updated lang/README.ru.txt
RestorerZ [Tue, 31 Mar 2026 15:51:32 +0000 (15:51 +0000)] 
translation(ru): updated lang/README.ru.txt

closes: #19865

Signed-off-by: RestorerZ <restorer@mail2k.ru>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agotranslation(ru): updated the Russian man page the xxd
RestorerZ [Tue, 31 Mar 2026 15:49:44 +0000 (15:49 +0000)] 
translation(ru): updated the Russian man page the xxd

closes: #19867

Signed-off-by: RestorerZ <restorer@mail2k.ru>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(sshconfig): Add missing kex algorithm
Thomas Braun [Tue, 31 Mar 2026 15:45:02 +0000 (15:45 +0000)] 
runtime(sshconfig): Add missing kex algorithm

These are available already with openssh 10.2p1.

closes: #19864

Signed-off-by: Thomas Braun <thomas.braun@byte-physics.de>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(racket): Use shellescape() to harden the K mapping
Christian Brabandt [Tue, 31 Mar 2026 15:38:30 +0000 (15:38 +0000)] 
runtime(racket): Use shellescape() to harden the K mapping

fyi: @benknoble

Co-authored-by: Michał Majchrowicz <mmajchrowicz@afine.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoFix a few typos in tests
zeertzjq [Tue, 31 Mar 2026 15:20:08 +0000 (15:20 +0000)] 
Fix a few typos in tests

closes: #19871

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(tera): use fnameescape() when loading separate syntax files
Christian Brabandt [Tue, 31 Mar 2026 15:04:48 +0000 (15:04 +0000)] 
runtime(tera): use fnameescape() when loading separate syntax files

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agotranslation(ru): updated translations
RestorerZ [Mon, 30 Mar 2026 10:32:10 +0000 (10:32 +0000)] 
translation(ru): updated translations

closes: #19868

Signed-off-by: RestorerZ <restorer@mail2k.ru>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(rustfmt): not correctly escaping directory names
Christian Brabandt [Mon, 30 Mar 2026 10:18:35 +0000 (10:18 +0000)] 
runtime(rustfmt): not correctly escaping directory names

Problem:  runtime(rustfmt): not correctly escaping directory names
Solution: Use fnamescape() (Michał Majchrowicz)

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(vimgoto): Not correctly escaping the filanems
Christian Brabandt [Mon, 30 Mar 2026 10:15:19 +0000 (10:15 +0000)] 
runtime(vimgoto): Not correctly escaping the filanems

Problem:  runtime(vimgoto): not correctly escaping the filenames
Solution: Use fnamescape() (Michał Majchrowicz)

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(typeset): Use fnameescape() for the :lcd command
Christian Brabandt [Mon, 30 Mar 2026 10:12:03 +0000 (10:12 +0000)] 
runtime(typeset): Use fnameescape() for the :lcd command

Problem:  runtime(typeset) does not escape the detected directory
Solution: Use fnameescape() (Michał Majchrowicz)

fyi @lifepillar

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agoruntime(context): use fnameescape() for the Log command
Christian Brabandt [Mon, 30 Mar 2026 09:58:07 +0000 (09:58 +0000)] 
runtime(context): use fnameescape() for the Log command

Problem:  runtime(context) does not escape the detected log file
Solution: Use fnameescape() (Michał Majchrowicz)

fyi @lifepillar

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0272: [security]: 'tabpanel' can be set in a modeline v9.2.0272
Christian Brabandt [Mon, 30 Mar 2026 08:20:43 +0000 (08:20 +0000)] 
patch 9.2.0272: [security]: 'tabpanel' can be set in a modeline

Problem:  'tabpanel' can be set in a modeline
Solution: Set the P_MLE flag for the 'tabpanel' option, disable
          autocmd_add()/autocomd_delete() functions in restricted/secure
          mode.

Github Advisory:
https://github.com/vim/vim/security/advisories/GHSA-2gmj-rpqf-pxvh

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0271: buffer underflow in vim_fgets() v9.2.0271
Koda Reef [Sun, 29 Mar 2026 15:19:49 +0000 (15:19 +0000)] 
patch 9.2.0271: buffer underflow in vim_fgets()

Problem:  buffer underflow in vim_fgets()
Solution: Ensure size is always greater than 1
          (Koda Reef)

Signed-off-by: Koda Reef <kodareef5@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0270: test: trailing spaces used in tests v9.2.0270
Paul Ollis [Sun, 29 Mar 2026 14:21:11 +0000 (14:21 +0000)] 
patch 9.2.0270: test: trailing spaces used in tests

Problem:  test: trailing spaces used in tests
Solution: Rewrite tests to avoid trailing spaces (Paul Ollis).

Some tests currently rely on trailing whitespace at the end of lines,
escaped with '\'. I have demonstrated in another PR, such spaces can be
inadvertently removed and this is difficult to spot.

Note: there are more trailing spaces in a few more test files, see
testdir/test_codestyle.vim. Those are not yet removed.

closes: #19838

Signed-off-by: Paul Ollis <paul@cleversheep.org>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0269: configure: Link error on Solaris v9.2.0269
Christian Brabandt [Sun, 29 Mar 2026 14:00:51 +0000 (14:00 +0000)] 
patch 9.2.0269: configure: Link error on Solaris

Problem:  configure: Link error on Solaris
          (idgn23, after v9.2.0153)
Solution: Move the check for the nsl library a bit earlier,
          regenerate configure

fixes: #19803

Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0268: memory leak in call_oc_method() v9.2.0268
Huihui Huang [Sun, 29 Mar 2026 13:56:42 +0000 (13:56 +0000)] 
patch 9.2.0268: memory leak in call_oc_method()

Problem:  memory leak in call_oc_method()
Solution: Clean up argvars in the failure case
          (Huihui Huang)

closes: #19828

Signed-off-by: Huihui Huang <625173@qq.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0267: 'autowrite' not triggered for :term v9.2.0267
rendcrx [Sun, 29 Mar 2026 09:20:34 +0000 (09:20 +0000)] 
patch 9.2.0267: 'autowrite' not triggered for :term

Problem:  'autowrite' not triggered for :term
Solution: Trigger autowrite for :term command
          (rendcrx)

closes: #19855

Signed-off-by: rendcrx <974449413@qq.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0266: typeahead buffer overflow during mouse drag event v9.2.0266
Yasuhiro Matsumoto [Sun, 29 Mar 2026 09:15:14 +0000 (09:15 +0000)] 
patch 9.2.0266: typeahead buffer overflow during mouse drag event

Problem:  typeahead buffer overflow during mouse drag event
Solution: Change the guard from 5 to 10 to account for the worst case
          (Yasuhiro Matsumoto).

The typeahead buffer guard in mch_inchar() only reserved 5 bytes per
iteration, but a mouse event writes up to 7 bytes (3 header + 4
coordinates) and a scroll event with modifiers writes up to 10 bytes
(3 modifier + 3 scroll + 4 coordinates).  During fast mouse dragging,
3+ events could queue up and overflow the 20-byte buffer, corrupting
adjacent static variables and causing garbage bytes (including Ctrl-Z)
to be fed into the input stream, which triggered nv_suspend/ex_stop.

closes: #19851

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0265: unnecessary restrictions for defining dictionary function names v9.2.0265
thinca [Sat, 28 Mar 2026 10:07:27 +0000 (10:07 +0000)] 
patch 9.2.0265: unnecessary restrictions for defining dictionary function names

Problem:  unnecessary restrictions for defining dictionary function
          names
Solution: Allow defining dict function with bracket key that is not a
          valid identifier (thinca)

In Vim script, "function obj.func()" and "function obj['func']()" both
define a dictionary function.  However, the bracket form required the
key to match function naming rules (eval_isnamec), so
"function obj['foo-bar']()" failed with E475.

Assigning and calling already work: "let obj['foo-bar'] = obj.func"
and "call obj['foo-bar']()" are valid.  Only the definition was
incorrectly restricted.

Skip the identifier check when the name comes from fd_newkey (i.e. the
key was given in bracket notation).  Dictionary keys may be any string.

Supported by AI

closes: #19833

Signed-off-by: thinca <thinca@gmail.com>
Signed-off-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0264: Cannot disable kitty keyboard protocol in vim :terminal v9.2.0264
Julio B [Sat, 28 Mar 2026 10:01:38 +0000 (10:01 +0000)] 
patch 9.2.0264: Cannot disable kitty keyboard protocol in vim :terminal

Problem:  Cannot disable kitty keyboard protocol in vim :terminal
Solution: Handle "CSI <u" sequence in libvterm (Julio B).

related: v9.0.0930
closes: #19837

Signed-off-by: Julio B <julio.bacel@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0263: hlset() cannot handle attributes with spaces v9.2.0263
Yasuhiro Matsumoto [Sat, 28 Mar 2026 09:47:15 +0000 (09:47 +0000)] 
patch 9.2.0263: hlset() cannot handle attributes with spaces

Problem:  hlset() cannot handle attributes with spaces
Solution: Handle attributes with spaces by quoting those
          (Yasuhiro Matsumoto).

hlset(hlget('Normal')) fails with E416 when a highlight attribute value
contains spaces (e.g. font name "Monospace 10"). hlg_add_or_update()
builds a string like "font=Monospace 10" and passes it to do_highlight(),
whose parser splits on whitespace and treats "10" as a separate key
without "=".

Fix by quoting values with single quotes (e.g. font='Monospace 10')
when the value contains spaces and the attribute is a key=value pair.
do_highlight() already supports single-quoted values.

closes: #19843

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0262: invalid lnum when pasting text copied blockwise v9.2.0262
Pierluigi Lenoci [Fri, 27 Mar 2026 15:49:27 +0000 (15:49 +0000)] 
patch 9.2.0262: invalid lnum when pasting text copied blockwise

Problem:  invalid lnum when pasting text copied blockwise
          (KillTheMule)
Solution: Subtract nr_lines from curwin->w_cursor.lnum when calling
          changed_lines() in do_put() (Pierluigi Lenoci)

When doing a blockwise paste beyond the end of the buffer, new lines are
appended and nr_lines is incremented accordingly. However, the
changed_lines() call used curwin->w_cursor.lnum as the "lnume" argument
(the first line below the changed lines BEFORE the change), which is
incorrect because the cursor has already been moved past the newly
appended lines.

Fix by subtracting nr_lines from curwin->w_cursor.lnum, so that lnume
correctly reflects the state before the change, as documented in
changed_lines().

Add a listener test to verify the correct values are reported.

Port of neovim/neovim#12733.

fixes:  #6660
closes: #19844

Signed-off-by: Pierluigi Lenoci <pierluigi.lenoci@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0261: terminal: redraws are slow v9.2.0261
Yasuhiro Matsumoto [Thu, 26 Mar 2026 22:12:52 +0000 (22:12 +0000)] 
patch 9.2.0261: terminal: redraws are slow

Problem:  terminal: redraws are slow (Mao-Yining)
Solution: Disable redrawing in handle_movecursor()
          (Yasuhiro Matsumoto)

handle_movecursor callback was calling update_cursor() with redraw=TRUE
on every cursor move inside vterm_input_write(). This triggered
gui_mch_flush() (GdiFlush + DWriteContext_Flush) and TextChangedT
autocmd for each cursor move. ConPTY output contains ~17 cursor moves
per 4KB chunk, each flush taking ~5ms, resulting in 80-110ms per chunk.

Fix by passing FALSE to update_cursor() in handle_movecursor since
write_to_term() already calls update_cursor() with proper redraw after
vterm_input_write() finishes.

Also set vterm_screen_set_damage_merge() to VTERM_DAMAGE_SCROLL so that
damage callbacks are buffered until vterm_screen_flush_damage() instead
of being emitted per cell.

fixes:  #19845
closes: #19846

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0260: statusline not redrawn after closing a popup window v9.2.0260
Yasuhiro Matsumoto [Thu, 26 Mar 2026 21:19:34 +0000 (21:19 +0000)] 
patch 9.2.0260: statusline not redrawn after closing a popup window

Problem:  When a popup window overlapping a status line is closed or
          hidden, the status line is not redrawn, leaving ghost
          artifacts from the popup.
Solution: popup_free() and popup_hide() call
          redraw_all_later(UPD_NOT_VALID) which marks window contents
          for redraw but does not set w_redr_status. The diff-based path
          in may_update_popup_mask() that normally sets w_redr_status
          is skipped when redrawing_all_win is TRUE. Add status_redraw_all
          calls to ensure status lines are properly redrawn
          (Yasuhiro Matsumoto).

closes: #19830

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
2 months agopatch 9.2.0259: tabpanel: corrupted display during scrolling causing flicker v9.2.0259
Yasuhiro Matsumoto [Thu, 26 Mar 2026 21:03:46 +0000 (21:03 +0000)] 
patch 9.2.0259: tabpanel: corrupted display during scrolling causing flicker

Problem:  tabpanel: corrupted tabpanel during scrolling causing flicker
Solution: When the tabpanel is visible, force a line-by-line redraw in
          win_do_lines() similarly to popup handling (Yasuhiro Matsumoto).

When a vertical tabpanel is visible, terminal scroll operations in
win_do_lines() affect the full screen width, corrupting the tabpanel
area. The tabpanel is then redrawn via redraw_tabpanel, causing visible
flicker. Return FAIL to force line-by-line redraw instead, analogous to
the existing popup_visible check.

closes: #19832

Signed-off-by: Yasuhiro Matsumoto <mattn.jp@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>