mirror of
https://github.com/ruby/ruby.git
synced 2025-09-16 17:14:01 +02:00
merge from trunk (r27718)
* win32/win32.c, include/ruby/win32.h (rb_w32_has_cancel_io): new function. * io.c (WAIT_FD_IN_WIN32): check only when it's not cancelable. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_2@27732 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
5b2c631d31
commit
52583c34d1
4 changed files with 17 additions and 2 deletions
|
@ -1,3 +1,10 @@
|
|||
Tue May 11 14:09:21 2010 NAKAMURA Usaku <usa@ruby-lang.org>
|
||||
|
||||
* win32/win32.c, include/ruby/win32.h (rb_w32_has_cancel_io): new
|
||||
function.
|
||||
|
||||
* io.c (WAIT_FD_IN_WIN32): check only when it's not cancelable.
|
||||
|
||||
Tue May 11 11:49:44 2010 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* ext/sdbm/sdbm.h (DBM): large file support on win32.
|
||||
|
|
|
@ -222,6 +222,7 @@ struct msghdr {
|
|||
extern int rb_w32_cmdvector(const char *, char ***);
|
||||
extern rb_pid_t rb_w32_pipe_exec(const char *, const char *, int, int *, int *);
|
||||
extern int flock(int fd, int oper);
|
||||
extern int rb_w32_has_cancel_io(void);
|
||||
extern int rb_w32_is_socket(int);
|
||||
extern int WSAAPI rb_w32_accept(int, struct sockaddr *, int *);
|
||||
extern int WSAAPI rb_w32_bind(int, const struct sockaddr *, int);
|
||||
|
|
5
io.c
5
io.c
|
@ -189,9 +189,10 @@ static int max_file_descriptor = NOFILE;
|
|||
#define READ_CHAR_PENDING(fptr) ((fptr)->cbuf_len)
|
||||
|
||||
#if defined(_WIN32)
|
||||
#define WAIT_FD_IN_WIN32(fptr) rb_thread_wait_fd((fptr)->fd);
|
||||
#define WAIT_FD_IN_WIN32(fptr) \
|
||||
(rb_w32_has_cancel_io() ? 0 : rb_thread_wait_fd((fptr)->fd))
|
||||
#else
|
||||
#define WAIT_FD_IN_WIN32(fptr) ;
|
||||
#define WAIT_FD_IN_WIN32(fptr)
|
||||
#endif
|
||||
|
||||
#define READ_CHECK(fptr) do {\
|
||||
|
|
|
@ -548,6 +548,12 @@ init_env(void)
|
|||
typedef BOOL (WINAPI *cancel_io_t)(HANDLE);
|
||||
static cancel_io_t cancel_io = NULL;
|
||||
|
||||
int
|
||||
rb_w32_has_cancel_io(void)
|
||||
{
|
||||
return cancel_io != NULL;
|
||||
}
|
||||
|
||||
static void
|
||||
init_func(void)
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue