mirror of
https://github.com/Homebrew/brew.git
synced 2025-07-14 16:09:03 +08:00
295 lines
6.7 KiB
Ruby
295 lines
6.7 KiB
Ruby
module HomebrewArgvExtension
|
|
def named
|
|
@named ||= self - options_only
|
|
end
|
|
|
|
def options_only
|
|
select { |arg| arg.start_with?("-") }
|
|
end
|
|
|
|
def flags_only
|
|
select { |arg| arg.start_with?("--") }
|
|
end
|
|
|
|
def formulae
|
|
require "formula"
|
|
@formulae ||= (downcased_unique_named - casks).map do |name|
|
|
if name.include?("/") || File.exist?(name)
|
|
Formulary.factory(name, spec)
|
|
else
|
|
Formulary.find_with_priority(name, spec)
|
|
end
|
|
end
|
|
end
|
|
|
|
def resolved_formulae
|
|
require "formula"
|
|
@resolved_formulae ||= (downcased_unique_named - casks).map do |name|
|
|
if name.include?("/") || File.exist?(name)
|
|
f = Formulary.factory(name, spec)
|
|
if f.any_version_installed?
|
|
tab = Tab.for_formula(f)
|
|
resolved_spec = spec(nil) || tab.spec
|
|
f.active_spec = resolved_spec if f.send(resolved_spec)
|
|
f.build = tab
|
|
if f.head? && tab.tabfile
|
|
k = Keg.new(tab.tabfile.parent)
|
|
f.version.update_commit(k.version.version.commit) if k.version.head?
|
|
end
|
|
end
|
|
else
|
|
rack = Formulary.to_rack(name)
|
|
alias_path = Formulary.factory(name).alias_path
|
|
f = Formulary.from_rack(rack, spec(nil), alias_path: alias_path)
|
|
end
|
|
|
|
# If this formula was installed with an alias that has since changed,
|
|
# then it was specified explicitly in ARGV. (Using the alias would
|
|
# instead have found the new formula.)
|
|
#
|
|
# Because of this, the user is referring to this specific formula,
|
|
# not any formula targetted by the same alias, so in this context
|
|
# the formula shouldn't be considered outdated if the alias used to
|
|
# install it has changed.
|
|
f.follow_installed_alias = false
|
|
|
|
f
|
|
end
|
|
end
|
|
|
|
def casks
|
|
@casks ||= downcased_unique_named.grep HOMEBREW_CASK_TAP_CASK_REGEX
|
|
end
|
|
|
|
def kegs
|
|
require "keg"
|
|
require "formula"
|
|
@kegs ||= downcased_unique_named.collect do |name|
|
|
raise UsageError if name.empty?
|
|
|
|
rack = Formulary.to_rack(name.downcase)
|
|
|
|
dirs = rack.directory? ? rack.subdirs : []
|
|
|
|
raise NoSuchKegError, rack.basename if dirs.empty?
|
|
|
|
linked_keg_ref = HOMEBREW_LINKED_KEGS/rack.basename
|
|
opt_prefix = HOMEBREW_PREFIX/"opt/#{rack.basename}"
|
|
|
|
begin
|
|
if opt_prefix.symlink? && opt_prefix.directory?
|
|
Keg.new(opt_prefix.resolved_path)
|
|
elsif linked_keg_ref.symlink? && linked_keg_ref.directory?
|
|
Keg.new(linked_keg_ref.resolved_path)
|
|
elsif dirs.length == 1
|
|
Keg.new(dirs.first)
|
|
else
|
|
f = if name.include?("/") || File.exist?(name)
|
|
Formulary.factory(name)
|
|
else
|
|
Formulary.from_rack(rack)
|
|
end
|
|
|
|
unless (prefix = f.installed_prefix).directory?
|
|
raise MultipleVersionsInstalledError, rack.basename
|
|
end
|
|
|
|
Keg.new(prefix)
|
|
end
|
|
rescue FormulaUnavailableError
|
|
raise <<-EOS.undent
|
|
Multiple kegs installed to #{rack}
|
|
However we don't know which one you refer to.
|
|
Please delete (with rm -rf!) all but one and then try again.
|
|
EOS
|
|
end
|
|
end
|
|
end
|
|
|
|
# self documenting perhaps?
|
|
def include?(arg)
|
|
@n=index arg
|
|
end
|
|
|
|
def next
|
|
at(@n+1) || raise(UsageError)
|
|
end
|
|
|
|
def value(name)
|
|
arg_prefix = "--#{name}="
|
|
flag_with_value = find { |arg| arg.start_with?(arg_prefix) }
|
|
flag_with_value.strip_prefix(arg_prefix) if flag_with_value
|
|
end
|
|
|
|
def force?
|
|
flag? "--force"
|
|
end
|
|
|
|
def verbose?
|
|
flag?("--verbose") || !ENV["VERBOSE"].nil? || !ENV["HOMEBREW_VERBOSE"].nil?
|
|
end
|
|
|
|
def debug?
|
|
flag?("--debug") || !ENV["HOMEBREW_DEBUG"].nil?
|
|
end
|
|
|
|
def quieter?
|
|
flag? "--quieter"
|
|
end
|
|
|
|
def interactive?
|
|
flag? "--interactive"
|
|
end
|
|
|
|
def one?
|
|
flag? "--1"
|
|
end
|
|
|
|
def dry_run?
|
|
include?("--dry-run") || switch?("n")
|
|
end
|
|
|
|
def keep_tmp?
|
|
include? "--keep-tmp"
|
|
end
|
|
|
|
def git?
|
|
flag? "--git"
|
|
end
|
|
|
|
def homebrew_developer?
|
|
!ENV["HOMEBREW_DEVELOPER"].nil?
|
|
end
|
|
|
|
def sandbox?
|
|
include?("--sandbox") || !ENV["HOMEBREW_SANDBOX"].nil?
|
|
end
|
|
|
|
def no_sandbox?
|
|
include?("--no-sandbox") || !ENV["HOMEBREW_NO_SANDBOX"].nil?
|
|
end
|
|
|
|
def ignore_deps?
|
|
include? "--ignore-dependencies"
|
|
end
|
|
|
|
def only_deps?
|
|
include? "--only-dependencies"
|
|
end
|
|
|
|
def json
|
|
value "json"
|
|
end
|
|
|
|
def build_head?
|
|
include? "--HEAD"
|
|
end
|
|
|
|
def build_devel?
|
|
include? "--devel"
|
|
end
|
|
|
|
def build_stable?
|
|
!(build_head? || build_devel?)
|
|
end
|
|
|
|
def build_universal?
|
|
include? "--universal"
|
|
end
|
|
|
|
# Request a 32-bit only build.
|
|
# This is needed for some use-cases though we prefer to build Universal
|
|
# when a 32-bit version is needed.
|
|
def build_32_bit?
|
|
include? "--32-bit"
|
|
end
|
|
|
|
def build_bottle?
|
|
include?("--build-bottle") || !ENV["HOMEBREW_BUILD_BOTTLE"].nil?
|
|
end
|
|
|
|
def bottle_arch
|
|
arch = value "bottle-arch"
|
|
arch.to_sym if arch
|
|
end
|
|
|
|
def build_from_source?
|
|
switch?("s") || include?("--build-from-source")
|
|
end
|
|
|
|
def build_all_from_source?
|
|
!ENV["HOMEBREW_BUILD_FROM_SOURCE"].nil?
|
|
end
|
|
|
|
# Whether a given formula should be built from source during the current
|
|
# installation run.
|
|
def build_formula_from_source?(f)
|
|
return true if build_all_from_source?
|
|
return false unless build_from_source? || build_bottle?
|
|
formulae.any? { |argv_f| argv_f.full_name == f.full_name }
|
|
end
|
|
|
|
def flag?(flag)
|
|
options_only.include?(flag) || switch?(flag[2, 1])
|
|
end
|
|
|
|
def force_bottle?
|
|
include? "--force-bottle"
|
|
end
|
|
|
|
def fetch_head?
|
|
include? "--fetch-HEAD"
|
|
end
|
|
|
|
# eg. `foo -ns -i --bar` has three switches, n, s and i
|
|
def switch?(char)
|
|
return false if char.length > 1
|
|
options_only.any? { |arg| arg.scan("-").size == 1 && arg.include?(char) }
|
|
end
|
|
|
|
def cc
|
|
value "cc"
|
|
end
|
|
|
|
def env
|
|
value "env"
|
|
end
|
|
|
|
# If the user passes any flags that trigger building over installing from
|
|
# a bottle, they are collected here and returned as an Array for checking.
|
|
def collect_build_flags
|
|
build_flags = []
|
|
|
|
build_flags << "--HEAD" if build_head?
|
|
build_flags << "--universal" if build_universal?
|
|
build_flags << "--32-bit" if build_32_bit?
|
|
build_flags << "--build-bottle" if build_bottle?
|
|
build_flags << "--build-from-source" if build_from_source?
|
|
|
|
build_flags
|
|
end
|
|
|
|
private
|
|
|
|
def spec(default = :stable)
|
|
if include?("--HEAD")
|
|
:head
|
|
elsif include?("--devel")
|
|
:devel
|
|
else
|
|
default
|
|
end
|
|
end
|
|
|
|
def downcased_unique_named
|
|
# Only lowercase names, not paths, bottle filenames or URLs
|
|
@downcased_unique_named ||= named.map do |arg|
|
|
if arg.include?("/") || arg.end_with?(".tar.gz") || File.exist?(arg)
|
|
arg
|
|
else
|
|
arg.downcase
|
|
end
|
|
end.uniq
|
|
end
|
|
end
|