outdated: Fix most code review comments

This commit is contained in:
William Ma 2020-07-22 22:06:48 -04:00
parent fa0f6f4d5b
commit 8d4a443e4d

View File

@ -46,7 +46,7 @@ module Homebrew
case json_version case json_version
when :v1 when :v1
opoo "JSON v1 has been deprecated; please use --json=v2" odeprecated "brew outdated --json=v1", "brew outdated --json=v2"
outdated = if args.formula? || !args.cask? outdated = if args.formula? || !args.cask?
outdated_formulae outdated_formulae
@ -87,67 +87,67 @@ module Homebrew
Homebrew.failed = args.named.present? && outdated.present? Homebrew.failed = args.named.present? && outdated.present?
end end
def print_outdated(formula_or_cask) def print_outdated(formulae_or_casks)
return formula_or_cask.each { |f_or_c| print_outdated(f_or_c) } if formula_or_cask.is_a? Array formulae_or_casks.each do |formula_or_cask|
if formula_or_cask.is_a?(Formula)
f = formula_or_cask
if formula_or_cask.is_a?(Formula) if verbose?
f = formula_or_cask outdated_kegs = f.outdated_kegs(fetch_head: args.fetch_HEAD?)
if verbose? current_version = if f.alias_changed?
outdated_kegs = f.outdated_kegs(fetch_head: args.fetch_HEAD?) latest = f.latest_formula
"#{latest.name} (#{latest.pkg_version})"
elsif f.head? && outdated_kegs.any? { |k| k.version.to_s == f.pkg_version.to_s }
# There is a newer HEAD but the version number has not changed.
"latest HEAD"
else
f.pkg_version.to_s
end
current_version = if f.alias_changed? outdated_versions = outdated_kegs
latest = f.latest_formula .group_by { |keg| Formulary.from_keg(keg).full_name }
"#{latest.name} (#{latest.pkg_version})" .sort_by { |full_name, _kegs| full_name }
elsif f.head? && outdated_kegs.any? { |k| k.version.to_s == f.pkg_version.to_s } .map do |full_name, kegs|
# There is a newer HEAD but the version number has not changed. "#{full_name} (#{kegs.map(&:version).join(", ")})"
"latest HEAD" end.join(", ")
pinned_version = " [pinned at #{f.pinned_version}]" if f.pinned?
puts "#{outdated_versions} < #{current_version}#{pinned_version}"
else
puts f.full_installed_specified_name
end
else
c = formula_or_cask
puts c.outdated_info(args.greedy?, verbose?, false)
end
end
end
def json_info(formulae_or_casks)
formulae_or_casks.map do |formula_or_cask|
if formula_or_cask.is_a?(Formula)
f = formula_or_cask
outdated_versions = f.outdated_kegs(fetch_head: args.fetch_HEAD?).map(&:version)
current_version = if f.head? && outdated_versions.any? { |v| v.to_s == f.pkg_version.to_s }
"HEAD"
else else
f.pkg_version.to_s f.pkg_version.to_s
end end
outdated_versions = outdated_kegs { name: f.full_name,
.group_by { |keg| Formulary.from_keg(keg).full_name } installed_versions: outdated_versions.map(&:to_s),
.sort_by { |full_name, _kegs| full_name } current_version: current_version,
.map do |full_name, kegs| pinned: f.pinned?,
"#{full_name} (#{kegs.map(&:version).join(", ")})" pinned_version: f.pinned_version }
end.join(", ")
pinned_version = " [pinned at #{f.pinned_version}]" if f.pinned?
puts "#{outdated_versions} < #{current_version}#{pinned_version}"
else else
puts f.full_installed_specified_name c = formula_or_cask
c.outdated_info(args.greedy?, verbose?, true)
end end
else
c = formula_or_cask
puts c.outdated_info(args.greedy?, verbose?, false)
end
end
def json_info(formula_or_cask)
return formula_or_cask.map { |f_or_c| json_info(f_or_c) } if formula_or_cask.is_a? Array
if formula_or_cask.is_a?(Formula)
f = formula_or_cask
outdated_versions = f.outdated_kegs(fetch_head: args.fetch_HEAD?).map(&:version)
current_version = if f.head? && outdated_versions.any? { |v| v.to_s == f.pkg_version.to_s }
"HEAD"
else
f.pkg_version.to_s
end
{ name: f.full_name,
installed_versions: outdated_versions.map(&:to_s),
current_version: current_version,
pinned: f.pinned?,
pinned_version: f.pinned_version }
else
c = formula_or_cask
c.outdated_info(args.greedy?, verbose?, true)
end end
end end
@ -173,9 +173,11 @@ module Homebrew
end end
def outdated_casks def outdated_casks
select_outdated( if args.named.present?
args.named.present? ? args.named.uniq.map { |ref| Cask::CaskLoader.load ref } : Cask::Caskroom.casks, select_outdated(args.named.uniq.map(&Cask::CaskLoader.method(:load)))
) else
select_outdated(Cask::Caskroom.casks)
end
end end
def outdated_formulae_casks def outdated_formulae_casks
@ -190,8 +192,12 @@ module Homebrew
end end
def select_outdated(formulae_or_casks) def select_outdated(formulae_or_casks)
formulae_or_casks.select do |fc| formulae_or_casks.select do |formula_or_cask|
fc.is_a?(Formula) ? fc.outdated?(fetch_head: args.fetch_HEAD?) : fc.outdated?(args.greedy?) if formula_or_cask.is_a?(Formula)
formula_or_cask.outdated?(fetch_head: args.fetch_HEAD?)
else
formula_or_cask.outdated?(args.greedy?)
end
end end
end end
end end