summaryrefslogtreecommitdiffstats
path: root/otherlibs/win32unix/socket.c
diff options
context:
space:
mode:
authorXavier Leroy <xavier.leroy@inria.fr>1996-09-04 14:17:43 +0000
committerXavier Leroy <xavier.leroy@inria.fr>1996-09-04 14:17:43 +0000
commita0c8d7373311facda78d250751203371cc0487b2 (patch)
treecfb65b4d0bff35f71cede7ae09e647433845236f /otherlibs/win32unix/socket.c
parentac9f8e8094ea19199a24fd5c67053718198ed172 (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/socket.c')
-rw-r--r--otherlibs/win32unix/socket.c46
1 files changed, 46 insertions, 0 deletions
diff --git a/otherlibs/win32unix/socket.c b/otherlibs/win32unix/socket.c
new file mode 100644
index 000000000..087ab5d14
--- /dev/null
+++ b/otherlibs/win32unix/socket.c
@@ -0,0 +1,46 @@
+/***********************************************************************/
+/* */
+/* Objective Caml */
+/* */
+/* Xavier Leroy and Pascal Cuoq, projet Cristal, INRIA Rocquencourt */
+/* */
+/* Copyright 1996 Institut National de Recherche en Informatique et */
+/* Automatique. Distributed only by permission. */
+/* */
+/***********************************************************************/
+
+/* $Id$ */
+
+#include <mlvalues.h>
+#include "unixwin.h"
+#include <sys/types.h>
+#include <winsock.h>
+
+int socket_domain_table[] = {
+ PF_UNIX, PF_INET
+};
+
+int socket_type_table[] = {
+ SOCK_STREAM, SOCK_DGRAM, SOCK_RAW, SOCK_SEQPACKET
+};
+
+value unix_socket(domain, type, proto) /* ML */
+ value domain, type, proto;
+{
+ SOCKET s;
+ int optionValue;
+
+ /* Set sockets to synchronous mode */
+ optionValue = SO_SYNCHRONOUS_NONALERT;
+ setsockopt(INVALID_SOCKET, SOL_SOCKET, SO_OPENTYPE,
+ (char *)&optionValue, sizeof(optionValue));
+
+ s = socket(socket_domain_table[Int_val(domain)],
+ socket_type_table[Int_val(type)],
+ Int_val(proto));
+ if (s == INVALID_SOCKET) {
+ _dosmaperr(WSAGetLastError());
+ uerror("socket", Nothing);
+ }
+ return Val_int(_open_osfhandle(s, 0));
+}