brew/Library/Homebrew/bottles.rb

107 lines
2.8 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={}
options = { :tag => bottle_tag }.merge(options)
suffix = ".#{options[:tag]}#{bottle_suffix(options[:revision])}"
"#{options[:name]}-#{options[:version]}#{suffix}"
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=nil
revision = revision.to_i > 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
2014-04-01 16:03:08 -05:00
def add(checksum, tag)
@bottles[tag] = checksum
end
def fetch_bottle_for(tag)
return [@bottles[tag], tag] if @bottles[tag]
find_altivec_tag(tag) || find_or_later_tag(tag)
end
def keys; @bottles.keys; end
def [](arg); @bottles[arg]; 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)$/
altitag = "#{$1}_altivec".to_sym
return [@bottles[altitag], altitag] if @bottles[altitag]
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