From 4c9a9a620af6a026773f1339dedec12d66af7867 Mon Sep 17 00:00:00 2001 From: knu Date: Thu, 6 Sep 2001 05:02:29 +0000 Subject: [PATCH] * ext/digest/digest.c (rb_digest_base_s_digest, rb_digest_base_s_hexdigest): ensure that a string is given. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@1734 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ ext/digest/digest.c | 12 ++++++++++++ 2 files changed, 17 insertions(+) diff --git a/ChangeLog b/ChangeLog index 95d3a3df6d..5c14731632 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Thu Sep 6 13:56:14 2001 Akinori MUSHA + + * ext/digest/digest.c (rb_digest_base_s_digest, + rb_digest_base_s_hexdigest): ensure that a string is given. + Thu Sep 6 13:28:51 2001 WATANABE Hirofumi * lib/jcode.rb (_regexp_quote): fix quote handling, again. diff --git a/ext/digest/digest.c b/ext/digest/digest.c index f737d254ab..5355776119 100644 --- a/ext/digest/digest.c +++ b/ext/digest/digest.c @@ -96,6 +96,12 @@ rb_digest_base_s_digest(class, str) if (class == cDigest_Base) rb_raise(rb_eNotImpError, "Digest::Base is an abstract class"); +#ifdef StringValue + StringValue(str); +#else + Check_Type(str, T_STRING); +#endif + algo = get_digest_base_metadata(class); pctx = xmalloc(algo->ctx_size); @@ -129,6 +135,12 @@ rb_digest_base_s_hexdigest(class, str) if (class == cDigest_Base) rb_raise(rb_eNotImpError, "Digest::Base is an abstract class"); +#ifdef StringValue + StringValue(str); +#else + Check_Type(str, T_STRING); +#endif + algo = get_digest_base_metadata(class); pctx = xmalloc(algo->ctx_size);