X-Git-Url: http://git.dolda2000.com/gitweb/?a=blobdiff_plain;f=lib%2Fmtio.c;h=70a0949684d4169c8aa6fec6cb51944939ba49c5;hb=091936b4cde21cdfd2d0f8650f9536e7ede19c50;hp=43cc1f7045d3478c483846ebf57a232684b5d100;hpb=be078ac9feafbf0eb7547ea14bb2e73936caa60c;p=ashd.git
diff --git a/lib/mtio.c b/lib/mtio.c
index 43cc1f7..70a0949 100644
--- a/lib/mtio.c
+++ b/lib/mtio.c
@@ -16,16 +16,17 @@
along with this program. If not, see .
*/
+#ifdef HAVE_CONFIG_H
+#include
+#endif
#include
#include
+#include
#include
#include
#include
#include
-#ifdef HAVE_CONFIG_H
-#include
-#endif
#include
#include
#include
@@ -106,6 +107,7 @@ static int mtclose(void *cookie)
return(0);
}
+#if defined(HAVE_GLIBC_STDIO)
static cookie_io_functions_t iofuns = {
.read = mtread,
.write = mtwrite,
@@ -128,3 +130,43 @@ FILE *mtstdopen(int fd, int issock, int timeout, char *mode)
fcntl(fd, F_SETFL, fcntl(fd, F_GETFL) | O_NONBLOCK);
return(ret);
}
+#elif defined(HAVE_BSD_STDIO)
+static int bsd2mtread(void *cookie, char *buf, int len)
+{
+ return(mtread(cookie, buf, len));
+}
+
+static int bsd2mtwrite(void *cookie, const char *buf, int len)
+{
+ return(mtwrite(cookie, buf, len));
+}
+
+FILE *mtstdopen(int fd, int issock, int timeout, char *mode)
+{
+ struct stdiofd *d;
+ FILE *ret;
+ int r, w;
+
+ if(!strcmp(mode, "r")) {
+ r = 1; w = 0;
+ } else if(!strcmp(mode, "w")) {
+ r = 0; w = 1;
+ } else if(!strcmp(mode, "r+")) {
+ r = w = 1;
+ } else {
+ return(NULL);
+ }
+ omalloc(d);
+ d->fd = fd;
+ d->sock = issock;
+ d->timeout = timeout;
+ ret = funopen(d, r?bsd2mtread:NULL, w?bsd2mtwrite:NULL, NULL, mtclose);
+ if(!ret)
+ free(d);
+ else
+ fcntl(fd, F_SETFL, fcntl(fd, F_GETFL) | O_NONBLOCK);
+ return(ret);
+}
+#else
+#error "No stdio implementation for this system"
+#endif