diff options
author | Robert James Kaes <rjkaes@users.sourceforge.net> | 2001-09-16 20:11:07 +0000 |
---|---|---|
committer | Robert James Kaes <rjkaes@users.sourceforge.net> | 2001-09-16 20:11:07 +0000 |
commit | b9c4c480d223e7f084a7f165a295872d78952fcd (patch) | |
tree | b850911b6c022a12d531504768113d2a9bbab5b6 /src | |
parent | 08baf6b01bca04f4612109a57824516e45e2e727 (diff) |
Moved the safe_write() and safe_read() functions here.
Diffstat (limited to 'src')
-rw-r--r-- | src/sock.c | 32 | ||||
-rw-r--r-- | src/sock.h | 5 |
2 files changed, 35 insertions, 2 deletions
@@ -1,4 +1,4 @@ -/* $Id: sock.c,v 1.7 2001-09-07 04:18:26 rjkaes Exp $ +/* $Id: sock.c,v 1.8 2001-09-16 20:11:07 rjkaes Exp $ * * Sockets are created and destroyed here. When a new connection comes in from * a client, we need to copy the socket and the create a second socket to the @@ -200,6 +200,36 @@ char *getpeer_string(int fd, char *string) } /* + * Write the buffer to the socket. If an EINTR occurs, pick up and try + * again. + */ +ssize_t safe_write(int fd, const void *buffer, size_t count) +{ + ssize_t len; + + do { + len = write(fd, buffer, count); + } while (len < 0 && errno == EINTR); + + return len; +} + +/* + * Matched pair for safe_write(). If an EINTR occurs, pick up and try + * again. + */ +ssize_t safe_read(int fd, void *buffer, size_t count) +{ + ssize_t len; + + do { + len = read(fd, buffer, count); + } while (len < 0 && errno == EINTR); + + return len; +} + +/* * Reads in a line of text one character at a time. Finishes when either a * newline is detected, or maxlen characters have been read. The function * will actually copy one less than maxlen into the buffer. In other words, @@ -1,4 +1,4 @@ -/* $Id: sock.h,v 1.4 2001-06-02 02:07:34 rjkaes Exp $ +/* $Id: sock.h,v 1.5 2001-09-16 20:11:07 rjkaes Exp $ * * See 'sock.c' for a detailed description. * @@ -37,6 +37,9 @@ extern int socket_blocking(int sock); extern char *getpeer_ip(int fd, char *ipaddr); extern char *getpeer_string(int fd, char *string); +extern ssize_t safe_write(int fd, const void *buffer, size_t count); +extern ssize_t safe_read(int fd, void *buffer, size_t count); + extern ssize_t readline(int fd, char *ptr, size_t maxlen); #endif |