]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0081: X11 mouse-scrolling stutters v9.1.0081
authorlilydjwg <lilydjwg@gmail.com>
Thu, 8 Feb 2024 10:04:21 +0000 (11:04 +0100)
committerChristian Brabandt <cb@256bit.org>
Thu, 8 Feb 2024 10:04:21 +0000 (11:04 +0100)
Problem:  X11 mouse-scrolling stutters
          (Ron Aaron, after 9.1.0064)
Solution: Handle GDK_SCROLL_SMOOTH fractional distance events
          (lilydjwg)

I don't know why, but with GDK_SMOOTH_SCROLL_MASK we get wheel events as
GDK_SCROLL_SMOOTH. What's more, one wheel scroll is counted as 1.5
distance in Wayland but 1.0 in X11.

I failed to find any docs on gtk.org about this.

fixes: #13987
closes: #13991

Signed-off-by: lilydjwg <lilydjwg@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
src/gui_gtk_x11.c
src/version.c

index dd0179ee056ba8c826c710e4524fe921a98fed12..98ab3d49b67223ad63d37243621302e633f54178 100644 (file)
@@ -2105,25 +2105,25 @@ scroll_event(GtkWidget *widget,
 #if GTK_CHECK_VERSION(3,4,0)
     if (event->direction == GDK_SCROLL_SMOOTH)
     {
-       while (acc_x > 1.0)
+       while (acc_x >= 1.0)
        { // right
            acc_x = MAX(0.0, acc_x - 1.0);
            gui_send_mouse_event(MOUSE_6, (int)event->x, (int)event->y,
                    FALSE, vim_modifiers);
        }
-       while (acc_x < -1.0)
+       while (acc_x <= -1.0)
        { // left
            acc_x = MIN(0.0, acc_x + 1.0);
            gui_send_mouse_event(MOUSE_7, (int)event->x, (int)event->y,
                    FALSE, vim_modifiers);
        }
-       while (acc_y > 1.0)
+       while (acc_y >= 1.0)
        { // down
            acc_y = MAX(0.0, acc_y - 1.0);
            gui_send_mouse_event(MOUSE_5, (int)event->x, (int)event->y,
                    FALSE, vim_modifiers);
        }
-       while (acc_y < -1.0)
+       while (acc_y <= -1.0)
        { // up
            acc_y = MIN(0.0, acc_y + 1.0);
            gui_send_mouse_event(MOUSE_4, (int)event->x, (int)event->y,
index 36f9dc07ea9498a7a35915933dab9b06668abfc2..408dd37b932cc91be85288a5009d766c5c9d5011 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    81,
 /**/
     80,
 /**/