brew/Library/Homebrew/bottles.rb

118 lines
2.9 KiB
Ruby
Raw Normal View History

require 'tab'
2013-10-18 12:56:51 -05:00
require 'os/mac'
require 'extend/ARGV'
2013-08-03 20:02:10 -07:00
require 'bottle_version'
def bottle_filename options={}
name = options.fetch(:name)
version = options.fetch(:version)
tag = options.fetch(:tag)
revision = options.fetch(:revision)
"#{name}-#{version}.#{tag}#{bottle_suffix(revision)}"
end
def built_as_bottle? f
2012-07-22 16:07:20 +01:00
return false unless f.installed?
tab = Tab.for_keg(f.installed_prefix)
tab.built_as_bottle
end
2012-04-30 15:10:51 -05:00
def bottle_file_outdated? f, file
filename = file.basename.to_s
return unless f.bottle && filename.match(Pathname::BOTTLE_EXTNAME_RX)
2012-04-30 15:10:51 -05:00
bottle_ext = filename[bottle_native_regex, 1]
bottle_url_ext = f.bottle.url[bottle_native_regex, 1]
2012-04-30 15:10:51 -05:00
bottle_ext && bottle_url_ext && bottle_ext != bottle_url_ext
end
def bottle_suffix revision
revision = revision > 0 ? ".#{revision}" : ""
".bottle#{revision}.tar.gz"
end
def bottle_native_regex
2013-06-06 16:02:27 -05:00
/(\.#{bottle_tag}\.bottle\.(\d+\.)?tar\.gz)$/o
end
def bottle_url(root_url, filename_options)
"#{root_url}/#{bottle_filename(filename_options)}"
end
2013-06-06 16:02:27 -05:00
def bottle_tag
if MacOS.version >= :lion
2013-06-06 16:02:27 -05:00
MacOS.cat
elsif MacOS.version == :snow_leopard
2013-06-13 12:04:58 -05:00
Hardware::CPU.is_64_bit? ? :snow_leopard : :snow_leopard_32
2013-06-06 16:02:27 -05:00
else
# Return, e.g., :tiger_g3, :leopard_g5_64, :leopard_64 (which is Intel)
if Hardware::CPU.type == :ppc
tag = "#{MacOS.cat}_#{Hardware::CPU.family}".to_sym
else
tag = MacOS.cat
end
MacOS.prefer_64_bit? ? "#{tag}_64".to_sym : tag
2013-06-06 16:02:27 -05:00
end
end
def bottle_filename_formula_name filename
path = Pathname.new filename
2013-08-03 20:02:10 -07:00
version = BottleVersion.parse(path).to_s
basename = path.basename.to_s
basename.rpartition("-#{version}").first
end
class BottleCollector
def initialize
@bottles = {}
end
def fetch_checksum_for(tag)
2014-07-16 18:54:19 -05:00
return [@bottles[tag], tag] if key?(tag)
find_altivec_tag(tag) || find_or_later_tag(tag)
end
2014-07-15 21:55:14 -05:00
def keys
@bottles.keys
end
def [](key)
@bottles[key]
end
def []=(key, value)
@bottles[key] = value
end
2014-07-16 18:54:19 -05:00
def key?(key)
@bottles.key?(key)
end
# This allows generic Altivec PPC bottles to be supported in some
# formulae, while also allowing specific bottles in others; e.g.,
# sometimes a formula has just :tiger_altivec, other times it has
# :tiger_g4, :tiger_g5, etc.
def find_altivec_tag(tag)
if tag.to_s =~ /(\w+)_(g4|g4e|g5)$/
2014-07-16 18:54:19 -05:00
altivec_tag = "#{$1}_altivec".to_sym
return [@bottles[altivec_tag], altivec_tag] if key?(altivec_tag)
end
end
# Allows a bottle tag to specify a specific OS or later,
# so the same bottle can target multiple OSs.
# Not used in core, used in taps.
def find_or_later_tag(tag)
results = @bottles.find_all {|k,v| k.to_s =~ /_or_later$/}
results.each do |key, hsh|
later_tag = key.to_s[/(\w+)_or_later$/, 1].to_sym
bottle_version = MacOS::Version.from_symbol(later_tag)
return [hsh, key] if bottle_version <= MacOS::Version.from_symbol(tag)
end
nil
end
end