aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/mouse.c
diff options
context:
space:
mode:
authorDaniel Steinberg <dstein64@users.noreply.github.com>2021-06-29 17:55:54 -0400
committerDaniel Steinberg <dstein64@users.noreply.github.com>2021-09-29 11:13:49 -0400
commit3b9e75b3664652e5557dd6423adda9b55d113c4f (patch)
tree850b93ce542558916feaf4d710c95a716eb361c1 /src/nvim/mouse.c
parentec4731d982031e363a59efd4566fc72234bb43c8 (diff)
downloadrneovim-3b9e75b3664652e5557dd6423adda9b55d113c4f.tar.gz
rneovim-3b9e75b3664652e5557dd6423adda9b55d113c4f.tar.bz2
rneovim-3b9e75b3664652e5557dd6423adda9b55d113c4f.zip
vim-patch:8.1.2304: cannot get the mouse position when getting a mouse click
Problem: Cannot get the mouse position when getting a mouse click. Solution: Add getmousepos(). https://github.com/vim/vim/commit/db3a205147ce2c335d5c2181c1f789277f8775b0
Diffstat (limited to 'src/nvim/mouse.c')
-rw-r--r--src/nvim/mouse.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/nvim/mouse.c b/src/nvim/mouse.c
index cf463fd40a..14c20b2b2b 100644
--- a/src/nvim/mouse.c
+++ b/src/nvim/mouse.c
@@ -363,6 +363,7 @@ bool mouse_comp_pos(win_T *win, int *rowp, int *colp, linenr_T *lnump)
bool retval = false;
int off;
int count;
+ char_u *p;
if (win->w_p_rl) {
col = win->w_width_inner - 1 - col;
@@ -407,6 +408,12 @@ bool mouse_comp_pos(win_T *win, int *rowp, int *colp, linenr_T *lnump)
col += row * (win->w_width_inner - off);
// add skip column (for long wrapping line)
col += win->w_skipcol;
+ // limit to text length plus one
+ p = ml_get_buf(win->w_buffer, lnum, false);
+ count = STRLEN(p);
+ if (col > count) {
+ col = count;
+ }
}
if (!win->w_p_wrap) {