diff options
author | knu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-10-31 16:04:19 +0000 |
---|---|---|
committer | knu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-10-31 16:04:19 +0000 |
commit | 598566fce37cef25e7c888c0ff3231b070833a72 (patch) | |
tree | 8755c24c5a3fed1a03326dcde15d0c3148d4f963 | |
parent | 5ab2cc5389b17a73d0720a63184d2f5765c6a32c (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-- | ChangeLog | 5 | ||||
-rw-r--r-- | ext/digest/digest.c | 8 | ||||
-rw-r--r-- | test/digest/test_digest.rb | 6 |
3 files changed, 19 insertions, 0 deletions
@@ -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)) |