require 'tab' require 'os/mac' require 'extend/ARGV' 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 unless f.bottle && filename.match(Pathname::BOTTLE_EXTNAME_RX) 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_regex /(\.#{bottle_tag}\.bottle\.(\d+\.)?tar\.gz)$/o 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_receipt_path bottle_file Utils.popen_read("tar", "-tzf", bottle_file, "*/*/INSTALL_RECEIPT.json").chomp end def bottle_resolve_formula_names bottle_file receipt_file_path = bottle_receipt_path bottle_file receipt_file = Utils.popen_read("tar", "-xOzf", bottle_file, receipt_file_path) name = receipt_file_path.split("/").first tap = Tab.from_file_content(receipt_file, "#{bottle_file}/#{receipt_file_path}").tap if tap.nil? || tap == "Homebrew/homebrew" full_name = name else full_name = "#{tap.sub("homebrew-", "")}/#{name}" end [name, full_name] end def bottle_resolve_version bottle_file PkgVersion.parse bottle_receipt_path(bottle_file).split("/")[1] end class Bintray def self.package(formula_name) formula_name.to_s.gsub "+", "x" end def self.repository(tap=nil) return "bottles" if tap.nil? || tap == "Homebrew/homebrew" "bottles-#{tap.sub(/^homebrew\/(homebrew-)?/i, "")}" end end class BottleCollector def initialize @checksums = {} end def fetch_checksum_for(tag) tag = find_matching_tag(tag) return self[tag], tag if tag end def keys @checksums.keys end def [](key) @checksums[key] end def []=(key, value) @checksums[key] = value end def key?(key) @checksums.key?(key) end private def find_matching_tag(tag) if key?(tag) tag else find_altivec_tag(tag) || find_or_later_tag(tag) end 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)$/ altivec_tag = "#{$1}_altivec".to_sym 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) begin tag_version = MacOS::Version.from_symbol(tag) rescue ArgumentError return end keys.find do |key| if key.to_s.end_with?("_or_later") later_tag = key.to_s[/(\w+)_or_later$/, 1].to_sym MacOS::Version.from_symbol(later_tag) <= tag_version end end end end