require 'tab' require 'os/mac' require 'extend/ARGV' require 'bottle_version' def bottle_filename options={} options = { :tag => bottle_tag }.merge(options) "#{options[:name]}-#{options[:version]}#{bottle_native_suffix(options)}" end def built_as_bottle? f return false unless f.installed? tab = Tab.for_keg(f.installed_prefix) tab.built_as_bottle end def bottle_file_outdated? f, file filename = file.basename.to_s return nil unless f and f.bottle and f.bottle.url \ and filename.match(bottle_regex) bottle_ext = filename[bottle_native_regex, 1] bottle_url_ext = f.bottle.url[bottle_native_regex, 1] 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 /(\.#{bottle_tag}\.bottle\.(\d+\.)?tar\.gz)$/o end def bottle_regex Pathname::BOTTLE_EXTNAME_RX end def bottle_url(root_url, filename_options={}) "#{root_url}/#{bottle_filename(filename_options)}" end def bottle_tag if MacOS.version >= :lion MacOS.cat elsif MacOS.version == :snow_leopard Hardware::CPU.is_64_bit? ? :snow_leopard : :snow_leopard_32 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 end end def bottle_filename_formula_name filename path = Pathname.new filename 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) @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