move cask/cmd/list to cask/list
This commit is contained in:
parent
10dd6a30ca
commit
e39232313f
@ -13,7 +13,6 @@ require "cask/cmd/abstract_command"
|
|||||||
require "cask/cmd/audit"
|
require "cask/cmd/audit"
|
||||||
require "cask/cmd/fetch"
|
require "cask/cmd/fetch"
|
||||||
require "cask/cmd/install"
|
require "cask/cmd/install"
|
||||||
require "cask/cmd/list"
|
|
||||||
require "cask/cmd/reinstall"
|
require "cask/cmd/reinstall"
|
||||||
require "cask/cmd/uninstall"
|
require "cask/cmd/uninstall"
|
||||||
require "cask/cmd/upgrade"
|
require "cask/cmd/upgrade"
|
||||||
|
|||||||
@ -1,81 +0,0 @@
|
|||||||
# typed: false
|
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
require "cask/artifact/relocated"
|
|
||||||
|
|
||||||
module Cask
|
|
||||||
class Cmd
|
|
||||||
# Cask implementation of the `brew list` command.
|
|
||||||
#
|
|
||||||
# @api private
|
|
||||||
class List < AbstractCommand
|
|
||||||
extend T::Sig
|
|
||||||
|
|
||||||
def self.parser
|
|
||||||
super do
|
|
||||||
switch "-1",
|
|
||||||
description: "Force output to be one entry per line."
|
|
||||||
switch "--versions",
|
|
||||||
description: "Show the version number the listed casks."
|
|
||||||
switch "--full-name",
|
|
||||||
description: "Print casks with fully-qualified names."
|
|
||||||
switch "--json",
|
|
||||||
description: "Print a JSON representation of the listed casks. "
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
sig { void }
|
|
||||||
def run
|
|
||||||
self.class.list_casks(
|
|
||||||
*casks,
|
|
||||||
json: args.json?,
|
|
||||||
one: args.public_send(:"1?"),
|
|
||||||
full_name: args.full_name?,
|
|
||||||
versions: args.versions?,
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
def self.list_casks(*casks, json: false, one: false, full_name: false, versions: false)
|
|
||||||
output = if casks.any?
|
|
||||||
casks.each do |cask|
|
|
||||||
raise CaskNotInstalledError, cask unless cask.installed?
|
|
||||||
end
|
|
||||||
else
|
|
||||||
Caskroom.casks
|
|
||||||
end
|
|
||||||
|
|
||||||
if json
|
|
||||||
puts JSON.pretty_generate(output.map(&:to_h))
|
|
||||||
elsif one
|
|
||||||
puts output.map(&:to_s)
|
|
||||||
elsif full_name
|
|
||||||
puts output.map(&:full_name).sort(&tap_and_name_comparison)
|
|
||||||
elsif versions
|
|
||||||
puts output.map(&method(:format_versioned))
|
|
||||||
elsif !output.empty? && casks.any?
|
|
||||||
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).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)
|
|
||||||
|
|
||||||
puts artifact
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def self.format_versioned(cask)
|
|
||||||
cask.to_s.concat(cask.versions.map(&:to_s).join(" ").prepend(" "))
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
50
Library/Homebrew/cask/list.rb
Normal file
50
Library/Homebrew/cask/list.rb
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
# typed: false
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require "cask/artifact/relocated"
|
||||||
|
|
||||||
|
module Cask
|
||||||
|
# @api private
|
||||||
|
class List
|
||||||
|
|
||||||
|
def self.list_casks(*casks, one: false, full_name: false, versions: false)
|
||||||
|
output = if casks.any?
|
||||||
|
casks.each do |cask|
|
||||||
|
raise CaskNotInstalledError, cask unless cask.installed?
|
||||||
|
end
|
||||||
|
else
|
||||||
|
Caskroom.casks
|
||||||
|
end
|
||||||
|
|
||||||
|
if one
|
||||||
|
puts output.map(&:to_s)
|
||||||
|
elsif full_name
|
||||||
|
puts output.map(&:full_name).sort(&tap_and_name_comparison)
|
||||||
|
elsif versions
|
||||||
|
puts output.map(&method(:format_versioned))
|
||||||
|
elsif !output.empty? && casks.any?
|
||||||
|
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).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)
|
||||||
|
|
||||||
|
puts artifact
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.format_versioned(cask)
|
||||||
|
cask.to_s.concat(cask.versions.map(&:to_s).join(" ").prepend(" "))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
@ -4,7 +4,7 @@
|
|||||||
require "metafiles"
|
require "metafiles"
|
||||||
require "formula"
|
require "formula"
|
||||||
require "cli/parser"
|
require "cli/parser"
|
||||||
require "cask/cmd"
|
require "cask/list"
|
||||||
|
|
||||||
module Homebrew
|
module Homebrew
|
||||||
extend T::Sig
|
extend T::Sig
|
||||||
@ -164,7 +164,7 @@ module Homebrew
|
|||||||
end
|
end
|
||||||
return if casks.blank?
|
return if casks.blank?
|
||||||
|
|
||||||
Cask::Cmd::List.list_casks(
|
Cask::List.list_casks(
|
||||||
*casks,
|
*casks,
|
||||||
one: args.public_send(:"1?"),
|
one: args.public_send(:"1?"),
|
||||||
full_name: args.full_name?,
|
full_name: args.full_name?,
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user