mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-27 22:46:15 +01:00
Ignore SIGPIPE when using GSocket
http://bugzilla.gnome.org/show_bug.cgi?id=583001
This commit is contained in:
parent
2ea22d8f46
commit
25800ed4a3
@ -28,6 +28,7 @@
|
|||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
#include <signal.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
@ -102,6 +103,12 @@
|
|||||||
*
|
*
|
||||||
* All socket file descriptors are set to be close-on-exec.
|
* All socket file descriptors are set to be close-on-exec.
|
||||||
*
|
*
|
||||||
|
* Note that creating a #GSocket causes the signal %SIGPIPE to be
|
||||||
|
* ignored for the remainder of the program. If you are writing a
|
||||||
|
* command-line utility that uses #GSocket, you may need to take into
|
||||||
|
* account the fact that your program will not automatically be killed
|
||||||
|
* if it tries to write to %stdout after it has been closed.
|
||||||
|
*
|
||||||
* Since: 2.22
|
* Since: 2.22
|
||||||
**/
|
**/
|
||||||
|
|
||||||
@ -616,6 +623,14 @@ g_socket_class_init (GSocketClass *klass)
|
|||||||
/* Make sure winsock has been initialized */
|
/* Make sure winsock has been initialized */
|
||||||
type = g_inet_address_get_type ();
|
type = g_inet_address_get_type ();
|
||||||
|
|
||||||
|
#ifdef SIGPIPE
|
||||||
|
/* There is no portable, thread-safe way to avoid having the process
|
||||||
|
* be killed by SIGPIPE when calling send() or sendmsg(), so we are
|
||||||
|
* forced to simply ignore the signal process-wide.
|
||||||
|
*/
|
||||||
|
signal (SIGPIPE, SIG_IGN);
|
||||||
|
#endif
|
||||||
|
|
||||||
g_type_class_add_private (klass, sizeof (GSocketPrivate));
|
g_type_class_add_private (klass, sizeof (GSocketPrivate));
|
||||||
|
|
||||||
gobject_class->finalize = g_socket_finalize;
|
gobject_class->finalize = g_socket_finalize;
|
||||||
|
Loading…
Reference in New Issue
Block a user