summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-12-01 05:36:39 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-12-01 05:36:39 +0000
commit417ea3a3c37395c49df9bc8bed21d3627736c288 (patch)
tree4b65734d0b3145d1de838a6ecc53c0464cdcb04c
parentd264d3cc38696d8b66d7261ae75a96fb8bdf2729 (diff)
* string.c (rb_memhash): zero-filled strings should return
different values. [ruby-core:33500] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@29991 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--string.c2
-rw-r--r--test/ruby/test_string.rb2
3 files changed, 8 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index c8baecc44d..0e613356a0 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Wed Dec 1 14:36:36 2010 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * string.c (rb_memhash): zero-filled strings should return
+ different values. [ruby-core:33500]
+
Wed Dec 1 14:27:49 2010 Ryan Davis <ryand-ruby@zenspider.com>
* lib/minitest/*.rb: Imported minitest 2.0.0 r5952.
diff --git a/string.c b/string.c
index 8e494dbb83..ade48c65bd 100644
--- a/string.c
+++ b/string.c
@@ -2073,7 +2073,7 @@ rb_str_prepend(VALUE str, VALUE str2)
st_index_t
rb_memhash(const void *ptr, long len)
{
- return st_hash(ptr, len, rb_hash_start(0));
+ return st_hash(ptr, len, rb_hash_start((st_index_t)len));
}
st_index_t
diff --git a/test/ruby/test_string.rb b/test/ruby/test_string.rb
index 892aa2335d..e8287622f6 100644
--- a/test/ruby/test_string.rb
+++ b/test/ruby/test_string.rb
@@ -727,6 +727,8 @@ class TestString < Test::Unit::TestCase
def test_hash
assert_equal(S("hello").hash, S("hello").hash)
assert(S("hello").hash != S("helLO").hash)
+ bug4104 = '[ruby-core:33500]'
+ assert_not_equal(S("a").hash, S("a\0").hash, bug4104)
end
def test_hash_random