summaryrefslogtreecommitdiff
path: root/variable.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2001-11-13 08:19:52 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2001-11-13 08:19:52 +0000
commit7422ccdd9e2fb2b28844879d5117d8fdc000c944 (patch)
tree9a6e9129ad35a2c0306e222f4ad2c59163849ee8 /variable.c
parent948ff2456bc7839817ea043b42b6423538ab873c (diff)
* signal.c (sighandle): should not re-register sighandler if
POSIX_SIGNAL is defined. * eval.c (error_print): errat array may be empty. * eval.c (rb_eval_cmd): should not upgrade safe level unless explicitly specified by argument newly added. * signal.c (sig_trap): should not allow tainted trap closure. * variable.c (rb_f_trace_var): should not allow trace_var on safe level higher than 3. * variable.c (rb_f_trace_var): should not allow tainted trace closure. * gc.c: do not use static stack until system stack overflows. * eval.c (eval): should call Exception#exception instead of calling rb_exc_new3() directly. * error.c (exc_exception): set "mesg" directly to the clone. it might be better to set mesg via some method for flexibility. * variable.c (cvar_override_check): should print original module name, if 'a' is T_ICLASS. * parse.y (yylex): float '1_.0' should not be allowed. * variable.c (var_getter): should care about var as Qfalse (ruby-bugs#PR199). * array.c (cmpint): <=> or block for {min,max} may return bignum. * array.c (sort_1): use rb_compint. * array.c (sort_2): ditto. * enum.c (min_ii): ditto. * enum.c (min_ii): ditto. * enum.c (max_i): ditto. * enum.c (max_ii): ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@1827 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'variable.c')
-rw-r--r--variable.c37
1 files changed, 24 insertions, 13 deletions
diff --git a/variable.c b/variable.c
index fc02f749f7..1f8f2fb7ff 100644
--- a/variable.c
+++ b/variable.c
@@ -402,7 +402,7 @@ var_getter(id, var)
ID id;
VALUE *var;
{
- if (!var || !*var) return Qnil;
+ if (!var) return Qnil;
return *var;
}
@@ -518,7 +518,7 @@ static void
rb_trace_eval(cmd, val)
VALUE cmd, val;
{
- rb_eval_cmd(cmd, rb_ary_new3(1, val));
+ rb_eval_cmd(cmd, rb_ary_new3(1, val), 0);
}
VALUE
@@ -527,19 +527,19 @@ rb_f_trace_var(argc, argv)
VALUE *argv;
{
VALUE var, cmd;
- ID id;
struct global_entry *entry;
struct trace_var *trace;
+ rb_secure(4);
if (rb_scan_args(argc, argv, "11", &var, &cmd) == 1) {
cmd = rb_f_lambda();
}
if (NIL_P(cmd)) {
return rb_f_untrace_var(argc, argv);
}
- id = rb_to_id(var);
- if (!st_lookup(rb_global_tbl, id, &entry)) {
- rb_name_error(id, "undefined global variable %s", rb_id2name(id));
+ entry = rb_global_entry(rb_to_id(var));
+ if (OBJ_TAINTED(cmd)) {
+ rb_raise(rb_eSecurityError, "Insecure: tainted variable trace");
}
trace = ALLOC(struct trace_var);
trace->next = entry->var->trace;
@@ -1419,17 +1419,28 @@ rb_cvar_singleton(obj)
return CLASS_OF(obj);
}
+static VALUE
+original_module(c)
+ VALUE c;
+{
+ if (TYPE(c) == T_ICLASS)
+ return RBASIC(c)->klass;
+ return c;
+}
+
static void
-cvar_override_check(id, a, b)
- VALUE a, b;
+cvar_override_check(id, a)
+ VALUE a;
{
+ VALUE base = original_module(a);
+
a = RCLASS(a)->super;
while (a) {
if (RCLASS(a)->iv_tbl) {
if (st_lookup(RCLASS(a)->iv_tbl,id,0)) {
rb_warning("class variable %s of %s is overridden by %s",
- rb_id2name(id), rb_class2name(a),
- rb_class2name(b));
+ rb_id2name(id), rb_class2name(original_module(a)),
+ rb_class2name(base));
}
}
a = RCLASS(a)->super;
@@ -1452,7 +1463,7 @@ rb_cvar_set(klass, id, val)
rb_raise(rb_eSecurityError, "Insecure: can't modify class variable");
st_insert(RCLASS(tmp)->iv_tbl,id,val);
if (ruby_verbose) {
- cvar_override_check(id, tmp, klass);
+ cvar_override_check(id, tmp);
}
return;
}
@@ -1482,7 +1493,7 @@ rb_cvar_declare(klass, id, val)
}
st_insert(RCLASS(tmp)->iv_tbl,id,val);
if (ruby_verbose) {
- cvar_override_check(id, tmp, klass);
+ cvar_override_check(id, tmp);
}
return;
}
@@ -1505,7 +1516,7 @@ rb_cvar_get(klass, id)
if (RCLASS(tmp)->iv_tbl) {
if (st_lookup(RCLASS(tmp)->iv_tbl,id,&value)) {
if (ruby_verbose) {
- cvar_override_check(id, tmp, klass);
+ cvar_override_check(id, tmp);
}
return value;
}