cmd/info: Add support for casks
This commit is contained in:
		
							parent
							
								
									90b92301ae
								
							
						
					
					
						commit
						9a8f4c7c96
					
				@ -38,6 +38,14 @@ module Homebrew
 | 
			
		||||
        end
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      def to_formulae_casks_unknowns(method: nil)
 | 
			
		||||
        downcased_unique_named.map do |name|
 | 
			
		||||
          load_formula_or_cask(name, method: method)
 | 
			
		||||
        rescue FormulaOrCaskUnavailableError => e
 | 
			
		||||
          e
 | 
			
		||||
        end.uniq.freeze
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      def load_formula_or_cask(name, only: nil, method: nil)
 | 
			
		||||
        if only != :cask
 | 
			
		||||
          begin
 | 
			
		||||
 | 
			
		||||
@ -64,27 +64,29 @@ module Homebrew
 | 
			
		||||
  def info
 | 
			
		||||
    args = info_args.parse
 | 
			
		||||
 | 
			
		||||
    if args.days.present? && !VALID_DAYS.include?(args.days)
 | 
			
		||||
      raise UsageError, "--days must be one of #{VALID_DAYS.join(", ")}"
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    if args.category.present?
 | 
			
		||||
      if args.named.present? && !VALID_FORMULA_CATEGORIES.include?(args.category)
 | 
			
		||||
        raise UsageError, "--category must be one of #{VALID_FORMULA_CATEGORIES.join(", ")} when querying formulae"
 | 
			
		||||
    if args.analytics?
 | 
			
		||||
      if args.days.present? && !VALID_DAYS.include?(args.days)
 | 
			
		||||
        raise UsageError, "--days must be one of #{VALID_DAYS.join(", ")}"
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      unless VALID_CATEGORIES.include?(args.category)
 | 
			
		||||
        raise UsageError, "--category must be one of #{VALID_CATEGORIES.join(", ")}"
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
      if args.category.present?
 | 
			
		||||
        if args.named.present? && !VALID_FORMULA_CATEGORIES.include?(args.category)
 | 
			
		||||
          raise UsageError, "--category must be one of #{VALID_FORMULA_CATEGORIES.join(", ")} when querying formulae"
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
    if args.json
 | 
			
		||||
        unless VALID_CATEGORIES.include?(args.category)
 | 
			
		||||
          raise UsageError, "--category must be one of #{VALID_CATEGORIES.join(", ")}"
 | 
			
		||||
        end
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      print_analytics(args: args)
 | 
			
		||||
    elsif args.json
 | 
			
		||||
      raise UsageError, "invalid JSON version: #{args.json}" unless ["v1", true].include? args.json
 | 
			
		||||
      raise FormulaUnspecifiedError if !(args.all? || args.installed?) && args.no_named?
 | 
			
		||||
 | 
			
		||||
      print_json(args: args)
 | 
			
		||||
    elsif args.github?
 | 
			
		||||
      raise FormulaUnspecifiedError if args.no_named?
 | 
			
		||||
      raise FormulaOrCaskUnspecifiedError if args.no_named?
 | 
			
		||||
 | 
			
		||||
      exec_browser(*args.named.to_formulae_and_casks.map { |f| github_info(f) })
 | 
			
		||||
    else
 | 
			
		||||
@ -92,7 +94,7 @@ module Homebrew
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def print_info(args:)
 | 
			
		||||
  def print_analytics(args:)
 | 
			
		||||
    if args.no_named?
 | 
			
		||||
      if args.analytics?
 | 
			
		||||
        Utils::Analytics.output(args: args)
 | 
			
		||||
@ -100,27 +102,43 @@ module Homebrew
 | 
			
		||||
        count = Formula.racks.length
 | 
			
		||||
        puts "#{count} #{"keg".pluralize(count)}, #{HOMEBREW_CELLAR.dup.abv}"
 | 
			
		||||
      end
 | 
			
		||||
    else
 | 
			
		||||
      args.named.each_with_index do |f, i|
 | 
			
		||||
        puts unless i.zero?
 | 
			
		||||
        begin
 | 
			
		||||
          formula = Formulary.factory(f)
 | 
			
		||||
          if args.analytics?
 | 
			
		||||
            Utils::Analytics.formula_output(formula, args: args)
 | 
			
		||||
          else
 | 
			
		||||
            info_formula(formula, args: args)
 | 
			
		||||
          end
 | 
			
		||||
        rescue FormulaUnavailableError => e
 | 
			
		||||
          if args.analytics?
 | 
			
		||||
            Utils::Analytics.output(filter: f, args: args)
 | 
			
		||||
            next
 | 
			
		||||
          end
 | 
			
		||||
          ofail e.message
 | 
			
		||||
          # No formula with this name, try a missing formula lookup
 | 
			
		||||
          if (reason = MissingFormula.reason(f, show_info: true))
 | 
			
		||||
            $stderr.puts reason
 | 
			
		||||
          end
 | 
			
		||||
 | 
			
		||||
      return
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    args.named.to_formulae_casks_unknowns.each_with_index do |obj, i|
 | 
			
		||||
      puts unless i.zero?
 | 
			
		||||
 | 
			
		||||
      case obj
 | 
			
		||||
      when Formula
 | 
			
		||||
        Utils::Analytics.formula_output(obj, args: args)
 | 
			
		||||
      when Cask::Cask
 | 
			
		||||
        Utils::Analytics.cask_output(obj, args: args)
 | 
			
		||||
      when FormulaOrCaskUnavailableError
 | 
			
		||||
        Utils::Analytics.output(filter: obj.name, args: args)
 | 
			
		||||
      else
 | 
			
		||||
        raise
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def print_info(args:)
 | 
			
		||||
    args.named.to_formulae_casks_unknowns(method: nil).each_with_index do |obj, i|
 | 
			
		||||
      puts unless i.zero?
 | 
			
		||||
 | 
			
		||||
      case obj
 | 
			
		||||
      when Formula
 | 
			
		||||
        info_formula(obj, args: args)
 | 
			
		||||
      when Cask::Cask
 | 
			
		||||
        info_cask(obj, args: args)
 | 
			
		||||
      when FormulaOrCaskUnavailableError
 | 
			
		||||
        ofail obj.message
 | 
			
		||||
        # No formula with this name, try a missing formula lookup
 | 
			
		||||
        if (reason = MissingFormula.reason(obj.name, show_info: true))
 | 
			
		||||
          $stderr.puts reason
 | 
			
		||||
        end
 | 
			
		||||
      else
 | 
			
		||||
        raise
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
@ -274,4 +292,10 @@ module Homebrew
 | 
			
		||||
 | 
			
		||||
    "#{dep.name} #{dep.option_tags.map { |o| "--#{o}" }.join(" ")}"
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def info_cask(cask, args:)
 | 
			
		||||
    require "cask/cmd/info"
 | 
			
		||||
 | 
			
		||||
    Cask::Cmd::Info.info(cask)
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user