diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/nvim/eval/funcs.c | 11 | ||||
| -rw-r--r-- | src/nvim/mouse.c | 7 | 
2 files changed, 11 insertions, 7 deletions
| diff --git a/src/nvim/eval/funcs.c b/src/nvim/eval/funcs.c index 6e3be94366..98edc36a7c 100644 --- a/src/nvim/eval/funcs.c +++ b/src/nvim/eval/funcs.c @@ -3780,7 +3780,18 @@ void f_getmousepos(typval_T *argvars, typval_T *rettv, FunPtr fptr)        winrow = row + 1 + wp->w_border_adj[0];  // Adjust by 1 for top border        wincol = col + 1 + wp->w_border_adj[3];  // Adjust by 1 for left border        if (row >= 0 && row < wp->w_height && col >= 0 && col < wp->w_width) { +        char_u *p; +        int count; +          mouse_comp_pos(wp, &row, &col, &line); + +        // limit to text length plus one +        p = ml_get_buf(wp->w_buffer, line, false); +        count = (int)STRLEN(p); +        if (col > count) { +          col = count; +        } +          column = col + 1;        }      } diff --git a/src/nvim/mouse.c b/src/nvim/mouse.c index 4001d620c8..cf463fd40a 100644 --- a/src/nvim/mouse.c +++ b/src/nvim/mouse.c @@ -363,7 +363,6 @@ 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; @@ -408,12 +407,6 @@ 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 = (int)STRLEN(p); -    if (col > count) { -      col = count; -    }    }    if (!win->w_p_wrap) { | 
