diff options
author | knu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-10-18 04:26:06 +0000 |
---|---|---|
committer | knu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-10-18 04:26:06 +0000 |
commit | 74cacd0df4e6c6a504969d7eb10e76676a607fa3 (patch) | |
tree | d1da2a75e0970eb4c8a2204ccd5e884b42d5a816 | |
parent | 0a8d8b8a684dc66669c6b2add3637c78673a97fe (diff) | |
download | ruby-74cacd0df4e6c6a504969d7eb10e76676a607fa3.tar.gz |
* ext/digest/digest.c (rb_digest_class_init): Define
Digest::Class.new(). [Feature #3954]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@29528 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | ext/digest/digest.c | 8 | ||||
-rwxr-xr-x | test/digest/test_digest.rb | 6 |
3 files changed, 19 insertions, 0 deletions
@@ -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)) |