aboutsummaryrefslogtreecommitdiff
path: root/src/utils.c
diff options
context:
space:
mode:
authorEric Wong <normalperson@yhbt.net>2008-06-30 02:43:04 +0000
committerEric Wong <normalperson@yhbt.net>2008-06-30 02:43:04 +0000
commit8426740f44e6584e291f23ac9858754111221395 (patch)
treeb0459e117615e3a492deee60f93236254d405853 /src/utils.c
parentc5931529675a863e7173635c5f8779f78b3940e2 (diff)
utils: add new unforgiving utility functions
We'll be using pipes when waiting for I/O, and condition variables at other times. git-svn-id: https://svn.musicpd.org/mpd/trunk@7391 09075e82-0dd4-0310-85a5-a0d7c8717e4f
Diffstat (limited to 'src/utils.c')
-rw-r--r--src/utils.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/src/utils.c b/src/utils.c
index a311796c..eedae22d 100644
--- a/src/utils.c
+++ b/src/utils.c
@@ -230,3 +230,27 @@ int set_nonblocking(int fd)
while ((ret = fcntl(fd, F_SETFL, flags)) < 0 && errno == EINTR) ;
return ret;
}
+
+void init_async_pipe(int file_des[2])
+{
+ if (pipe(file_des) < 0)
+ FATAL("Couldn't open pipe: %s", strerror(errno));
+ if (set_nonblocking(file_des[0]) < 0)
+ FATAL("Couldn't set non-blocking I/O: %s\n", strerror(errno));
+ if (set_nonblocking(file_des[1]) < 0)
+ FATAL("Couldn't set non-blocking I/O: %s\n", strerror(errno));
+}
+
+void xpthread_mutex_destroy(pthread_mutex_t *mutex)
+{
+ int err;
+ if ((err = pthread_mutex_destroy(mutex)))
+ FATAL("failed to destroy mutex: %s\n", strerror(err));
+}
+
+void xpthread_cond_destroy(pthread_cond_t *cond)
+{
+ int err;
+ if ((err = pthread_cond_destroy(cond)))
+ FATAL("failed to destroy cond: %s\n", strerror(err));
+}