From a0c8d7373311facda78d250751203371cc0487b2 Mon Sep 17 00:00:00 2001 From: Xavier Leroy Date: Wed, 4 Sep 1996 14:17:43 +0000 Subject: Merge du stage de Pascal Cuoq git-svn-id: http://caml.inria.fr/svn/ocaml/trunk@952 f963ae5c-01c2-4b8c-9fe0-0dff7051ff02 --- otherlibs/win32unix/socket.c | 46 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 otherlibs/win32unix/socket.c (limited to 'otherlibs/win32unix/socket.c') 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 +#include "unixwin.h" +#include +#include + +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)); +} -- cgit v1.2.3-70-g09d2