Project

General

Profile

Actions

Feature #6819

closed

OpenSSL::Digest.new should return an instance of the chosen subclass

Added by drbrain (Eric Hodel) over 11 years ago. Updated over 11 years ago.

Status:
Closed
Target version:
[ruby-core:46908]

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

openssl.digest.module_function.patch (1.08 KB) openssl.digest.module_function.patch drbrain (Eric Hodel), 08/02/2012 07:30 AM

Updated by nobu (Nobuyoshi Nakada) over 11 years ago

=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

Updated by nobu (Nobuyoshi Nakada) over 11 years ago

  • Description updated (diff)

Updated by drbrain (Eric Hodel) over 11 years ago

I agree. I have attached a patch to implement your suggestion.

Actions #4

Updated by Anonymous over 11 years ago

  • 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]

Updated by MartinBosslet (Martin Bosslet) over 11 years ago

drbrain (Eric Hodel) wrote:

I agree. I have attached a patch to implement your suggestion.

Thanks to both of you!

Actions

Also available in: Atom PDF

Like0
Like0Like0Like0Like0Like0