diff options
author | Xavier Leroy <xavier.leroy@inria.fr> | 1996-09-04 14:17:43 +0000 |
---|---|---|
committer | Xavier Leroy <xavier.leroy@inria.fr> | 1996-09-04 14:17:43 +0000 |
commit | a0c8d7373311facda78d250751203371cc0487b2 (patch) | |
tree | cfb65b4d0bff35f71cede7ae09e647433845236f /otherlibs/win32unix/accept.c | |
parent | ac9f8e8094ea19199a24fd5c67053718198ed172 (diff) |
Merge du stage de Pascal Cuoq
git-svn-id: http://caml.inria.fr/svn/ocaml/trunk@952 f963ae5c-01c2-4b8c-9fe0-0dff7051ff02
Diffstat (limited to 'otherlibs/win32unix/accept.c')
-rw-r--r-- | otherlibs/win32unix/accept.c | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/otherlibs/win32unix/accept.c b/otherlibs/win32unix/accept.c new file mode 100644 index 000000000..9d68b935f --- /dev/null +++ b/otherlibs/win32unix/accept.c @@ -0,0 +1,55 @@ +/***********************************************************************/ +/* */ +/* Objective Caml */ +/* */ +/* Xavier Leroy, projet Cristal, INRIA Rocquencourt */ +/* */ +/* Copyright 1996 Institut National de Recherche en Informatique et */ +/* Automatique. Distributed only by permission. */ +/* */ +/***********************************************************************/ + +/* $Id$ */ + +#include <mlvalues.h> +#include <alloc.h> +#include <memory.h> +#include "unixsupport.h" +#include "socketaddr.h" + +value unix_accept(sock) /* ML */ + value sock; +{ + SOCKET s; + value res; + int fd; + int optionValue; + HANDLE h; + Push_roots(a,1); + + + /* Set sockets to synchronous mode */ + optionValue = SO_SYNCHRONOUS_NONALERT; + setsockopt(INVALID_SOCKET, SOL_SOCKET, SO_OPENTYPE, + (char *)&optionValue, sizeof(optionValue)); + + sock_addr_len = sizeof(sock_addr); + h = _get_osfhandle(Int_val(sock)); + if (h == -1) uerror("accept", Nothing); + enter_blocking_section(); + s = accept(h, &sock_addr.s_gen, &sock_addr_len); + leave_blocking_section(); + if (s == INVALID_SOCKET) { + _dosmaperr(WSAGetLastError()); + uerror("accept", Nothing); + }; + a[0] = alloc_sockaddr(); + res = alloc_tuple(2); + fd = _open_osfhandle(s, 0); + if (fd == -1) uerror("accept", Nothing); + Field(res, 0) = Val_int(fd); + Field(res, 1) = a[0]; + Pop_roots(); + return res; +} + |