aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Homebrew
diff options
context:
space:
mode:
authorXu Cheng2016-03-20 14:03:28 +0800
committerXu Cheng2016-03-20 14:55:58 +0800
commitbd7e8543b3fba04a914f8f8c583652d6970d51db (patch)
tree093840f1a433792f3231f32b9f6d6bf9d428b11a /Library/Homebrew
parent93cbab0021676010f195c8629d79fefdb00a2d40 (diff)
downloadbrew-bd7e8543b3fba04a914f8f8c583652d6970d51db.tar.bz2
deprecate SHA1
Diffstat (limited to 'Library/Homebrew')
-rw-r--r--Library/Homebrew/checksum.rb2
-rw-r--r--Library/Homebrew/compat.rb1
-rw-r--r--Library/Homebrew/compat/sha1.rb35
-rw-r--r--Library/Homebrew/extend/pathname.rb6
4 files changed, 37 insertions, 7 deletions
diff --git a/Library/Homebrew/checksum.rb b/Library/Homebrew/checksum.rb
index a4e38e0ad..1197609b1 100644
--- a/Library/Homebrew/checksum.rb
+++ b/Library/Homebrew/checksum.rb
@@ -2,7 +2,7 @@ class Checksum
attr_reader :hash_type, :hexdigest
alias_method :to_s, :hexdigest
- TYPES = [:sha1, :sha256]
+ TYPES = [:sha256]
def initialize(hash_type, hexdigest)
@hash_type = hash_type
diff --git a/Library/Homebrew/compat.rb b/Library/Homebrew/compat.rb
index 4ee137f1d..4bfe7174b 100644
--- a/Library/Homebrew/compat.rb
+++ b/Library/Homebrew/compat.rb
@@ -5,6 +5,7 @@ require "compat/formula_specialties"
require "compat/hardware"
require "compat/macos"
require "compat/md5"
+require "compat/sha1"
require "compat/requirements"
require "compat/version"
require "compat/download_strategy"
diff --git a/Library/Homebrew/compat/sha1.rb b/Library/Homebrew/compat/sha1.rb
new file mode 100644
index 000000000..9d6fbc6e0
--- /dev/null
+++ b/Library/Homebrew/compat/sha1.rb
@@ -0,0 +1,35 @@
+class Formula
+ def self.sha1(val)
+ stable.sha1(val)
+ end
+end
+
+class SoftwareSpec
+ def sha1(val)
+ @resource.sha1(val)
+ end
+end
+
+class Resource
+ def sha1(val)
+ @checksum = Checksum.new(:sha1, val)
+ end
+end
+
+class BottleSpecification
+ def sha1(val)
+ digest, tag = val.shift
+ collector[tag] = Checksum.new(:sha1, digest)
+ end
+end
+
+class Pathname
+ def sha1
+ require "digest/sha1"
+ opoo <<-EOS.undent
+ SHA1 support is deprecated and will be removed in a future version.
+ Please switch this formula to SHA256.
+ EOS
+ incremental_hash(Digest::SHA1)
+ end
+end
diff --git a/Library/Homebrew/extend/pathname.rb b/Library/Homebrew/extend/pathname.rb
index 2f3fbc32f..3f898fecb 100644
--- a/Library/Homebrew/extend/pathname.rb
+++ b/Library/Homebrew/extend/pathname.rb
@@ -300,12 +300,6 @@ class Pathname
digest.hexdigest
end
- # @private
- def sha1
- require "digest/sha1"
- incremental_hash(Digest::SHA1)
- end
-
def sha256
require "digest/sha2"
incremental_hash(Digest::SHA2)