diff options
author | knu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-10-20 12:48:35 +0000 |
---|---|---|
committer | knu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-10-20 12:48:35 +0000 |
commit | b2c7fe1bbffe9e5fe741b7dd3725017b55250c1e () | |
tree | 357017c76c382d89ee3c3f359e14a2496f095635 /ext/digest/bubblebabble | |
parent | 03f19e27ed9dc0b0110dce0108626d414e00fca2 (diff) |
* 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
-rw-r--r-- | ext/digest/bubblebabble/bubblebabble.c | 28 | ||||
-rw-r--r-- | ext/digest/bubblebabble/depend | 3 | ||||
-rw-r--r-- | ext/digest/bubblebabble/extconf.rb | 3 |
3 files changed, 21 insertions, 13 deletions
@@ -12,8 +12,8 @@ ************************************************/ #include "ruby.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 * * Returns the BubbleBabble encoded hash value of a given _string_. */ static VALUE -rb_digest_base_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) { 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); /* 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::Base#bubblebabble() */ - rb_define_method(cDigest_Base, "bubblebabble", rb_digest_base_bubblebabble, 0); id_digest = rb_intern("digest"); } @@ -0,0 +1,3 @@ @@ -1,3 +1,6 @@ require 'mkmf' create_makefile('digest/bubblebabble') |