summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-12-16 13:40:04 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-12-16 13:40:04 +0000
commit0988148782eeac20a239658789dde13c55d84689 (patch)
tree991eb5a9addb95887a945a6c7c2f73352dc3e864
parent6cd0d06bae4ca127f39f8c3ea458d8a8c1b30a90 (diff)
hash.c: warnings in rb_hash_reject
* hash.c (rb_hash_dup_empty): split from rb_hash_dup. * hash.c (rb_hash_reject): add warnings (currently suppressed). git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@44247 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--hash.c34
1 files changed, 30 insertions, 4 deletions
diff --git a/hash.c b/hash.c
index 9daa430026..bc0b96ac20 100644
--- a/hash.c
+++ b/hash.c
@@ -27,6 +27,11 @@
# endif
#endif
+#define HAS_MISC_ATTRIBUTES(hash) \
+ (FL_TEST((hash), FL_EXIVAR|FL_TAINT|HASH_PROC_DEFAULT) || \
+ !NIL_P(RHASH_IFNONE(hash)))
+#define HASH_REJECT_COPY_MISC_ATTRIBUTES 0
+
static VALUE rb_hash_s_try_convert(VALUE, VALUE);
/*
@@ -272,8 +277,8 @@ rb_hash_new(void)
return hash_alloc(rb_cHash);
}
-VALUE
-rb_hash_dup(VALUE hash)
+static VALUE
+rb_hash_dup_empty(VALUE hash)
{
NEWOBJ_OF(ret, struct RHash,
rb_obj_class(hash),
@@ -281,8 +286,6 @@ rb_hash_dup(VALUE hash)
if (FL_TEST((hash), FL_EXIVAR))
rb_copy_generic_ivar((VALUE)(ret),(VALUE)(hash));
- if (!RHASH_EMPTY_P(hash))
- ret->ntbl = st_copy(RHASH(hash)->ntbl);
if (FL_TEST(hash, HASH_PROC_DEFAULT)) {
FL_SET(ret, HASH_PROC_DEFAULT);
}
@@ -290,6 +293,15 @@ rb_hash_dup(VALUE hash)
return (VALUE)ret;
}
+VALUE
+rb_hash_dup(VALUE hash)
+{
+ VALUE ret = rb_hash_dup_empty(hash);
+ if (!RHASH_EMPTY_P(hash))
+ RHASH(ret)->ntbl = st_copy(RHASH(hash)->ntbl);
+ return ret;
+}
+
static void
rb_hash_modify_check(VALUE hash)
{
@@ -1117,7 +1129,21 @@ rb_hash_reject(VALUE hash)
VALUE result;
RETURN_SIZED_ENUMERATOR(hash, 0, 0, hash_enum_size);
+#if HASH_REJECT_COPY_TRIVIAL_ATTRIBUTES
+# if 0
+ if (HAS_MISC_ATTRIBUTES(has)) {
+ rb_warn("copying unguaranteed attributes")
+ }
+# endif
+ result = rb_hash_dup_empty(hash);
+#else
+# if 0
+ if (HAS_MISC_ATTRIBUTES(has)) {
+ rb_warn("unguaranteed attributes are not copied")
+ }
+# endif
result = rb_hash_new();
+#endif
if (!RHASH_EMPTY_P(hash)) {
rb_hash_foreach(hash, reject_i, result);
}