summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorknu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-10-31 16:04:19 +0000
committerknu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-10-31 16:04:19 +0000
commit598566fce37cef25e7c888c0ff3231b070833a72 (patch)
tree8755c24c5a3fed1a03326dcde15d0c3148d4f963
parent5ab2cc5389b17a73d0720a63184d2f5765c6a32c (diff)
* ext/digest/digest.c (rb_digest_class_init): Define
Digest::Class.new(). [Feature #3954] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@29656 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--ext/digest/digest.c8
-rw-r--r--test/digest/test_digest.rb6
3 files changed, 19 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index 966404ce66..bbfd5028c5 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Mon Nov 1 00:58:00 2010 Akinori MUSHA <[email protected]>
+
+ * ext/digest/digest.c (rb_digest_class_init): Define
+ Digest::Class.new(). [Feature #3954]
+
Sat Oct 30 11:26:07 2010 Marc-Andre Lafortune <[email protected]>
* object.c: Make BasicObject.new accept no parameter.
diff --git a/ext/digest/digest.c b/ext/digest/digest.c
index 7c07fc3cac..a32a3f0925 100644
--- a/ext/digest/digest.c
+++ b/ext/digest/digest.c
@@ -415,6 +415,13 @@ rb_digest_class_s_hexdigest(int argc, VALUE *argv, VALUE klass)
return hexencode_str_new(rb_funcall2(klass, id_digest, argc, argv));
}
+/* :nodoc: */
+static VALUE
+rb_digest_class_init(VALUE self)
+{
+ return self;
+}
+
/*
* Document-class: Digest::Base
*
@@ -622,6 +629,7 @@ Init_digest(void)
* class Digest::Class
*/
rb_cDigest_Class = rb_define_class_under(rb_mDigest, "Class", rb_cObject);
+ rb_define_method(rb_cDigest_Class, "initialize", rb_digest_class_init, 0);
rb_include_module(rb_cDigest_Class, rb_mDigest_Instance);
/* class methods */
diff --git a/test/digest/test_digest.rb b/test/digest/test_digest.rb
index 8f7602743f..6d6880cc94 100644
--- a/test/digest/test_digest.rb
+++ b/test/digest/test_digest.rb
@@ -17,6 +17,12 @@ module TestDigest
Data1 = "abc"
Data2 = "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"
+ def test_s_new
+ self.class::DATA.each do |str, hexdigest|
+ assert_raise(ArgumentError) { self.class::ALGO.new("") }
+ end
+ end
+
def test_s_hexdigest
self.class::DATA.each do |str, hexdigest|
assert_equal(hexdigest, self.class::ALGO.hexdigest(str))