Feature #6819
closed
OpenSSL::Digest.new should return an instance of the chosen subclass
Added by drbrain (Eric Hodel) over 12 years ago.
Updated over 12 years ago.
Description
=begin
(({OpenSSL::Digest.new})) allows you to create a digest given the digest name:
digester = OpenSSL::Digest.new "SHA1"
digester.update "hello"
The digester returned is of class (({OpenSSL::Digest})) regardless of the input type.
I would like this changed so that it returns the specific subclass of (({OpenSSL::Digest})):
digester = OpenSSL::Digest.new "SHA1"
digester.class #=> OpenSSL::Digest::SHA1
When multiple digests are created this makes it easier to distinguish the type of digest you are working with.
This will also make (({OpenSSL::Digest.new})) behave similarly to (({Digest})):
digester = Digest("SHA1").new
digester.class #=> Digest::SHA1
=end
Files
=begin
--- drbrain (Eric Hodel) wrote:
I would like this changed so that it returns the specific subclass of OpenSSL::Digest:
digester = OpenSSL::Digest.new "SHA1"
digester.class #=> OpenSSL::Digest::SHA1
It sounds like quite exceptional.
Rather I'd suggest (({OpenSSL.Digest()})) method as well as (({Digest()})), or new similar class method.
--- drbrain (Eric Hodel) wrote:
This will also make OpenSSL::Digest.new behave similarly to Digest:
digester = Digest("SHA1").new
digester.class #=> Digest::SHA1
It differs than your proposal.
=end
- Description updated (diff)
I agree. I have attached a patch to implement your suggestion.
- Status changed from Open to Closed
- % Done changed from 0 to 100
This issue was solved with changeset r36592.
Eric, thank you for reporting this issue.
Your contribution to Ruby is greatly appreciated.
May Ruby be with you.
- ext/openssl/lib/openssl/digest.rb
test/openssl/test_digest.rb: Add Digest module function to OpenSSL
module and test it. Patch provided by Eric Hodel.
[ruby-core:46908][Feature #6819]
drbrain (Eric Hodel) wrote:
I agree. I have attached a patch to implement your suggestion.
Thanks to both of you!
Also available in: Atom
PDF
Like0
Like0Like0Like0Like0Like0