diff options
author | Xavier Leroy <xavier.leroy@inria.fr> | 2006-10-18 08:17:32 +0000 |
---|---|---|
committer | Xavier Leroy <xavier.leroy@inria.fr> | 2006-10-18 08:17:32 +0000 |
commit | 741d1e70781e74a523e3a142ec6176422671c8c1 (patch) | |
tree | bb654e809b7a5ab6f82a35f3f9bcc4fe3e01cf89 /otherlibs/win32unix/read.c | |
parent | b74f4b01e790de7c237a74ca12e2972443c81c5b (diff) |
PR#4097: Tentative fix, to be tested
git-svn-id: http://caml.inria.fr/svn/ocaml/trunk@7695 f963ae5c-01c2-4b8c-9fe0-0dff7051ff02
Diffstat (limited to 'otherlibs/win32unix/read.c')
-rw-r--r-- | otherlibs/win32unix/read.c | 25 |
1 files changed, 12 insertions, 13 deletions
diff --git a/otherlibs/win32unix/read.c b/otherlibs/win32unix/read.c index 704cec2c7..c87d55ed0 100644 --- a/otherlibs/win32unix/read.c +++ b/otherlibs/win32unix/read.c @@ -19,35 +19,34 @@ #include <signals.h> #include "unixsupport.h" -CAMLprim value unix_read(value fd, value buf, value ofs, value len) +CAMLprim value unix_read(value fd, value buf, value ofs, value vlen) { + intnat len; DWORD numbytes, numread; char iobuf[UNIX_BUFFER_SIZE]; + DOWRD errcode = 0; Begin_root (buf); - numbytes = Long_val(len); - if (numbytes > UNIX_BUFFER_SIZE) numbytes = UNIX_BUFFER_SIZE; + len = Long_val(vlen); + numbytes = len > UNIX_BUFFER_SIZE ? UNIX_BUFFER_SIZE : len; if (Descr_kind_val(fd) == KIND_SOCKET) { int ret; SOCKET s = Socket_val(fd); enter_blocking_section(); ret = recv(s, iobuf, numbytes, 0); + if (ret == SOCKET_ERROR) errcode = WSAGetLastError(); leave_blocking_section(); - if (ret == SOCKET_ERROR) { - win32_maperr(WSAGetLastError()); - uerror("read", Nothing); - } numread = ret; } else { - BOOL ret; HANDLE h = Handle_val(fd); enter_blocking_section(); - ret = ReadFile(h, iobuf, numbytes, &numread, NULL); + if (! ReadFile(h, iobuf, numbytes, &numread, NULL)) + errcode = GetLastError(); leave_blocking_section(); - if (! ret) { - win32_maperr(GetLastError()); - uerror("read", Nothing); - } + } + if (errcode) { + win32_maperr(errcode); + uerror("read", Nothing); } memmove (&Byte(buf, Long_val(ofs)), iobuf, numread); End_roots(); |