diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-12-02 00:31:17 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-12-02 00:31:17 +0000 |
commit | fc0fcec74e5a9817e6d1e2b100fdb0e78b71e9b9 (patch) | |
tree | 35ffa1fb7bc0fd6ba9fc19021d6fd7e2405d5a23 | |
parent | aa997fca3e0ebde50ea9121c14eeb5c82d749a53 (diff) | |
download | ruby-fc0fcec74e5a9817e6d1e2b100fdb0e78b71e9b9.tar.gz |
* eval.c (thread_mark): mark thread group. [ruby-dev:25020]
* eval.c (thgroup_add): check whether the argument is really a Thread.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@7436 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | eval.c | 5 |
2 files changed, 11 insertions, 0 deletions
@@ -1,3 +1,9 @@ +Thu Dec 2 09:30:58 2004 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * eval.c (thread_mark): mark thread group. [ruby-dev:25020] + + * eval.c (thgroup_add): check whether the argument is really a Thread. + Thu Dec 2 07:57:16 2004 Yukihiro Matsumoto <matz@ruby-lang.org> * io.c (rb_io_ctl): [ruby-dev:25019] @@ -9786,6 +9786,7 @@ thread_mark(th) rb_gc_mark(th->last_line); rb_gc_mark(th->last_match); rb_mark_tbl(th->locals); + rb_gc_mark(th->thgroup); /* mark data in copied stack */ if (th == curr_thread) return; @@ -12480,6 +12481,10 @@ thgroup_add(group, thread) rb_secure(4); th = rb_thread_check(thread); + if (!th->next || !th->prev) { + rb_raise(rb_eTypeError, "wrong argument type %s (expected Thread)", + rb_obj_classname(thread)); + } if (OBJ_FROZEN(group)) { rb_raise(rb_eThreadError, "can't move to the frozen thread group"); |