Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/external/bsd/nvi/dist/cl When testing to see if a signal han...
details: https://anonhg.NetBSD.org/src/rev/9381d19b699d
branches: trunk
changeset: 828283:9381d19b699d
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Wed Dec 06 17:16:14 2017 +0000
description:
When testing to see if a signal handler was previously installed in
h_winch, test sa_handler against all SIG_* actions defined in sys/signal.h
instead of just 0. Corrects an issue where vi crashes after a window is
resized.
diffstat:
external/bsd/nvi/dist/cl/cl_main.c | 10 +++++++---
1 files changed, 7 insertions(+), 3 deletions(-)
diffs (32 lines):
diff -r 2c85277a2e55 -r 9381d19b699d external/bsd/nvi/dist/cl/cl_main.c
--- a/external/bsd/nvi/dist/cl/cl_main.c Wed Dec 06 16:38:22 2017 +0000
+++ b/external/bsd/nvi/dist/cl/cl_main.c Wed Dec 06 17:16:14 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cl_main.c,v 1.8 2017/11/06 03:27:34 rin Exp $ */
+/* $NetBSD: cl_main.c,v 1.9 2017/12/06 17:16:14 jmcneill Exp $ */
/*-
* Copyright (c) 1993, 1994
* The Regents of the University of California. All rights reserved.
@@ -16,7 +16,7 @@
static const char sccsid[] = "Id: cl_main.c,v 10.54 2001/07/29 19:07:27 skimo Exp (Berkeley) Date: 2001/07/29 19:07:27 ";
#endif /* not lint */
#else
-__RCSID("$NetBSD: cl_main.c,v 1.8 2017/11/06 03:27:34 rin Exp $");
+__RCSID("$NetBSD: cl_main.c,v 1.9 2017/12/06 17:16:14 jmcneill Exp $");
#endif
#include <sys/types.h>
@@ -314,8 +314,12 @@
F_SET(clp, CL_SIGWINCH);
/* If there was a previous handler, call that. */
- if (clp->oact[INDX_WINCH].sa_handler)
+ if (clp->oact[INDX_WINCH].sa_handler != SIG_DFL &&
+ clp->oact[INDX_WINCH].sa_handler != SIG_IGN &&
+ clp->oact[INDX_WINCH].sa_handler != SIG_ERR &&
+ clp->oact[INDX_WINCH].sa_handler != SIG_HOLD) {
clp->oact[INDX_WINCH].sa_handler(signo);
+ }
}
#undef GLOBAL_CLP
Home |
Main Index |
Thread Index |
Old Index