# HG changeset patch # User Bram Moolenaar # Date 1574117103 -3600 # Node ID 0969f82fbbff35561fd049bab15f161819de5fb4 # Parent 0e6db18219637301b16ff27d10a58f53b470fc63 patch 8.1.2321: cannot select all text with the mouse Commit: https://github.com/vim/vim/commit/0a5aa7b28a39507260acb15c1ef698a33c855cc1 Author: Bram Moolenaar Date: Mon Nov 18 23:31:48 2019 +0100 patch 8.1.2321: cannot select all text with the mouse Problem: Cannot select all text with the mouse. (John Marriott) Solution: Move limiting the mouse column to f_getmousepos(). (closes https://github.com/vim/vim/issues/5242) diff --git a/src/mouse.c b/src/mouse.c --- a/src/mouse.c +++ b/src/mouse.c @@ -2822,7 +2822,6 @@ mouse_comp_pos( int retval = FALSE; int off; int count; - char_u *p; #ifdef FEAT_RIGHTLEFT if (win->w_p_rl) @@ -2882,11 +2881,6 @@ mouse_comp_pos( col += row * (win->w_width - 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) @@ -3053,7 +3047,17 @@ f_getmousepos(typval_T *argvars UNUSED, col -= left_off; 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, NULL); + + // 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/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -742,6 +742,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 2321, +/**/ 2320, /**/ 2319,