]> granicus.if.org Git - vim/commitdiff
patch 7.4.2238 v7.4.2238
authorBram Moolenaar <Bram@vim.org>
Sun, 21 Aug 2016 19:03:37 +0000 (21:03 +0200)
committerBram Moolenaar <Bram@vim.org>
Sun, 21 Aug 2016 19:03:37 +0000 (21:03 +0200)
Problem:    With SGR mouse reporting (suckless terminal) the mouse release and
            scroll up/down is confused.
Solution:   Don't see a release as a scroll up/down. (Ralph Eastwood)

src/term.c
src/version.c

index 774ef655270082ddf1135ebb8684cdbd6cfd8ec1..4d505e33d4c423fae603dda49eab21ac6181d05f 100644 (file)
@@ -4939,7 +4939,7 @@ check_termcode(
                button = getdigits(&p);
                mouse_code = 0;
 
-               switch( button )
+               switch (button)
                {
                    case 4: mouse_code = MOUSE_LEFT; break;
                    case 1: mouse_code = MOUSE_RIGHT; break;
@@ -4947,7 +4947,7 @@ check_termcode(
                    default: return -1;
                }
 
-               switch( action )
+               switch (action)
                {
                    case 31: /* Initial press */
                        if (*p++ != ';')
@@ -5096,9 +5096,11 @@ check_termcode(
            else if (orig_num_clicks == 4)
                modifiers |= MOD_MASK_4CLICK;
 
-           /* Work out our pseudo mouse event */
+           /* Work out our pseudo mouse event. Note that MOUSE_RELEASE gets
+            * added, then it's not mouse up/down. */
            key_name[0] = (int)KS_EXTRA;
-           if (wheel_code != 0)
+            if (wheel_code != 0
+                             && (wheel_code & MOUSE_RELEASE) != MOUSE_RELEASE)
            {
                if (wheel_code & MOUSE_CTRL)
                    modifiers |= MOD_MASK_CTRL;
index fe60c32489cd9e812f6350ad4037f66288b818a0..0d3d4919678b39a97185e2e343b73d998a2572ba 100644 (file)
@@ -763,6 +763,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    2238,
 /**/
     2237,
 /**/