summaryrefslogtreecommitdiffstats
path: root/otherlibs/win32unix/pipe.c
diff options
context:
space:
mode:
authorXavier Leroy <xavier.leroy@inria.fr>1997-09-04 13:45:56 +0000
committerXavier Leroy <xavier.leroy@inria.fr>1997-09-04 13:45:56 +0000
commit0efc0065fc1c1f1709ffd9abeee1751409c2170a (patch)
tree7e9e59e604771b609405ed77fff0c938a6205812 /otherlibs/win32unix/pipe.c
parent1e664b94467a65841e63d2dea50cd1f64e8a3258 (diff)
Debug, tests
git-svn-id: http://caml.inria.fr/svn/ocaml/trunk@1701 f963ae5c-01c2-4b8c-9fe0-0dff7051ff02
Diffstat (limited to 'otherlibs/win32unix/pipe.c')
-rw-r--r--otherlibs/win32unix/pipe.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/otherlibs/win32unix/pipe.c b/otherlibs/win32unix/pipe.c
index c782f7afa..411a76bad 100644
--- a/otherlibs/win32unix/pipe.c
+++ b/otherlibs/win32unix/pipe.c
@@ -12,6 +12,7 @@
/* $Id$ */
#include <mlvalues.h>
+#include <memory.h>
#include <alloc.h>
#include "unixsupport.h"
#include <fcntl.h>
@@ -20,10 +21,14 @@
value unix_pipe(value unit) /* ML */
{
+ SECURITY_ATTRIBUTES attr;
HANDLE readh, writeh;
value readfd = Val_unit, writefd = Val_unit, res;
- if (! CreatePipe(&readh, &writeh, NULL, SIZEBUF)) {
+ attr.nLength = sizeof(attr);
+ attr.lpSecurityDescriptor = NULL;
+ attr.bInheritHandle = TRUE;
+ if (! CreatePipe(&readh, &writeh, &attr, SIZEBUF)) {
_dosmaperr(GetLastError());
uerror("pipe", Nothing);
}