Skip to content

Commit

Permalink
merges r21096 from trunk into ruby_1_9_1.
Browse files Browse the repository at this point in the history
* thread.c (rb_thread_atfork, rb_thread_atfork_before_exec): DRY.

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_1@21125 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
  • Loading branch information
yugui committed Dec 28, 2008
1 parent 61974ea commit 6a0e407
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 24 deletions.
4 changes: 4 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
Sat Dec 27 19:30:01 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>

* thread.c (rb_thread_atfork, rb_thread_atfork_before_exec): DRY.

Sat Dec 27 17:08:43 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>

* .gdbinit (dummy_gdb_enums.special_consts): forces to load debug
Expand Down
45 changes: 21 additions & 24 deletions thread.c
Original file line number Diff line number Diff line change
Expand Up @@ -2438,14 +2438,29 @@ clear_coverage(void)
}
}

static void
rb_thread_atfork_internal(int (*atfork)(st_data_t, st_data_t, st_data_t))
{
rb_thread_t *th = GET_THREAD();
rb_vm_t *vm = th->vm;
VALUE thval = th->self;
vm->main_thread = th;

st_foreach(vm->living_threads, atfork, (st_data_t)th);
st_clear(vm->living_threads);
st_insert(vm->living_threads, thval, (st_data_t)th->thread_id);
vm->sleeper = 0;
clear_coverage();
}

static int
terminate_atfork_i(st_data_t key, st_data_t val, rb_thread_t *current_th)
terminate_atfork_i(st_data_t key, st_data_t val, st_data_t current_th)
{
VALUE thval = key;
rb_thread_t *th;
GetThreadPtr(thval, th);

if (th != current_th) {
if (th != (rb_thread_t *)current_th) {
thread_cleanup_func(th);
}
return ST_CONTINUE;
Expand All @@ -2454,27 +2469,18 @@ terminate_atfork_i(st_data_t key, st_data_t val, rb_thread_t *current_th)
void
rb_thread_atfork(void)
{
rb_thread_t *th = GET_THREAD();
rb_vm_t *vm = th->vm;
VALUE thval = th->self;
vm->main_thread = th;

st_foreach(vm->living_threads, terminate_atfork_i, (st_data_t)th);
st_clear(vm->living_threads);
st_insert(vm->living_threads, thval, (st_data_t) th->thread_id);
vm->sleeper = 0;
clear_coverage();
rb_thread_atfork_internal(terminate_atfork_i);
rb_reset_random_seed();
}

static int
terminate_atfork_before_exec_i(st_data_t key, st_data_t val, rb_thread_t *current_th)
terminate_atfork_before_exec_i(st_data_t key, st_data_t val, st_data_t current_th)
{
VALUE thval = key;
rb_thread_t *th;
GetThreadPtr(thval, th);

if (th != current_th) {
if (th != (rb_thread_t *)current_th) {
thread_cleanup_func_before_exec(th);
}
return ST_CONTINUE;
Expand All @@ -2483,16 +2489,7 @@ terminate_atfork_before_exec_i(st_data_t key, st_data_t val, rb_thread_t *curren
void
rb_thread_atfork_before_exec(void)
{
rb_thread_t *th = GET_THREAD();
rb_vm_t *vm = th->vm;
VALUE thval = th->self;
vm->main_thread = th;

st_foreach(vm->living_threads, terminate_atfork_before_exec_i, (st_data_t)th);
st_clear(vm->living_threads);
st_insert(vm->living_threads, thval, (st_data_t) th->thread_id);
vm->sleeper = 0;
clear_coverage();
rb_thread_atfork_internal(terminate_atfork_before_exec_i);
}

struct thgroup {
Expand Down

0 comments on commit 6a0e407

Please sign in to comment.