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
 | 
