aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2024-07-19 11:54:42 +0800
committerGitHub <noreply@github.com>2024-07-19 03:54:42 +0000
commit35b35cb93cb54d2a9b7f881b930ba42186e57d23 (patch)
tree13e30c46ed8d9621bf5f0118f0f0952d42943fee /src
parent0b710c8e55930a082e030f980f84bd1e71a29592 (diff)
downloadrneovim-35b35cb93cb54d2a9b7f881b930ba42186e57d23.tar.gz
rneovim-35b35cb93cb54d2a9b7f881b930ba42186e57d23.tar.bz2
rneovim-35b35cb93cb54d2a9b7f881b930ba42186e57d23.zip
vim-patch:9.1.0601: Wrong cursor position with 'breakindent' when wide char doesn't fit (#29793)
Problem: Wrong cursor position with 'breakindent' when a double-width character doesn't fit in a screen line (mikoto2000) Solution: Include the width of the 'breakindent' properly. (zeertzjq) fixes: vim/vim#15289 closes: vim/vim#15290 https://github.com/vim/vim/commit/b5d6b5caac752fe15856e37fd3abc5459292d4b8
Diffstat (limited to 'src')
-rw-r--r--src/nvim/plines.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/nvim/plines.c b/src/nvim/plines.c
index f273f88dd1..f74beff954 100644
--- a/src/nvim/plines.c
+++ b/src/nvim/plines.c
@@ -268,7 +268,7 @@ CharSize charsize_regular(CharsizeArg *csarg, char *const cur, colnr_T const vco
head += (max_head_vcol - (vcol + head_prev + prev_rem)
+ width2 - 1) / width2 * head_mid;
} else if (max_head_vcol < 0) {
- int off = virt_text_cursor_off(csarg, *cur == NUL);
+ int off = mb_added + virt_text_cursor_off(csarg, *cur == NUL);
if (off >= prev_rem) {
if (size > off) {
head += (1 + (off - prev_rem) / width) * head_mid;