From c8a183c13d951b74315a0d38367c900e59379e3f Mon Sep 17 00:00:00 2001 From: Curtis McEnroe Date: Tue, 8 Aug 2017 19:00:54 -0400 Subject: Turn off SIGPIPE at the socket level I imagine it's better to not generate SIGPIPE at all rather than generate and ignore. --- server.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) (limited to 'server.c') diff --git a/server.c b/server.c index fc3b3d0..8ad47ba 100755 --- a/server.c +++ b/server.c @@ -260,8 +260,6 @@ static bool clientPut(const struct Client *client, uint8_t color, char cell) { int main() { int error; - signal(SIGPIPE, SIG_IGN); - tilesMap(); int server = socket(PF_LOCAL, SOCK_STREAM, 0); @@ -304,6 +302,10 @@ int main() { if (fd < 0) err(EX_IOERR, "accept"); fcntl(fd, F_SETFL, O_NONBLOCK); + int on = 1; + error = setsockopt(fd, SOL_SOCKET, SO_NOSIGPIPE, &on, sizeof(on)); + if (error) err(EX_IOERR, "setsockopt"); + struct Client *client = clientAdd(fd); struct kevent event = { -- cgit 1.4.1