brew/Library/Homebrew/bottles.rb

139 lines
3.6 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 f, options={}
options = { :tag => bottle_tag }.merge(options)
2012-04-03 11:43:41 -05:00
name = f.name.downcase
version = PkgVersion.new(f.stable.version, f.revision)
options[:revision] ||= f.bottle.revision.to_i if f.bottle
"#{name}-#{version}#{bottle_native_suffix(options)}"
end
def install_bottle? f, options={:warn=>false}
return true if f.local_bottle_path
2013-09-01 12:59:01 +01:00
return true if ARGV.force_bottle?
return false unless f.pour_bottle?
return false unless f.default_build?
return false unless bottle_current?(f)
if f.bottle.cellar != :any && f.bottle.cellar != HOMEBREW_CELLAR.to_s
if options[:warn]
opoo "Building source; cellar of #{f}'s bottle is #{f.bottle.cellar}"
end
return false
end
true
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
def bottle_current? f
f.bottle and f.bottle.url and not f.bottle.checksum.empty?
end
2012-04-30 15:10:51 -05:00
def bottle_file_outdated? f, file
filename = file.basename.to_s
return nil unless f and f.bottle and f.bottle.url \
2013-01-27 18:58:50 +00:00
and filename.match(bottle_regex)
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_native_suffix options={}
options = { :tag => bottle_tag }.merge(options)
".#{options[:tag]}#{bottle_suffix(options[:revision])}"
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_regex
Pathname::BOTTLE_EXTNAME_RX
end
def bottle_url f, tag=bottle_tag
"#{f.bottle.root_url}/#{bottle_filename(f, :tag => tag)}"
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 add(checksum, tag, url=nil)
@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