summaryrefslogtreecommitdiffstats
path: root/vm_core.h
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-07-05 05:04:41 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-07-05 05:04:41 +0000
commit4ac1fbee630eeccd2c1b2f90586b1e76de0a2286 (patch)
treea810917b0517707971dc9f4f9bb5392f02fb2b52 /vm_core.h
parent69b7b66a107e81d6a20fbabd74c28ccb6b0eecfa (diff)
downloadruby-4ac1fbee630eeccd2c1b2f90586b1e76de0a2286.tar.gz
ruby-4ac1fbee630eeccd2c1b2f90586b1e76de0a2286.tar.xz
ruby-4ac1fbee630eeccd2c1b2f90586b1e76de0a2286.zip
* thread.c (rb_threadptr_exec_event_hooks): new function to
execute event hooks, with preserving errinfo. [ruby-core:24118] git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@23959 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'vm_core.h')
-rw-r--r--vm_core.h22
1 files changed, 3 insertions, 19 deletions
diff --git a/vm_core.h b/vm_core.h
index 43784803d..8019e63a2 100644
--- a/vm_core.h
+++ b/vm_core.h
@@ -639,30 +639,14 @@ void rb_threadptr_execute_interrupts(rb_thread_t *);
RUBY_VM_CHECK_INTS_TH(GET_THREAD())
/* tracer */
-static inline void
-exec_event_hooks(rb_event_hook_t *hook, rb_event_flag_t flag, VALUE self, ID id, VALUE klass)
-{
- if (self == rb_mRubyVMFrozenCore) return;
- while (hook) {
- if (flag & hook->flag) {
- (*hook->func)(flag, hook->data, self, id, klass);
- }
- hook = hook->next;
- }
-}
+void
+rb_threadptr_exec_event_hooks(rb_thread_t *th, rb_event_flag_t flag, VALUE self, ID id, VALUE klass);
#define EXEC_EVENT_HOOK(th, flag, self, id, klass) do { \
rb_event_flag_t wait_event__ = th->event_flags; \
if (UNLIKELY(wait_event__)) { \
if (wait_event__ & (flag | RUBY_EVENT_VM)) { \
- VALUE self__ = (self), klass__ = (klass); \
- ID id__ = (id); \
- if (wait_event__ & flag) { \
- exec_event_hooks(th->event_hooks, flag, self__, id__, klass__); \
- } \
- if (wait_event__ & RUBY_EVENT_VM) { \
- exec_event_hooks(th->vm->event_hooks, flag, self__, id__, klass__); \
- } \
+ rb_threadptr_exec_event_hooks(th, flag, self, id, klass); \
} \
} \
} while (0)