aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2016-05-25 21:35:09 +0200
committerKim Alvefur <zash@zash.se>2016-05-25 21:35:09 +0200
commit713422034f373d676d484d3f40fee0667416a25a (patch)
tree3556e1c72692e7f3e51123d92fbdc1d6ed34e820
parent4ba59d52f26e0fc37af41eecc501e21cd6b0aff4 (diff)
parent0fd7323ab79f69224bdd868ecabb2f3f6aed4e36 (diff)
downloadprosody-713422034f373d676d484d3f40fee0667416a25a.tar.gz
prosody-713422034f373d676d484d3f40fee0667416a25a.zip
Merge 0.10->trunk
-rw-r--r--util-src/crand.c2
-rw-r--r--util-src/pposix.c13
2 files changed, 14 insertions, 1 deletions
diff --git a/util-src/crand.c b/util-src/crand.c
index 735135fb..fbdec8f8 100644
--- a/util-src/crand.c
+++ b/util-src/crand.c
@@ -106,7 +106,7 @@ int Lrandom(lua_State *L) {
#endif
- lua_pushlstring(L, buf, ret);
+ lua_pushlstring(L, (const char *)buf, ret);
#ifndef BUFLEN
free(buf);
#endif
diff --git a/util-src/pposix.c b/util-src/pposix.c
index 1b69852d..b48465d3 100644
--- a/util-src/pposix.c
+++ b/util-src/pposix.c
@@ -49,6 +49,19 @@
#define WITH_MALLINFO
#endif
+#if defined(RFPROC) && defined(EV_SET)
+/*
+ * On *BSD, calling fork() is equivalent to rfork(RFPROC | RFFDG).
+ *
+ * RFFDG being set means that the file descriptor table is copied,
+ * otherwise it's shared. We want the later, otherwise libevent gets
+ * messed up.
+ *
+ * See issue #412
+ */
+#define fork() rfork(RFPROC)
+#endif
+
/* Daemonization support */
static int lc_daemonize(lua_State* L) {