mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	* class.c, constant.h, gc.c, method.h, object.c, variable.c,
vm_insnhelper.c: use struct rb_constant_entry_t as entry of RCLASS_CONST_TBL. RCLASS_CONST_TBL has contained VALUE of constant directly. Now instead rb_const_entry_t is contained in RCLASS_CONST_TBL, rb_const_entry_t is managed by malloc, and have not only the value itself but also visibility flag. This is another preparation for private constant (see [ruby-dev:39685][ruby-core:32698]). git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@29602 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
		
							parent
							
								
									e169ea0cac
								
							
						
					
					
						commit
						a115768161
					
				
					 8 changed files with 116 additions and 18 deletions
				
			
		
							
								
								
									
										11
									
								
								ChangeLog
									
										
									
									
									
								
							
							
						
						
									
										11
									
								
								ChangeLog
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -1,3 +1,14 @@
 | 
			
		|||
Wed Oct 27 02:02:54 2010  Yusuke Endoh  <mame@tsg.ne.jp>
 | 
			
		||||
 | 
			
		||||
	* class.c, constant.h, gc.c, method.h, object.c, variable.c,
 | 
			
		||||
	  vm_insnhelper.c: use struct rb_constant_entry_t as entry of
 | 
			
		||||
	  RCLASS_CONST_TBL.  RCLASS_CONST_TBL has contained VALUE of constant
 | 
			
		||||
	  directly.  Now instead rb_const_entry_t is contained in
 | 
			
		||||
	  RCLASS_CONST_TBL,  rb_const_entry_t is managed by malloc, and
 | 
			
		||||
	  have not only the value itself but also visibility flag.
 | 
			
		||||
	  This is another preparation for private constant (see
 | 
			
		||||
	  [ruby-dev:39685][ruby-core:32698]).
 | 
			
		||||
 | 
			
		||||
Wed Oct 27 01:56:34 2010  Yusuke Endoh  <mame@tsg.ne.jp>
 | 
			
		||||
 | 
			
		||||
	* class.c, gc.c, object.c, variable.c, vm_insnhelper.c,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										18
									
								
								class.c
									
										
									
									
									
								
							
							
						
						
									
										18
									
								
								class.c
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -26,6 +26,7 @@
 | 
			
		|||
#include "ruby/ruby.h"
 | 
			
		||||
#include "ruby/st.h"
 | 
			
		||||
#include "method.h"
 | 
			
		||||
#include "constant.h"
 | 
			
		||||
#include "vm_core.h"
 | 
			
		||||
#include <ctype.h>
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -140,6 +141,14 @@ clone_method(ID mid, const rb_method_entry_t *me, struct clone_method_data *data
 | 
			
		|||
    return ST_CONTINUE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static int
 | 
			
		||||
clone_const(ID key, const rb_const_entry_t *ce, st_table *tbl)
 | 
			
		||||
{
 | 
			
		||||
    rb_const_entry_t *nce = ALLOC(rb_const_entry_t);
 | 
			
		||||
    *nce = *ce;
 | 
			
		||||
    st_insert(tbl, key, (st_data_t)nce);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* :nodoc: */
 | 
			
		||||
VALUE
 | 
			
		||||
rb_mod_init_copy(VALUE clone, VALUE orig)
 | 
			
		||||
| 
						 | 
				
			
			@ -164,15 +173,15 @@ rb_mod_init_copy(VALUE clone, VALUE orig)
 | 
			
		|||
    }
 | 
			
		||||
    if (RCLASS_CONST_TBL(orig)) {
 | 
			
		||||
	if (RCLASS_CONST_TBL(clone)) {
 | 
			
		||||
	    st_free_table(RCLASS_CONST_TBL(clone));
 | 
			
		||||
	    rb_free_const_table(RCLASS_CONST_TBL(clone));
 | 
			
		||||
	}
 | 
			
		||||
	RCLASS_CONST_TBL(clone) = st_copy(RCLASS_CONST_TBL(orig));
 | 
			
		||||
	RCLASS_CONST_TBL(clone) = st_init_numtable();
 | 
			
		||||
	st_foreach(RCLASS_CONST_TBL(orig), clone_const, (st_data_t)RCLASS_CONST_TBL(clone));
 | 
			
		||||
    }
 | 
			
		||||
    if (RCLASS_M_TBL(orig)) {
 | 
			
		||||
	struct clone_method_data data;
 | 
			
		||||
 | 
			
		||||
	if (RCLASS_M_TBL(clone)) {
 | 
			
		||||
	    extern void rb_free_m_table(st_table *tbl);
 | 
			
		||||
	    rb_free_m_table(RCLASS_M_TBL(clone));
 | 
			
		||||
	}
 | 
			
		||||
	data.tbl = RCLASS_M_TBL(clone) = st_init_numtable();
 | 
			
		||||
| 
						 | 
				
			
			@ -224,7 +233,8 @@ rb_singleton_class_clone(VALUE obj)
 | 
			
		|||
	    RCLASS_IV_TBL(clone) = st_copy(RCLASS_IV_TBL(klass));
 | 
			
		||||
	}
 | 
			
		||||
	if (RCLASS_CONST_TBL(klass)) {
 | 
			
		||||
	    RCLASS_CONST_TBL(clone) = st_copy(RCLASS_CONST_TBL(klass));
 | 
			
		||||
	    RCLASS_CONST_TBL(clone) = st_init_numtable();
 | 
			
		||||
	    st_foreach(RCLASS_CONST_TBL(klass), clone_const, (st_data_t)RCLASS_CONST_TBL(clone));
 | 
			
		||||
	}
 | 
			
		||||
	RCLASS_M_TBL(clone) = st_init_numtable();
 | 
			
		||||
	data.tbl = RCLASS_M_TBL(clone);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										26
									
								
								constant.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								constant.h
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,26 @@
 | 
			
		|||
/**********************************************************************
 | 
			
		||||
 | 
			
		||||
  constant.h -
 | 
			
		||||
 | 
			
		||||
  $Author$
 | 
			
		||||
  created at: Sun Nov 15 00:09:33 2009
 | 
			
		||||
 | 
			
		||||
  Copyright (C) 2009 Yusuke Endoh
 | 
			
		||||
 | 
			
		||||
**********************************************************************/
 | 
			
		||||
#ifndef CONSTANT_H
 | 
			
		||||
#define CONSTANT_H
 | 
			
		||||
 | 
			
		||||
typedef enum {
 | 
			
		||||
    CONST_PUBLIC    = 0x00,
 | 
			
		||||
    CONST_PRIVATE   = 0x01,
 | 
			
		||||
} rb_const_flag_t;
 | 
			
		||||
 | 
			
		||||
typedef struct rb_const_entry_struct {
 | 
			
		||||
    rb_const_flag_t flag;
 | 
			
		||||
    VALUE value;            /* should be mark */
 | 
			
		||||
} rb_const_entry_t;
 | 
			
		||||
 | 
			
		||||
void rb_free_const_table(st_table *tbl);
 | 
			
		||||
 | 
			
		||||
#endif /* CONSTANT_H */
 | 
			
		||||
							
								
								
									
										37
									
								
								gc.c
									
										
									
									
									
								
							
							
						
						
									
										37
									
								
								gc.c
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -19,6 +19,7 @@
 | 
			
		|||
#include "eval_intern.h"
 | 
			
		||||
#include "vm_core.h"
 | 
			
		||||
#include "gc.h"
 | 
			
		||||
#include "constant.h"
 | 
			
		||||
#include <stdio.h>
 | 
			
		||||
#include <setjmp.h>
 | 
			
		||||
#include <sys/types.h>
 | 
			
		||||
| 
						 | 
				
			
			@ -1504,6 +1505,38 @@ rb_free_m_table(st_table *tbl)
 | 
			
		|||
    st_free_table(tbl);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static int
 | 
			
		||||
mark_const_entry_i(ID key, const rb_const_entry_t *ce, st_data_t data)
 | 
			
		||||
{
 | 
			
		||||
    struct mark_tbl_arg *arg = (void*)data;
 | 
			
		||||
    gc_mark(arg->objspace, ce->value, arg->lev);
 | 
			
		||||
    return ST_CONTINUE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
mark_const_tbl(rb_objspace_t *objspace, st_table *tbl, int lev)
 | 
			
		||||
{
 | 
			
		||||
    struct mark_tbl_arg arg;
 | 
			
		||||
    if (!tbl) return;
 | 
			
		||||
    arg.objspace = objspace;
 | 
			
		||||
    arg.lev = lev;
 | 
			
		||||
    st_foreach(tbl, mark_const_entry_i, (st_data_t)&arg);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static int
 | 
			
		||||
free_const_entry_i(ID key, rb_const_entry_t *ce, st_data_t data)
 | 
			
		||||
{
 | 
			
		||||
    xfree(ce);
 | 
			
		||||
    return ST_CONTINUE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
rb_free_const_table(st_table *tbl)
 | 
			
		||||
{
 | 
			
		||||
    st_foreach(tbl, free_const_entry_i, 0);
 | 
			
		||||
    st_free_table(tbl);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
rb_mark_tbl(st_table *tbl)
 | 
			
		||||
{
 | 
			
		||||
| 
						 | 
				
			
			@ -1718,7 +1751,7 @@ gc_mark_children(rb_objspace_t *objspace, VALUE ptr, int lev)
 | 
			
		|||
      case T_MODULE:
 | 
			
		||||
	mark_m_tbl(objspace, RCLASS_M_TBL(obj), lev);
 | 
			
		||||
	mark_tbl(objspace, RCLASS_IV_TBL(obj), lev);
 | 
			
		||||
	mark_tbl(objspace, RCLASS_CONST_TBL(obj), lev);
 | 
			
		||||
	mark_const_tbl(objspace, RCLASS_CONST_TBL(obj), lev);
 | 
			
		||||
	ptr = RCLASS_SUPER(obj);
 | 
			
		||||
	goto again;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -2181,7 +2214,7 @@ obj_free(rb_objspace_t *objspace, VALUE obj)
 | 
			
		|||
	    st_free_table(RCLASS_IV_TBL(obj));
 | 
			
		||||
	}
 | 
			
		||||
	if (RCLASS_CONST_TBL(obj)) {
 | 
			
		||||
	    st_free_table(RCLASS_CONST_TBL(obj));
 | 
			
		||||
	    rb_free_const_table(RCLASS_CONST_TBL(obj));
 | 
			
		||||
	}
 | 
			
		||||
	if (RCLASS_IV_INDEX_TBL(obj)) {
 | 
			
		||||
	    st_free_table(RCLASS_IV_INDEX_TBL(obj));
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										1
									
								
								method.h
									
										
									
									
									
								
							
							
						
						
									
										1
									
								
								method.h
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -99,5 +99,6 @@ int rb_method_entry_arity(const rb_method_entry_t *me);
 | 
			
		|||
void rb_mark_method_entry(const rb_method_entry_t *me);
 | 
			
		||||
void rb_free_method_entry(rb_method_entry_t *me);
 | 
			
		||||
void rb_sweep_method_entry(void *vm);
 | 
			
		||||
void rb_free_m_table(st_table *tbl);
 | 
			
		||||
 | 
			
		||||
#endif /* METHOD_H */
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										3
									
								
								object.c
									
										
									
									
									
								
							
							
						
						
									
										3
									
								
								object.c
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -19,6 +19,7 @@
 | 
			
		|||
#include <ctype.h>
 | 
			
		||||
#include <math.h>
 | 
			
		||||
#include <float.h>
 | 
			
		||||
#include "constant.h"
 | 
			
		||||
 | 
			
		||||
VALUE rb_cBasicObject;
 | 
			
		||||
VALUE rb_mKernel;
 | 
			
		||||
| 
						 | 
				
			
			@ -222,7 +223,7 @@ init_copy(VALUE dest, VALUE obj)
 | 
			
		|||
	    RCLASS_IV_TBL(dest) = 0;
 | 
			
		||||
	}
 | 
			
		||||
	if (RCLASS_CONST_TBL(dest)) {
 | 
			
		||||
	    st_free_table(RCLASS_CONST_TBL(dest));
 | 
			
		||||
	    rb_free_const_table(RCLASS_CONST_TBL(dest));
 | 
			
		||||
	    RCLASS_CONST_TBL(dest) = 0;
 | 
			
		||||
	}
 | 
			
		||||
	if (RCLASS_IV_TBL(obj)) {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										35
									
								
								variable.c
									
										
									
									
									
								
							
							
						
						
									
										35
									
								
								variable.c
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -16,6 +16,7 @@
 | 
			
		|||
#include "ruby/util.h"
 | 
			
		||||
#include "ruby/encoding.h"
 | 
			
		||||
#include "node.h"
 | 
			
		||||
#include "constant.h"
 | 
			
		||||
 | 
			
		||||
void rb_vm_change_state(void);
 | 
			
		||||
void rb_vm_inc_const_missing_count(void);
 | 
			
		||||
| 
						 | 
				
			
			@ -71,8 +72,9 @@ fc_path(struct fc_result *fc, ID name)
 | 
			
		|||
}
 | 
			
		||||
 | 
			
		||||
static int
 | 
			
		||||
fc_i(ID key, VALUE value, struct fc_result *res)
 | 
			
		||||
fc_i(ID key, rb_const_entry_t *ce, struct fc_result *res)
 | 
			
		||||
{
 | 
			
		||||
    VALUE value = ce->value;
 | 
			
		||||
    if (!rb_is_const_id(key)) return ST_CONTINUE;
 | 
			
		||||
 | 
			
		||||
    if (value == res->klass) {
 | 
			
		||||
| 
						 | 
				
			
			@ -1439,7 +1441,7 @@ rb_autoload(VALUE mod, ID id, const char *file)
 | 
			
		|||
	rb_raise(rb_eArgError, "empty file name");
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if ((tbl = RCLASS_CONST_TBL(mod)) && st_lookup(tbl, (st_data_t)id, &av) && (VALUE)av != Qundef)
 | 
			
		||||
    if ((tbl = RCLASS_CONST_TBL(mod)) && st_lookup(tbl, (st_data_t)id, &av) && ((rb_const_entry_t*)av)->value != Qundef)
 | 
			
		||||
	return;
 | 
			
		||||
 | 
			
		||||
    rb_const_set(mod, id, Qundef);
 | 
			
		||||
| 
						 | 
				
			
			@ -1463,8 +1465,11 @@ static NODE*
 | 
			
		|||
autoload_delete(VALUE mod, ID id)
 | 
			
		||||
{
 | 
			
		||||
    st_data_t val, load = 0, n = id;
 | 
			
		||||
    rb_const_entry_t *ce;
 | 
			
		||||
 | 
			
		||||
    st_delete(RCLASS_CONST_TBL(mod), &n, 0);
 | 
			
		||||
    st_delete(RCLASS_CONST_TBL(mod), &n, &val);
 | 
			
		||||
    ce = (rb_const_entry_t*)val;
 | 
			
		||||
    if (ce) xfree(ce);
 | 
			
		||||
    if (st_lookup(RCLASS_IV_TBL(mod), (st_data_t)autoload, &val)) {
 | 
			
		||||
	struct st_table *tbl = check_autoload_table((VALUE)val);
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -1473,6 +1478,8 @@ autoload_delete(VALUE mod, ID id)
 | 
			
		|||
	if (tbl->num_entries == 0) {
 | 
			
		||||
	    n = autoload;
 | 
			
		||||
	    st_delete(RCLASS_CONST_TBL(mod), &n, &val);
 | 
			
		||||
	    ce = (rb_const_entry_t*)val;
 | 
			
		||||
	    if (ce) xfree(ce);
 | 
			
		||||
	}
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -1532,7 +1539,7 @@ autoload_node_id(VALUE mod, ID id)
 | 
			
		|||
    struct st_table *tbl = RCLASS_CONST_TBL(mod);
 | 
			
		||||
    st_data_t val;
 | 
			
		||||
 | 
			
		||||
    if (!tbl || !st_lookup(tbl, (st_data_t)id, &val) || (VALUE)val != Qundef) {
 | 
			
		||||
    if (!tbl || !st_lookup(tbl, (st_data_t)id, &val) || ((rb_const_entry_t*)val)->value != Qundef) {
 | 
			
		||||
	return 0;
 | 
			
		||||
    }
 | 
			
		||||
    return 1;
 | 
			
		||||
| 
						 | 
				
			
			@ -1579,7 +1586,7 @@ rb_const_get_0(VALUE klass, ID id, int exclude, int recurse)
 | 
			
		|||
	VALUE am = 0;
 | 
			
		||||
	st_data_t data;
 | 
			
		||||
	while (RCLASS_CONST_TBL(tmp) && st_lookup(RCLASS_CONST_TBL(tmp), (st_data_t)id, &data)) {
 | 
			
		||||
	    value = (VALUE)data;
 | 
			
		||||
	    value = ((rb_const_entry_t*)data)->value;
 | 
			
		||||
	    if (value == Qundef) {
 | 
			
		||||
		if (am == tmp) break;
 | 
			
		||||
		am = tmp;
 | 
			
		||||
| 
						 | 
				
			
			@ -1666,16 +1673,17 @@ rb_const_remove(VALUE mod, ID id)
 | 
			
		|||
 | 
			
		||||
    rb_vm_change_state();
 | 
			
		||||
 | 
			
		||||
    val = (VALUE)v;
 | 
			
		||||
    val = ((rb_const_entry_t*)v)->value;
 | 
			
		||||
    if (val == Qundef) {
 | 
			
		||||
	autoload_delete(mod, id);
 | 
			
		||||
	val = Qnil;
 | 
			
		||||
    }
 | 
			
		||||
    xfree((rb_const_entry_t*)v);
 | 
			
		||||
    return val;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static int
 | 
			
		||||
sv_i(ID key, VALUE value, st_table *tbl)
 | 
			
		||||
sv_i(ID key, rb_const_entry_t *ce, st_table *tbl)
 | 
			
		||||
{
 | 
			
		||||
    if (rb_is_const_id(key)) {
 | 
			
		||||
	if (!st_lookup(tbl, (st_data_t)key, 0)) {
 | 
			
		||||
| 
						 | 
				
			
			@ -1779,7 +1787,7 @@ rb_const_defined_0(VALUE klass, ID id, int exclude, int recurse)
 | 
			
		|||
  retry:
 | 
			
		||||
    while (tmp) {
 | 
			
		||||
	if (RCLASS_CONST_TBL(tmp) && st_lookup(RCLASS_CONST_TBL(tmp), (st_data_t)id, &value)) {
 | 
			
		||||
	    if ((VALUE)value == Qundef && !autoload_node((VALUE)klass, id, 0))
 | 
			
		||||
	    if (((rb_const_entry_t*)value)->value == Qundef && !autoload_node((VALUE)klass, id, 0))
 | 
			
		||||
		return (int)Qfalse;
 | 
			
		||||
	    return (int)Qtrue;
 | 
			
		||||
	}
 | 
			
		||||
| 
						 | 
				
			
			@ -1823,6 +1831,8 @@ check_before_mod_set(VALUE klass, ID id, VALUE val, const char *dest)
 | 
			
		|||
void
 | 
			
		||||
rb_const_set(VALUE klass, ID id, VALUE val)
 | 
			
		||||
{
 | 
			
		||||
    rb_const_entry_t *ce;
 | 
			
		||||
 | 
			
		||||
    if (NIL_P(klass)) {
 | 
			
		||||
	rb_raise(rb_eTypeError, "no class/module to define constant %s",
 | 
			
		||||
		 rb_id2name(id));
 | 
			
		||||
| 
						 | 
				
			
			@ -1836,7 +1846,7 @@ rb_const_set(VALUE klass, ID id, VALUE val)
 | 
			
		|||
	st_data_t value;
 | 
			
		||||
 | 
			
		||||
	if (st_lookup(RCLASS_CONST_TBL(klass), (st_data_t)id, &value)) {
 | 
			
		||||
	    if ((VALUE)value == Qundef)
 | 
			
		||||
	    if (((rb_const_entry_t*)value)->value == Qundef)
 | 
			
		||||
		autoload_delete(klass, id);
 | 
			
		||||
	    else
 | 
			
		||||
		rb_warn("already initialized constant %s", rb_id2name(id));
 | 
			
		||||
| 
						 | 
				
			
			@ -1844,7 +1854,12 @@ rb_const_set(VALUE klass, ID id, VALUE val)
 | 
			
		|||
    }
 | 
			
		||||
 | 
			
		||||
    rb_vm_change_state();
 | 
			
		||||
    st_insert(RCLASS_CONST_TBL(klass), (st_data_t)id, (st_data_t)val);
 | 
			
		||||
 | 
			
		||||
    ce = ALLOC(rb_const_entry_t);
 | 
			
		||||
    ce->flag = CONST_PUBLIC;
 | 
			
		||||
    ce->value = val;
 | 
			
		||||
 | 
			
		||||
    st_insert(RCLASS_CONST_TBL(klass), (st_data_t)id, (st_data_t)ce);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -11,6 +11,7 @@
 | 
			
		|||
/* finish iseq array */
 | 
			
		||||
#include "insns.inc"
 | 
			
		||||
#include <math.h>
 | 
			
		||||
#include "constant.h"
 | 
			
		||||
 | 
			
		||||
/* control stack frame */
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -1171,7 +1172,7 @@ vm_get_ev_const(rb_thread_t *th, const rb_iseq_t *iseq,
 | 
			
		|||
	      search_continue:
 | 
			
		||||
		if (RCLASS_CONST_TBL(klass) &&
 | 
			
		||||
		    st_lookup(RCLASS_CONST_TBL(klass), id, &data)) {
 | 
			
		||||
		    val = (st_data_t)data;
 | 
			
		||||
		    val = ((rb_const_entry_t*)data)->value;
 | 
			
		||||
		    if (val == Qundef) {
 | 
			
		||||
			if (am == klass) break;
 | 
			
		||||
			am = klass;
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue