From 01108e3f4567db222a7e6e2ed9c484506b491dba Mon Sep 17 00:00:00 2001 From: Paul Eggert Date: Sat, 22 Sep 2012 00:34:52 -0700 Subject: [PATCH] * emacs.c (shut_down_emacs): Don't assume stderr is buffered, or that fprintf is async-signal-safe. POSIX doesn't require either assumption. --- src/ChangeLog | 6 ++++++ src/emacs.c | 9 ++++++++- 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/src/ChangeLog b/src/ChangeLog index 439b5c06e27..847e065e1c3 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,9 @@ +2012-09-22 Paul Eggert + + * emacs.c (shut_down_emacs): Don't assume stderr is buffered, + or that fprintf is async-signal-safe. POSIX doesn't require + either assumption. + 2012-09-22 Chong Yidong * buffer.c (Fset_buffer_modified_p): Handle indirect buffers diff --git a/src/emacs.c b/src/emacs.c index d4b52ab64ea..a483f3848cf 100644 --- a/src/emacs.c +++ b/src/emacs.c @@ -27,6 +27,8 @@ along with GNU Emacs. If not, see . */ #include #include +#include + #include "lisp.h" #ifdef HAVE_WINDOW_SYSTEM @@ -2012,7 +2014,12 @@ shut_down_emacs (int sig, Lisp_Object stuff) { reset_all_sys_modes (); if (sig && sig != SIGTERM) - fprintf (stderr, "Fatal error %d: %s", sig, strsignal (sig)); + { + char buf[100]; + int buflen = snprintf (buf, sizeof buf, "Fatal error %d: %s", + sig, strsignal (sig)); + ignore_value (write (STDERR_FILENO, buf, buflen)); + } } } #else -- 2.39.2