summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog6
-rw-r--r--eval.c6
2 files changed, 7 insertions, 5 deletions
diff --git a/ChangeLog b/ChangeLog
index 319e9b9297..afd5edd5cc 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+Tue Oct 2 16:47:06 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * eval.c (identity_hash_new): hide internal hashes for refinements.
+
+ * eval.c (rb_mod_refine): no default value.
+
Mon Oct 1 22:54:02 2012 Shugo Maeda <shugo@ruby-lang.org>
* eval.c (identity_hash_new): new function to create a new identity
diff --git a/eval.c b/eval.c
index 789ca37a03..053d4ac8bf 100644
--- a/eval.c
+++ b/eval.c
@@ -1046,11 +1046,7 @@ identity_hash_new()
VALUE hash = rb_hash_new();
rb_funcall(hash, rb_intern("compare_by_identity"), 0);
-#if 0
- /* FIXME: The following code hides hash, but causes "method `default'
- * called on hidden T_HASH object" error. */
RBASIC(hash)->klass = 0;
-#endif
return hash;
}
@@ -1214,7 +1210,7 @@ rb_mod_refine(VALUE module, VALUE klass)
overlaid_modules = identity_hash_new();
rb_ivar_set(module, id_overlaid_modules, overlaid_modules);
}
- mod = rb_hash_aref(overlaid_modules, klass);
+ mod = rb_hash_lookup(overlaid_modules, klass);
if (NIL_P(mod)) {
mod = rb_module_new();
CONST_ID(id_refined_class, "__refined_class__");