diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-01-02 17:46:02 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-01-02 17:46:02 +0000 |
commit | 88fb246cc7944b7feb5585a4f4ac3248df4b7770 (patch) | |
tree | 906f911a84793e8a665d6e1b5c5c6c18d1be0844 | |
parent | 59dbfa3e4cc8d4705ef5a4abd9904fa523f26bfa (diff) |
* rubysig.h (TRAP_END): preserve errno before switching context.
[ruby-core:02137]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@5366 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | rubysig.h | 13 |
2 files changed, 15 insertions, 3 deletions
@@ -1,3 +1,8 @@ +Sat Jan 3 02:44:48 2004 Yukihiro Matsumoto <[email protected]> + + * rubysig.h (TRAP_END): preserve errno before switching context. + [ruby-core:02137] + Sat Jan 3 01:18:08 2004 Yukihiro Matsumoto <[email protected]> * dir.c: merge tuning from H.Yamamoto <[email protected]>. @@ -23,10 +23,13 @@ typedef LONG rb_atomic_t; /* Windows doesn't allow interrupt while system calls */ # define TRAP_BEG do {\ + extern int errno;\ rb_atomic_t trap_immediate = ATOMIC_SET(rb_trap_immediate, 1) # define TRAP_END\ - ATOMIC_SET(rb_trap_immediate, trap_immediate);\ - CHECK_INTS;\ + ATOMIC_SET(rb_trap_immediate, trap_immediate);\ + saved_errno = errno;\ + CHECK_INTS;\ + errno = saved_errno;\ } while (0) # define RUBY_CRITICAL(statements) do {\ rb_w32_enter_critical();\ @@ -42,10 +45,14 @@ typedef int rb_atomic_t; # define ATOMIC_DEC(var) (--(var)) # define TRAP_BEG do {\ + extern int errno;\ + int saved_errno = 0;\ int trap_immediate = rb_trap_immediate;\ rb_trap_immediate = 1 # define TRAP_END rb_trap_immediate = trap_immediate;\ - CHECK_INTS;\ + saved_errno = errno;\ + CHECK_INTS;\ + errno = saved_errno;\ } while (0) # define RUBY_CRITICAL(statements) do {\ |