diff options
author | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-10-11 17:33:44 +0000 |
---|---|---|
committer | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-10-11 17:33:44 +0000 |
commit | 7aecb95637e222bcc46453059a8b306e9197b063 (patch) | |
tree | 29117cd9a569bf22a817fcbba1af9bd1222a8748 | |
parent | 588586d9d4a15fdf982291eb59484fd6f7273417 (diff) |
* class.c, variable.c, gc.c (rb_class_tbl): removed.
rb_class_tbl is no longer used.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@43259 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | class.c | 5 | ||||
-rw-r--r-- | gc.c | 11 | ||||
-rw-r--r-- | variable.c | 5 |
4 files changed, 11 insertions, 15 deletions
@@ -1,3 +1,8 @@ +Sat Oct 12 02:32:42 2013 Koichi Sasada <ko1@atdot.net> + + * class.c, variable.c, gc.c (rb_class_tbl): removed. + rb_class_tbl is no longer used. + Fri Oct 11 21:05:19 2013 Koichi Sasada <ko1@atdot.net> * internal.h, parse.y: use `full_mark' instead of `full_marking'. @@ -31,7 +31,6 @@ #include "internal.h" #include <ctype.h> -extern st_table *rb_class_tbl; #define id_attached id__attached__ void @@ -517,12 +516,10 @@ make_singleton_class(VALUE obj) static VALUE boot_defclass(const char *name, VALUE super) { - extern st_table *rb_class_tbl; VALUE obj = rb_class_boot(super); ID id = rb_intern(name); rb_name_class(obj, id); - st_add_direct(rb_class_tbl, id, obj); rb_const_set((rb_cObject ? rb_cObject : obj), id, obj); return obj; } @@ -643,7 +640,6 @@ rb_define_class(const char *name, VALUE super) rb_warn("no super class for `%s', Object assumed", name); } klass = rb_define_class_id(id, super); - st_add_direct(rb_class_tbl, id, klass); rb_name_class(klass, id); rb_const_set(rb_cObject, id, klass); rb_class_inherited(super, klass); @@ -754,7 +750,6 @@ rb_define_module(const char *name) rb_raise(rb_eTypeError, "%s is not a module", rb_obj_classname(module)); } module = rb_define_module_id(id); - st_add_direct(rb_class_tbl, id, module); rb_const_set(rb_cObject, id, module); return module; @@ -535,7 +535,6 @@ VALUE *ruby_initial_gc_stress_ptr = &rb_objspace.gc_stress; int ruby_gc_debug_indent = 0; VALUE rb_mGC; -extern st_table *rb_class_tbl; int ruby_disable_gc_stress = 0; void rb_gcdebug_print_obj_condition(VALUE obj); @@ -3574,13 +3573,18 @@ gc_marks_body(rb_objspace_t *objspace, int full_mark) th->vm->self ? rb_gc_mark(th->vm->self) : rb_vm_mark(th->vm); MARK_CHECKPOINT; - mark_tbl(objspace, finalizer_table); + rb_gc_mark(rb_cObject); MARK_CHECKPOINT; mark_current_machine_context(objspace, th); MARK_CHECKPOINT; + mark_tbl(objspace, finalizer_table); + + MARK_CHECKPOINT; + objspace->rgengc.parent_object_is_promoted = TRUE; rb_gc_mark_symbols(full_mark); + objspace->rgengc.parent_object_is_promoted = FALSE; MARK_CHECKPOINT; rb_gc_mark_encodings(); @@ -3597,9 +3601,6 @@ gc_marks_body(rb_objspace_t *objspace, int full_mark) MARK_CHECKPOINT; rb_gc_mark_global_tbl(); - MARK_CHECKPOINT; - mark_tbl(objspace, rb_class_tbl); - /* mark generic instance variables for special constants */ MARK_CHECKPOINT; rb_mark_generic_ivar_tbl(); diff --git a/variable.c b/variable.c index 3b3189bddc..fa4a769b33 100644 --- a/variable.c +++ b/variable.c @@ -21,14 +21,12 @@ #include "id.h" st_table *rb_global_tbl; -st_table *rb_class_tbl; static ID autoload, classpath, tmp_classpath, classid; void Init_var_tables(void) { rb_global_tbl = st_init_numtable(); - rb_class_tbl = st_init_numtable(); CONST_ID(autoload, "__autoload__"); /* __classpath__: fully qualified class path */ CONST_ID(classpath, "__classpath__"); @@ -135,9 +133,6 @@ find_class_path(VALUE klass, ID preferred) if (RCLASS_CONST_TBL(rb_cObject)) { st_foreach_safe(RCLASS_CONST_TBL(rb_cObject), fc_i, (st_data_t)&arg); } - if (arg.path == 0) { - st_foreach_safe(rb_class_tbl, fc_i, (st_data_t)&arg); - } if (arg.path) { st_data_t tmp = tmp_classpath; if (!RCLASS_IV_TBL(klass)) { |