]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0264: libgpm may delete some signal handlers v9.1.0264
authorJulio B <julio.bacel@gmail.com>
Thu, 4 Apr 2024 19:55:10 +0000 (21:55 +0200)
committerChristian Brabandt <cb@256bit.org>
Thu, 4 Apr 2024 19:55:10 +0000 (21:55 +0200)
Problem:  libgpm may delete some signal handlers
Solution: restore these signal handlers after calling gpm
          (Julio B)

When 'mouse' is set, vim is trying to detect mouse support on startup.
Eventually, vim resorts to using libgpm as the final method of
mouse detection. This library may delete some signals handlers that were
initially set up by vim.

This is how:
- mch_setmouse() calls gpm_open()
- Gpm_Open is executed, which returns early on line 210 [1]
- Keep in mind that lines 353-373 [2] are skipped, so
  gpm_saved_suspend_hook and gpm_saved_winch_hook are empty
- Finally, Gpm_Close is called, which will reset [3] SIGWINCH and
  SIGTSTP to an empty sigaction.

[1] https://github.com/telmich/gpm/blob/e82d1a653ca94aa4ed12441424da6ce780b1e530/src/lib/liblow.c#L210
[2] https://github.com/telmich/gpm/blob/e82d1a653ca94aa4ed12441424da6ce780b1e530/src/lib/liblow.c#L353-L373
[3] https://github.com/telmich/gpm/blob/e82d1a653ca94aa4ed12441424da6ce780b1e530/src/lib/liblow.c#L419-L424

fixes: #12154
closes: #14401

Signed-off-by: Julio B <julio.bacel@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
src/os_unix.c
src/version.c

index e98911e0f8a19f4e71d3ae07d9b5fd3088317eab..da7f56a67521090597cce782e5efbbb5e039a6c9 100644 (file)
@@ -7494,7 +7494,19 @@ gpm_open(void)
        return 1; // succeed
     }
     if (gpm_fd == -2)
+    {
        Gpm_Close(); // We don't want to talk to xterm via gpm
+
+        // Gpm_Close fails to properly restore the WINCH and TSTP handlers,
+        // leading to Vim ignoring resize signals. We have to re-initialize
+        // these handlers again here.
+# ifdef SIGWINCH
+       mch_signal(SIGWINCH, sig_winch);
+# endif
+# ifdef SIGTSTP
+       mch_signal(SIGTSTP, restricted ? SIG_IGN : sig_tstp);
+# endif
+    }
     return 0;
 }
 
index 1a82d9b3ab8829a83ffebc74cc986ba5e298c235..861adf1bd85e79144d2afc0bd1315d45a9832f08 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    264,
 /**/
     263,
 /**/