variable.c: move warnings to rb_ivar_get

* variable.c (generic_ivar_get, ivar_get): return undef value instead
  of Qnil with warnings, for uninitialized instance variable.
* variable.c (rb_ivar_get): warn for uninitialized instance variable
  here.


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@40558 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
nobu 2013-05-02 08:30:56 +00:00
Родитель 31457774a8
Коммит b996367eb5
1 изменённых файлов: 13 добавлений и 13 удалений

Просмотреть файл

@ -908,7 +908,7 @@ rb_generic_ivar_table(VALUE obj)
} }
static VALUE static VALUE
generic_ivar_get(VALUE obj, ID id, int warn) generic_ivar_get(VALUE obj, ID id, VALUE undef)
{ {
st_data_t tbl, val; st_data_t tbl, val;
@ -919,10 +919,7 @@ generic_ivar_get(VALUE obj, ID id, int warn)
} }
} }
} }
if (warn) { return undef;
rb_warning("instance variable %"PRIsVALUE" not initialized", QUOTE_ID(id));
}
return Qnil;
} }
static void static void
@ -1071,7 +1068,7 @@ rb_copy_generic_ivar(VALUE clone, VALUE obj)
} }
static VALUE static VALUE
ivar_get(VALUE obj, ID id, int warn) rb_ivar_lookup(VALUE obj, ID id, VALUE undef)
{ {
VALUE val, *ptr; VALUE val, *ptr;
struct st_table *iv_index_tbl; struct st_table *iv_index_tbl;
@ -1099,25 +1096,28 @@ ivar_get(VALUE obj, ID id, int warn)
default: default:
generic: generic:
if (FL_TEST(obj, FL_EXIVAR) || rb_special_const_p(obj)) if (FL_TEST(obj, FL_EXIVAR) || rb_special_const_p(obj))
return generic_ivar_get(obj, id, warn); return generic_ivar_get(obj, id, undef);
break; break;
} }
if (warn) { return undef;
rb_warning("instance variable %"PRIsVALUE" not initialized", QUOTE_ID(id));
}
return Qnil;
} }
VALUE VALUE
rb_ivar_get(VALUE obj, ID id) rb_ivar_get(VALUE obj, ID id)
{ {
return ivar_get(obj, id, TRUE); VALUE iv = rb_ivar_lookup(obj, id, Qundef);
if (iv == Qundef) {
rb_warning("instance variable %"PRIsVALUE" not initialized", QUOTE_ID(id));
iv = Qnil;
}
return iv;
} }
VALUE VALUE
rb_attr_get(VALUE obj, ID id) rb_attr_get(VALUE obj, ID id)
{ {
return ivar_get(obj, id, FALSE); return rb_ivar_lookup(obj, id, Qnil);
} }
VALUE VALUE