summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--ext/digest/digest.c8
-rwxr-xr-xtest/digest/test_digest.rb6
3 files changed, 19 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index d087c0dd40..96ae5f34c9 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Mon Oct 18 13:18:01 2010 Akinori MUSHA <knu@iDaemons.org>
+
+ * ext/digest/digest.c (rb_digest_class_init): Define
+ Digest::Class.new(). [Feature #3954]
+
Mon Oct 18 12:00:12 2010 NARUSE, Yui <naruse@ruby-lang.org>
* pack.c (pack_pack): Add native size option ! to q and Q.
diff --git a/ext/digest/digest.c b/ext/digest/digest.c
index 29ac36fc99..6f9149c31d 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 e35047e979..ac3db00f5e 100755
--- 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))