summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLaurent Bercot <ska-skaware@skarnet.org>2016-07-20 19:20:08 +0000
committerLaurent Bercot <ska-skaware@skarnet.org>2016-07-20 19:20:08 +0000
commit885cd198c0be874147a0e98e106a85abf720a7f1 (patch)
tree97ab9180887860cc98577628fd19ba4537d7651e /src
parentd68c3647e69cce6aaf4fd3d94e3eb33e3125b31c (diff)
downloadskalibs-885cd198c0be874147a0e98e106a85abf720a7f1.tar.xz
Add ipc_timed_recv
Diffstat (limited to 'src')
-rw-r--r--src/include/skalibs/unix-timed.h2
-rw-r--r--src/libunixonacid/buffer_timed_get.c1
-rw-r--r--src/libunixonacid/ipc_timed_recv.c30
3 files changed, 33 insertions, 0 deletions
diff --git a/src/include/skalibs/unix-timed.h b/src/include/skalibs/unix-timed.h
index c3ae4cd..68c6361 100644
--- a/src/include/skalibs/unix-timed.h
+++ b/src/include/skalibs/unix-timed.h
@@ -35,5 +35,7 @@ extern int netstring_timed_get (buffer *, stralloc *, tain_t const *, tain_t *)
extern int ipc_timed_send (int, char const *, unsigned int, tain_t const *, tain_t *) ;
#define ipc_timed_send_g(fd, s, len, deadline) ipc_timed_send(fd, s, len, (deadline), &STAMP)
+extern int ipc_timed_get (int, char *, unsigned int, char *, tain_t const *, tain_t *) ;
+#define ipc_timed_get_g(fd, s, len, path, deadline) ipc_timed_get(fd, s, len, path, (deadline), &STAMP)
#endif
diff --git a/src/libunixonacid/buffer_timed_get.c b/src/libunixonacid/buffer_timed_get.c
index 2f3b751..af846ff 100644
--- a/src/libunixonacid/buffer_timed_get.c
+++ b/src/libunixonacid/buffer_timed_get.c
@@ -1,6 +1,7 @@
/* ISC license. */
#include <skalibs/buffer.h>
+#include <skalibs/buffer.h>
#include <skalibs/tai.h>
#include <skalibs/unix-timed.h>
diff --git a/src/libunixonacid/ipc_timed_recv.c b/src/libunixonacid/ipc_timed_recv.c
new file mode 100644
index 0000000..bcb991d
--- /dev/null
+++ b/src/libunixonacid/ipc_timed_recv.c
@@ -0,0 +1,30 @@
+/* ISC license. */
+
+#include <skalibs/functypes.h>
+#include <skalibs/tai.h>
+#include <skalibs/webipc.h>
+#include <skalibs/unix-timed.h>
+
+struct blah_s
+{
+ int fd ;
+ char *s ;
+ unsigned int len ;
+ char *path ;
+} ;
+
+static int getfd (struct blah_s *blah)
+{
+ return blah->fd ;
+}
+
+static int get (struct blah_s *blah)
+{
+ return sanitize_read(ipc_recv(blah->fd, blah->s, blah->len, blah->path)) ;
+}
+
+int ipc_timed_get (int fd, char *s, unsigned int len, char *path, tain_t const *deadline, tain_t *stamp)
+{
+ struct blah_s blah = { .fd = fd, .s = s, .len = len, .path = path } ;
+ return timed_get(&blah, (initfunc_t_ref)&getfd, (initfunc_t_ref)&get, deadline, stamp) ;
+}