Skip to content
Snippets Groups Projects
Unverified Commit 5d38cd72 authored by Sean Molenaar's avatar Sean Molenaar
Browse files

cask/list: fix artifact list

parent 535e7dc8
No related branches found
No related tags found
No related merge requests found
# 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
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment