cmd/info: Add support for casks

This commit is contained in:
William Ma 2020-10-08 19:55:24 -04:00
parent 90b92301ae
commit 9a8f4c7c96
2 changed files with 66 additions and 34 deletions

View File

@ -38,6 +38,14 @@ module Homebrew
end end
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) def load_formula_or_cask(name, only: nil, method: nil)
if only != :cask if only != :cask
begin begin

View File

@ -64,27 +64,29 @@ module Homebrew
def info def info
args = info_args.parse args = info_args.parse
if args.days.present? && !VALID_DAYS.include?(args.days) if args.analytics?
raise UsageError, "--days must be one of #{VALID_DAYS.join(", ")}" if args.days.present? && !VALID_DAYS.include?(args.days)
end raise UsageError, "--days must be one of #{VALID_DAYS.join(", ")}"
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 end
unless VALID_CATEGORIES.include?(args.category) if args.category.present?
raise UsageError, "--category must be one of #{VALID_CATEGORIES.join(", ")}" if args.named.present? && !VALID_FORMULA_CATEGORIES.include?(args.category)
end raise UsageError, "--category must be one of #{VALID_FORMULA_CATEGORIES.join(", ")} when querying formulae"
end 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 UsageError, "invalid JSON version: #{args.json}" unless ["v1", true].include? args.json
raise FormulaUnspecifiedError if !(args.all? || args.installed?) && args.no_named? raise FormulaUnspecifiedError if !(args.all? || args.installed?) && args.no_named?
print_json(args: args) print_json(args: args)
elsif args.github? 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) }) exec_browser(*args.named.to_formulae_and_casks.map { |f| github_info(f) })
else else
@ -92,7 +94,7 @@ module Homebrew
end end
end end
def print_info(args:) def print_analytics(args:)
if args.no_named? if args.no_named?
if args.analytics? if args.analytics?
Utils::Analytics.output(args: args) Utils::Analytics.output(args: args)
@ -100,27 +102,43 @@ module Homebrew
count = Formula.racks.length count = Formula.racks.length
puts "#{count} #{"keg".pluralize(count)}, #{HOMEBREW_CELLAR.dup.abv}" puts "#{count} #{"keg".pluralize(count)}, #{HOMEBREW_CELLAR.dup.abv}"
end end
else
args.named.each_with_index do |f, i| return
puts unless i.zero? end
begin
formula = Formulary.factory(f) args.named.to_formulae_casks_unknowns.each_with_index do |obj, i|
if args.analytics? puts unless i.zero?
Utils::Analytics.formula_output(formula, args: args)
else case obj
info_formula(formula, args: args) when Formula
end Utils::Analytics.formula_output(obj, args: args)
rescue FormulaUnavailableError => e when Cask::Cask
if args.analytics? Utils::Analytics.cask_output(obj, args: args)
Utils::Analytics.output(filter: f, args: args) when FormulaOrCaskUnavailableError
next Utils::Analytics.output(filter: obj.name, args: args)
end else
ofail e.message raise
# No formula with this name, try a missing formula lookup end
if (reason = MissingFormula.reason(f, show_info: true)) end
$stderr.puts reason 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 end
else
raise
end end
end end
end end
@ -274,4 +292,10 @@ module Homebrew
"#{dep.name} #{dep.option_tags.map { |o| "--#{o}" }.join(" ")}" "#{dep.name} #{dep.option_tags.map { |o| "--#{o}" }.join(" ")}"
end end
def info_cask(cask, args:)
require "cask/cmd/info"
Cask::Cmd::Info.info(cask)
end
end end