Merge pull request #14839 from hyuraku/move-cask/cmd/info-to-cask/info

Move `cask/cmd/info` to `cask/info`
This commit is contained in:
Mike McQuaid 2023-03-01 12:25:26 +00:00 committed by GitHub
commit 9296db0c41
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 112 additions and 201 deletions

View File

@ -12,7 +12,6 @@ require "cask/config"
require "cask/cmd/abstract_command"
require "cask/cmd/audit"
require "cask/cmd/fetch"
require "cask/cmd/info"
require "cask/cmd/install"
require "cask/cmd/list"
require "cask/cmd/reinstall"

View File

@ -1,154 +0,0 @@
# typed: false
# frozen_string_literal: true
require "json"
module Cask
class Cmd
# Cask implementation of the `brew info` command.
#
# @api private
class Info < AbstractCommand
extend T::Sig
def self.parser
super do
flag "--json=",
description: "Output information in JSON format."
switch "--github",
description: "Open the GitHub source page for <Cask> in a browser. "
end
end
def github_info(cask)
sourcefile_path = cask.sourcefile_path
dir = cask.tap.path
path = sourcefile_path.relative_path_from(dir)
remote = cask.tap.remote
github_remote_path(remote, path)
end
def github_remote_path(remote, path)
if remote =~ %r{^(?:https?://|git(?:@|://))github\.com[:/](.+)/(.+?)(?:\.git)?$}
"https://github.com/#{Regexp.last_match(1)}/#{Regexp.last_match(2)}/blob/HEAD/#{path}"
else
"#{remote}/#{path}"
end
end
sig { void }
def run
if args.json == "v1"
puts JSON.pretty_generate(args.named.to_casks.map(&:to_h))
elsif args.github?
raise CaskUnspecifiedError if args.no_named?
args.named.to_casks.map do |cask|
exec_browser(github_info(cask))
end
else
args.named.to_casks.each_with_index do |cask, i|
puts unless i.zero?
odebug "Getting info for Cask #{cask}"
self.class.info(cask)
end
end
end
def self.get_info(cask)
require "cask/installer"
output = +"#{title_info(cask)}\n"
output << "#{Formatter.url(cask.homepage)}\n" if cask.homepage
output << installation_info(cask)
repo = repo_info(cask)
output << "#{repo}\n" if repo
output << name_info(cask)
output << desc_info(cask)
language = language_info(cask)
output << language if language
output << "#{artifact_info(cask)}\n"
caveats = Installer.caveats(cask)
output << caveats if caveats
output
end
def self.info(cask)
puts get_info(cask)
::Utils::Analytics.cask_output(cask, args: Homebrew::CLI::Args.new)
end
def self.title_info(cask)
title = "#{oh1_title(cask.token)}: #{cask.version}"
title += " (auto_updates)" if cask.auto_updates
title
end
def self.formatted_url(url)
"#{Tty.underline}#{url}#{Tty.reset}"
end
def self.installation_info(cask)
return "Not installed\n" unless cask.installed?
install_info = +""
cask.versions.each do |version|
versioned_staged_path = cask.caskroom_path.join(version)
path_details = if versioned_staged_path.exist?
versioned_staged_path.abv
else
Formatter.error("does not exist")
end
install_info << "#{versioned_staged_path} (#{path_details})\n"
end
install_info.freeze
end
def self.name_info(cask)
<<~EOS
#{ohai_title((cask.name.size > 1) ? "Names" : "Name")}
#{cask.name.empty? ? Formatter.error("None") : cask.name.join("\n")}
EOS
end
def self.desc_info(cask)
<<~EOS
#{ohai_title("Description")}
#{cask.desc.nil? ? Formatter.error("None") : cask.desc}
EOS
end
def self.language_info(cask)
return if cask.languages.empty?
<<~EOS
#{ohai_title("Languages")}
#{cask.languages.join(", ")}
EOS
end
def self.repo_info(cask)
return if cask.tap.nil?
url = if cask.tap.custom_remote? && !cask.tap.remote.nil?
cask.tap.remote
else
"#{cask.tap.default_remote}/blob/HEAD/Casks/#{cask.token}.rb"
end
"From: #{Formatter.url(url)}"
end
def self.artifact_info(cask)
artifact_output = ohai_title("Artifacts").dup
cask.artifacts.each do |artifact|
next unless artifact.respond_to?(:install_phase)
next unless DSL::ORDINARY_ARTIFACT_CLASSES.include?(artifact.class)
artifact_output << "\n" << artifact.to_s
end
artifact_output.freeze
end
end
end
end

View File

@ -0,0 +1,101 @@
# typed: false
# frozen_string_literal: true
require "json"
module Cask
#
# @api private
class Info
def self.get_info(cask)
require "cask/installer"
output = +"#{title_info(cask)}\n"
output << "#{Formatter.url(cask.homepage)}\n" if cask.homepage
output << installation_info(cask)
repo = repo_info(cask)
output << "#{repo}\n" if repo
output << name_info(cask)
output << desc_info(cask)
language = language_info(cask)
output << language if language
output << "#{artifact_info(cask)}\n"
caveats = Installer.caveats(cask)
output << caveats if caveats
output
end
def self.info(cask)
puts get_info(cask)
::Utils::Analytics.cask_output(cask, args: Homebrew::CLI::Args.new)
end
def self.title_info(cask)
title = "#{oh1_title(cask.token)}: #{cask.version}"
title += " (auto_updates)" if cask.auto_updates
title
end
def self.installation_info(cask)
return "Not installed\n" unless cask.installed?
install_info = +""
cask.versions.each do |version|
versioned_staged_path = cask.caskroom_path.join(version)
path_details = if versioned_staged_path.exist?
versioned_staged_path.abv
else
Formatter.error("does not exist")
end
install_info << "#{versioned_staged_path} (#{path_details})\n"
end
install_info.freeze
end
def self.name_info(cask)
<<~EOS
#{ohai_title((cask.name.size > 1) ? "Names" : "Name")}
#{cask.name.empty? ? Formatter.error("None") : cask.name.join("\n")}
EOS
end
def self.desc_info(cask)
<<~EOS
#{ohai_title("Description")}
#{cask.desc.nil? ? Formatter.error("None") : cask.desc}
EOS
end
def self.language_info(cask)
return if cask.languages.empty?
<<~EOS
#{ohai_title("Languages")}
#{cask.languages.join(", ")}
EOS
end
def self.repo_info(cask)
return if cask.tap.nil?
url = if cask.tap.custom_remote? && !cask.tap.remote.nil?
cask.tap.remote
else
"#{cask.tap.default_remote}/blob/HEAD/Casks/#{cask.token}.rb"
end
"From: #{Formatter.url(url)}"
end
def self.artifact_info(cask)
artifact_output = ohai_title("Artifacts").dup
cask.artifacts.each do |artifact|
next unless artifact.respond_to?(:install_phase)
next unless DSL::ORDINARY_ARTIFACT_CLASSES.include?(artifact.class)
artifact_output << "\n" << artifact.to_s
end
artifact_output.freeze
end
end
end

View File

@ -375,9 +375,8 @@ module Homebrew
end
def info_cask(cask, args:)
require "cask/cmd"
require "cask/cmd/info"
require "cask/info"
Cask::Cmd::Info.info(cask)
Cask::Info.info(cask)
end
end

View File

@ -2,7 +2,7 @@
# frozen_string_literal: true
require "cask/cmd/abstract_command"
require "cask/cmd/info"
require "cask/info"
require "cask/cask_loader"
require "cask/caskroom"
@ -48,7 +48,7 @@ module Homebrew
suggestion = <<~EOS
Found a cask named "#{name}" instead.
#{Cask::Cmd::Info.get_info(cask)}
#{Cask::Info.get_info(cask)}
EOS
else
return

View File

@ -3,10 +3,10 @@
require "utils"
describe Cask::Cmd::Info, :cask do
describe Cask::Info, :cask do
it "displays some nice info about the specified Cask" do
expect {
described_class.run("local-transmission")
described_class.info(Cask::CaskLoader.load("local-transmission"))
}.to output(<<~EOS).to_stdout
==> local-transmission: 2.61
https://transmissionbt.com/
@ -23,7 +23,7 @@ describe Cask::Cmd::Info, :cask do
it "prints auto_updates if the Cask has `auto_updates true`" do
expect {
described_class.run("with-auto-updates")
described_class.info(Cask::CaskLoader.load("with-auto-updates"))
}.to output(<<~EOS).to_stdout
==> with-auto-updates: 1.0 (auto_updates)
https://brew.sh/autoupdates
@ -38,43 +38,9 @@ describe Cask::Cmd::Info, :cask do
EOS
end
describe "given multiple Casks" do
let(:expected_output) {
<<~EOS
==> local-caffeine: 1.2.3
https://brew.sh/
Not installed
From: https://github.com/Homebrew/homebrew-cask/blob/HEAD/Casks/local-caffeine.rb
==> Name
None
==> Description
None
==> Artifacts
Caffeine.app (App)
==> local-transmission: 2.61
https://transmissionbt.com/
Not installed
From: https://github.com/Homebrew/homebrew-cask/blob/HEAD/Casks/local-transmission.rb
==> Name
Transmission
==> Description
BitTorrent client
==> Artifacts
Transmission.app (App)
EOS
}
it "displays the info" do
expect {
described_class.run("local-caffeine", "local-transmission")
}.to output(expected_output).to_stdout
end
end
it "prints caveats if the Cask provided one" do
expect {
described_class.run("with-caveats")
described_class.info(Cask::CaskLoader.load("with-caveats"))
}.to output(<<~EOS).to_stdout
==> with-caveats: 1.2.3
https://brew.sh/
@ -101,7 +67,7 @@ describe Cask::Cmd::Info, :cask do
it 'does not print "Caveats" section divider if the caveats block has no output' do
expect {
described_class.run("with-conditional-caveats")
described_class.info(Cask::CaskLoader.load("with-conditional-caveats"))
}.to output(<<~EOS).to_stdout
==> with-conditional-caveats: 1.2.3
https://brew.sh/
@ -118,7 +84,7 @@ describe Cask::Cmd::Info, :cask do
it "prints languages specified in the Cask" do
expect {
described_class.run("with-languages")
described_class.info(Cask::CaskLoader.load("with-languages"))
}.to output(<<~EOS).to_stdout
==> with-languages: 1.2.3
https://brew.sh/
@ -137,7 +103,7 @@ describe Cask::Cmd::Info, :cask do
it 'does not print "Languages" section divider if the languages block has no output' do
expect {
described_class.run("without-languages")
described_class.info(Cask::CaskLoader.load("without-languages"))
}.to output(<<~EOS).to_stdout
==> without-languages: 1.2.3
https://brew.sh/