Skip to content

Commit

Permalink
* ext/digest: Prefix C constants with RUBY_ and C type names with
Browse files Browse the repository at this point in the history
  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
  • Loading branch information
knu committed Oct 20, 2006
1 parent 03f19e2 commit b2c7fe1
Show file tree
Hide file tree
Showing 13 changed files with 595 additions and 404 deletions.
26 changes: 26 additions & 0 deletions ChangeLog
@@ -1,3 +1,29 @@
Fri Oct 20 20:28:37 2006 Akinori MUSHA <knu@iDaemons.org>

* 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.

Fri Oct 20 10:47:43 2006 NAKAMURA Usaku <usa@ruby-lang.org>

* lib/mkmf.rb: fixed the bug of handling COMMON_MACROS.
Expand Down
28 changes: 15 additions & 13 deletions ext/digest/bubblebabble/bubblebabble.c
Expand Up @@ -12,8 +12,8 @@
************************************************/

#include "ruby.h"
#include "digest.h"

static VALUE mDigest, cDigest_Base;
static ID id_digest;

static VALUE
Expand Down Expand Up @@ -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)
Expand All @@ -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));
}
Expand All @@ -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));
}
Expand All @@ -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");
}
3 changes: 3 additions & 0 deletions ext/digest/bubblebabble/depend
@@ -0,0 +1,3 @@
bubblebabble.o: bubblebabble.c $(srcdir)/../digest.h $(hdrdir)/ruby.h \
$(topdir)/config.h $(hdrdir)/defines.h $(hdrdir)/intern.h \
$(srcdir)/../defs.h
3 changes: 3 additions & 0 deletions ext/digest/bubblebabble/extconf.rb
@@ -1,3 +1,6 @@
require 'mkmf'

$defs << "-DHAVE_CONFIG_H"
$INCFLAGS << " -I$(srcdir)/.."

create_makefile('digest/bubblebabble')

0 comments on commit b2c7fe1

Please sign in to comment.