зеркало из https://github.com/github/ruby.git
* win32/win32.c (rb_w32_accept): secure fd before accept because if
error causes in securing, cannot restore the state of accepted socket. fixed [ruby-core:19728] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@20189 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
Родитель
0d93d8125e
Коммит
d544a3d6c7
|
@ -1,3 +1,10 @@
|
|||
Tue Nov 11 17:35:25 2008 NAKAMURA Usaku <usa@ruby-lang.org>
|
||||
|
||||
* win32/win32.c (rb_w32_accept): secure fd before accept because if
|
||||
error causes in securing, cannot restore the state of accepted
|
||||
socket.
|
||||
fixed [ruby-core:19728]
|
||||
|
||||
Tue Nov 11 14:40:40 2008 Martin Duerst <duerst@it.aoyama.ac.jp>
|
||||
|
||||
* test/ruby/test_transcode.rb: unnecessary setup method
|
||||
|
|
|
@ -2296,25 +2296,33 @@ int WSAAPI
|
|||
rb_w32_accept(int s, struct sockaddr *addr, int *addrlen)
|
||||
{
|
||||
SOCKET r;
|
||||
int fd;
|
||||
|
||||
if (!NtSocketsInitialized) {
|
||||
StartSockets();
|
||||
}
|
||||
RUBY_CRITICAL({
|
||||
r = accept(TO_SOCKET(s), addr, addrlen);
|
||||
if (r == INVALID_SOCKET) {
|
||||
errno = map_errno(WSAGetLastError());
|
||||
s = -1;
|
||||
}
|
||||
else {
|
||||
s = rb_w32_open_osfhandle(r, O_RDWR|O_BINARY|O_NOINHERIT);
|
||||
if (s != -1)
|
||||
HANDLE h = CreateFile("NUL", 0, 0, NULL, OPEN_ALWAYS, 0, NULL);
|
||||
fd = rb_w32_open_osfhandle((intptr_t)h, O_RDWR|O_BINARY|O_NOINHERIT);
|
||||
if (fd != -1) {
|
||||
r = accept(TO_SOCKET(s), addr, addrlen);
|
||||
if (r != INVALID_SOCKET) {
|
||||
MTHREAD_ONLY(EnterCriticalSection(&(_pioinfo(fd)->lock)));
|
||||
_set_osfhnd(fd, r);
|
||||
MTHREAD_ONLY(LeaveCriticalSection(&_pioinfo(fd)->lock));
|
||||
CloseHandle(h);
|
||||
st_insert(socklist, (st_data_t)r, (st_data_t)0);
|
||||
else
|
||||
closesocket(r);
|
||||
}
|
||||
else {
|
||||
errno = map_errno(WSAGetLastError());
|
||||
close(fd);
|
||||
fd = -1;
|
||||
}
|
||||
}
|
||||
else
|
||||
CloseHandle(h);
|
||||
});
|
||||
return s;
|
||||
return fd;
|
||||
}
|
||||
|
||||
#undef bind
|
||||
|
|
Загрузка…
Ссылка в новой задаче