mirror of
https://github.com/Homebrew/brew.git
synced 2025-07-14 16:09:03 +08:00

Formulae, casks, and resources have a `#livecheckable?` method that indicates whether they contain a `livecheck` block. This is intended to be read as "has a livecheckable?", not "is livecheckable?" (as livecheck can find versions for some packages/resources without a `livecheck` block). Unfortunately, correct understanding of this method's behavior [outside of documentation] relies on historical knowledge that few people possess, so this is often confusing to anyone who hasn't been working on livecheck since 2020. In the olden days, a "livecheckable" was a Ruby file containing a `livecheck` block (originally a hash) with a filename that corresponded to a related formula. The `livecheck` blocks in livecheckable files were integrated into their respective formulae in August 2020, so [first-party] livecheckables ceased to exist at that time. From that point forward, we simply referred to these as `livecheck` blocks. With that in mind, this clarifies the situation by replacing "livecheckable" language. This includes renaming `#livecheckable?` to `#livecheck_defined?`, replacing usage of "livecheckable" as a noun with "`livecheck` block", replacing "livecheckable" as a boolean with "livecheck_defined", and replacing incorrect usage of "livecheckable" as an adjective with "checkable".
110 lines
2.8 KiB
Ruby
110 lines
2.8 KiB
Ruby
# typed: strict
|
|
# frozen_string_literal: true
|
|
|
|
require "abstract_command"
|
|
require "formula"
|
|
require "formulary"
|
|
require "cask/cask_loader"
|
|
|
|
class String
|
|
# @!visibility private
|
|
sig { params(args: Integer).returns(Formula) }
|
|
def f(*args)
|
|
Formulary.factory(self, *args)
|
|
end
|
|
|
|
# @!visibility private
|
|
sig { params(config: T.nilable(T::Hash[Symbol, T.untyped])).returns(Cask::Cask) }
|
|
def c(config: nil)
|
|
Cask::CaskLoader.load(self, config:)
|
|
end
|
|
end
|
|
|
|
class Symbol
|
|
# @!visibility private
|
|
sig { params(args: Integer).returns(Formula) }
|
|
def f(*args)
|
|
to_s.f(*args)
|
|
end
|
|
|
|
# @!visibility private
|
|
sig { params(config: T.nilable(T::Hash[Symbol, T.untyped])).returns(Cask::Cask) }
|
|
def c(config: nil)
|
|
to_s.c(config:)
|
|
end
|
|
end
|
|
|
|
module Homebrew
|
|
module DevCmd
|
|
class Irb < AbstractCommand
|
|
cmd_args do
|
|
description <<~EOS
|
|
Enter the interactive Homebrew Ruby shell.
|
|
EOS
|
|
switch "--examples",
|
|
description: "Show several examples."
|
|
switch "--pry",
|
|
env: :pry,
|
|
description: "Use Pry instead of IRB. Implied if `HOMEBREW_PRY` is set."
|
|
end
|
|
|
|
# work around IRB modifying ARGV.
|
|
sig { params(argv: T.nilable(T::Array[String])).void }
|
|
def initialize(argv = nil) = super(argv || ARGV.dup.freeze)
|
|
|
|
sig { override.void }
|
|
def run
|
|
clean_argv
|
|
|
|
if args.examples?
|
|
puts <<~EOS
|
|
'v8'.f # => instance of the v8 formula
|
|
:hub.f.latest_version_installed?
|
|
:lua.f.methods - 1.methods
|
|
:mpd.f.recursive_dependencies.reject(&:installed?)
|
|
|
|
'vlc'.c # => instance of the vlc cask
|
|
:tsh.c.livecheck_defined?
|
|
EOS
|
|
return
|
|
end
|
|
|
|
if args.pry?
|
|
Homebrew.install_bundler_gems!(groups: ["pry"])
|
|
require "pry"
|
|
else
|
|
require "irb"
|
|
end
|
|
|
|
require "keg"
|
|
require "cask"
|
|
|
|
ohai "Interactive Homebrew Shell", "Example commands available with: `brew irb --examples`"
|
|
if args.pry?
|
|
Pry.config.should_load_rc = false # skip loading .pryrc
|
|
Pry.config.history_file = "#{Dir.home}/.brew_pry_history"
|
|
Pry.config.prompt_name = "brew"
|
|
|
|
Pry.start
|
|
else
|
|
ENV["IRBRC"] = (HOMEBREW_LIBRARY_PATH/"brew_irbrc").to_s
|
|
|
|
IRB.start
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
# Remove the `--debug`, `--verbose` and `--quiet` options which cause problems
|
|
# for IRB and have already been parsed by the CLI::Parser.
|
|
sig { returns(T.nilable(T::Array[Symbol])) }
|
|
def clean_argv
|
|
global_options = Homebrew::CLI::Parser
|
|
.global_options
|
|
.flat_map { |options| options[0..1] }
|
|
ARGV.reject! { |arg| global_options.include?(arg) }
|
|
end
|
|
end
|
|
end
|
|
end
|