summaryrefslogtreecommitdiffstats
path: root/otherlibs/win32unix/getpeername.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/getpeername.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/getpeername.c')
-rw-r--r--otherlibs/win32unix/getpeername.c31
1 files changed, 31 insertions, 0 deletions
diff --git a/otherlibs/win32unix/getpeername.c b/otherlibs/win32unix/getpeername.c
new file mode 100644
index 000000000..2921d3a70
--- /dev/null
+++ b/otherlibs/win32unix/getpeername.c
@@ -0,0 +1,31 @@
+/***********************************************************************/
+/* */
+/* 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 "unixsupport.h"
+#include "socketaddr.h"
+
+value unix_getpeername(sock) /* ML */
+ value sock;
+{
+ int retcode;
+
+ sock_addr_len = sizeof(sock_addr);
+ retcode = getpeername(_get_osfhandle(Int_val(sock)),
+ &sock_addr.s_gen, &sock_addr_len);
+ if (retcode == -1) {
+ _dosmaperr(WSAGetLastError());
+ uerror("getpeername", Nothing);
+ }
+ return alloc_sockaddr();
+}