mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* ext/digest: Prefix C constants with RUBY_ and C type names with
rb_ to avoid name clash in writing extensions. * ext/digest: Introduce Digest::Class and Digest::Instance for ease of implementing subclasses and add-ons, inspried by gotoyuzo. * ext/digest: The Digest::Instance module now requires and assumes that any instance be resettable and clonable, and add some convenient instance methods such as "new()", for creating a new copy, parameter taking "digest()" and "hexdigest()", for instant calculation. These methods make digest instances work just like digest classes. * ext/digest/sha2/lib/digest/sha2.rb: Add the Digest::SHA2 class to wrap up SHA2 variants: SHA256, SHA384 and SHA512, hoping this module would make a decent example of a digest subclass written in Ruby. * ext/digest/lib/digest.rb: Adjust autoload entries for SHA2 classes. * ext/digest/lib/digest/hmac.rb: Follow the framework updates. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@11197 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
03f19e27ed
commit
b2c7fe1bbf
13 changed files with 643 additions and 452 deletions
|
@ -12,8 +12,8 @@
|
|||
************************************************/
|
||||
|
||||
#include "ruby.h"
|
||||
#include "digest.h"
|
||||
|
||||
static VALUE mDigest, cDigest_Base;
|
||||
static ID id_digest;
|
||||
|
||||
static VALUE
|
||||
|
@ -83,9 +83,6 @@ bubblebabble_str_new(VALUE str_digest)
|
|||
* Digest.bubblebabble(string) -> bubblebabble_string
|
||||
*
|
||||
* Returns a BubbleBabble encoded version of a given _string_.
|
||||
*
|
||||
* If extra arguments are given, they are passed to
|
||||
* Digest::ALGORITHM.digest() along with the _string_.
|
||||
*/
|
||||
static VALUE
|
||||
rb_digest_s_bubblebabble(VALUE klass, VALUE str)
|
||||
|
@ -95,12 +92,12 @@ rb_digest_s_bubblebabble(VALUE klass, VALUE str)
|
|||
|
||||
/*
|
||||
* call-seq:
|
||||
* Digest::ALGORITHM.bubblebabble(string, ...) -> hash_string
|
||||
* Digest::Class.bubblebabble(string, ...) -> hash_string
|
||||
*
|
||||
* Returns the BubbleBabble encoded hash value of a given _string_.
|
||||
*/
|
||||
static VALUE
|
||||
rb_digest_base_s_bubblebabble(int argc, VALUE *argv, VALUE klass)
|
||||
rb_digest_class_s_bubblebabble(int argc, VALUE *argv, VALUE klass)
|
||||
{
|
||||
return bubblebabble_str_new(rb_funcall2(klass, id_digest, argc, argv));
|
||||
}
|
||||
|
@ -112,7 +109,7 @@ rb_digest_base_s_bubblebabble(int argc, VALUE *argv, VALUE klass)
|
|||
* Returns the resulting hash value in a Bubblebabble encoded form.
|
||||
*/
|
||||
static VALUE
|
||||
rb_digest_base_bubblebabble(VALUE self)
|
||||
rb_digest_instance_bubblebabble(VALUE self)
|
||||
{
|
||||
return bubblebabble_str_new(rb_funcall(self, id_digest, 0));
|
||||
}
|
||||
|
@ -124,17 +121,22 @@ rb_digest_base_bubblebabble(VALUE self)
|
|||
void
|
||||
Init_bubblebabble(void)
|
||||
{
|
||||
mDigest = rb_define_module("Digest");
|
||||
cDigest_Base = rb_define_class_under(mDigest, "Base", rb_cObject);
|
||||
VALUE mDigest, mDigest_Instance, cDigest_Class;
|
||||
|
||||
rb_require("digest");
|
||||
|
||||
mDigest = rb_path2class("Digest");
|
||||
mDigest_Instance = rb_path2class("Digest::Instance");
|
||||
cDigest_Class = rb_path2class("Digest::Class");
|
||||
|
||||
/* Digest::bubblebabble() */
|
||||
rb_define_module_function(mDigest, "bubblebabble", rb_digest_s_bubblebabble, 1);
|
||||
|
||||
/* Digest::Base::bubblebabble() */
|
||||
rb_define_singleton_method(cDigest_Base, "bubblebabble", rb_digest_base_s_bubblebabble, -1);
|
||||
/* Digest::Class::bubblebabble() */
|
||||
rb_define_singleton_method(cDigest_Class, "bubblebabble", rb_digest_class_s_bubblebabble, -1);
|
||||
|
||||
/* Digest::Base#bubblebabble() */
|
||||
rb_define_method(cDigest_Base, "bubblebabble", rb_digest_base_bubblebabble, 0);
|
||||
/* Digest::Instance#bubblebabble() */
|
||||
rb_define_method(mDigest_Instance, "bubblebabble", rb_digest_instance_bubblebabble, 0);
|
||||
|
||||
id_digest = rb_intern("digest");
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue