未验证 提交 19ef9328 编写于 作者: M Mike McQuaid 提交者: GitHub

Merge pull request #8355 from SMillerDev/fix/cask_list/artifacts

cask/list: fix artifact list
# frozen_string_literal: true
require "cask/artifact/relocated"
module Cask
class Cmd
class List < AbstractCommand
......@@ -48,17 +50,23 @@ module Cask
elsif versions
puts output.map(&method(:format_versioned))
elsif !output.empty? && casks.any?
puts output.map(&method(:list_artifacts))
output.map(&method(:list_artifacts))
elsif !output.empty?
puts Formatter.columns(output.map(&:to_s))
end
end
def self.list_artifacts(cask)
cask.artifacts.group_by(&:class).each do |klass, artifacts|
next unless klass.respond_to?(:english_description)
cask.artifacts.group_by(&:class).sort_by { |klass, _| klass.english_name }.each do |klass, artifacts|
next if [Artifact::Uninstall, Artifact::Zap].include? klass
ohai klass.english_name
artifacts.each do |artifact|
puts artifact.summarize_installed if artifact.respond_to?(:summarize_installed)
next if artifact.respond_to?(:summarize_installed)
return "==> #{klass.english_description}", artifacts.map(&:summarize_installed)
puts artifact
end
end
end
......
......@@ -126,9 +126,9 @@ describe Cask::Cmd::List, :cask do
expect {
described_class.run("local-transmission", "local-caffeine")
}.to output(<<~EOS).to_stdout
==> Apps
==> App
#{transmission.config.appdir.join("Transmission.app")} (#{transmission.config.appdir.join("Transmission.app").abv})
==> Apps
==> App
Missing App: #{caffeine.config.appdir.join("Caffeine.app")}
EOS
end
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册