Top Level Namespace
Defined Under Namespace
Modules: Digest
Instance Method Summary collapse
-
#Digest(name) ⇒ Object
call-seq: Digest(name) -> digest_subclass.
- #digest_conf(name) ⇒ Object
Instance Method Details
#Digest(name) ⇒ Object
call-seq:
Digest(name) -> digest_subclass
Returns a Digest subclass by name
in a thread-safe manner even when on-demand loading is involved.
require 'digest'
Digest("MD5")
# => Digest::MD5
Digest(:SHA256)
# => Digest::SHA256
Digest(:Foo)
# => LoadError: library not found for class Digest::Foo -- digest/foo
110 111 112 113 114 115 116 117 118 119 120 121 122 123 |
# File 'lib/digest.rb', line 110 def Digest(name) const = name.to_sym Digest::REQUIRE_MUTEX.synchronize { # Ignore autoload's because it is void when we have #const_missing Digest.const_missing(const) } rescue LoadError # Constants do not necessarily rely on digest/*. if Digest.const_defined?(const) Digest.const_get(const) else raise end end |
#digest_conf(name) ⇒ Object
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
# File 'digest_conf.rb', line 3 def digest_conf(name) unless with_config("bundled-#{name}") cc = with_config("common-digest") if cc != false or /\b#{name}\b/ =~ cc if File.exist?("#$srcdir/#{name}cc.h") and have_header("CommonCrypto/CommonDigest.h") $defs << "-D#{name.upcase}_USE_COMMONDIGEST" $headers << "#{name}cc.h" return :commondigest end end end $objs << "#{name}.#{$OBJEXT}" return end |