brew/Library/Homebrew/livecheck.rb

197 lines
5.6 KiB
Ruby
Raw Normal View History

2020-10-10 14:16:11 +02:00
# typed: true
2020-03-16 01:37:49 +05:30
# frozen_string_literal: true
require "livecheck/constants"
2022-07-02 10:09:25 +02:00
# The {Livecheck} class implements the DSL methods used in a formula's, cask's
# or resource's `livecheck` block and stores related instance variables. Most
# of these methods also return the related instance variable when no argument
# is provided.
#
# This information is used by the `brew livecheck` command to control its
# behavior. Example `livecheck` blocks can be found in the
# [`brew livecheck` documentation](https://docs.brew.sh/Brew-Livecheck).
2020-03-16 01:37:49 +05:30
class Livecheck
extend Forwardable
2022-07-02 10:09:25 +02:00
# A very brief description of why the formula/cask/resource is skipped (e.g.
# `No longer developed or maintained`).
2023-04-21 01:21:38 +02:00
sig { returns(T.nilable(String)) }
2020-03-16 01:37:49 +05:30
attr_reader :skip_msg
2023-04-21 01:21:38 +02:00
sig { params(package_or_resource: T.any(Cask::Cask, T.class_of(Formula), Resource)).void }
2022-07-02 10:09:25 +02:00
def initialize(package_or_resource)
@package_or_resource = package_or_resource
@referenced_cask_name = nil
@referenced_formula_name = nil
2020-03-16 01:37:49 +05:30
@regex = nil
@throttle = nil
2020-03-16 01:37:49 +05:30
@skip = false
@skip_msg = nil
2020-08-05 11:54:37 -04:00
@strategy = nil
2023-04-21 01:21:38 +02:00
@strategy_block = nil
2020-03-16 01:37:49 +05:30
@url = nil
end
# Sets the `@referenced_cask_name` instance variable to the provided `String`
# or returns the `@referenced_cask_name` instance variable when no argument
# is provided. Inherited livecheck values from the referenced cask
# (e.g. regex) can be overridden in the livecheck block.
2023-04-21 01:21:38 +02:00
sig {
params(
# Name of cask to inherit livecheck info from.
cask_name: String,
).returns(T.nilable(String))
}
def cask(cask_name = T.unsafe(nil))
case cask_name
when nil
@referenced_cask_name
when String
@referenced_cask_name = cask_name
end
end
# Sets the `@referenced_formula_name` instance variable to the provided
# `String` or returns the `@referenced_formula_name` instance variable when
# no argument is provided. Inherited livecheck values from the referenced
# formula (e.g. regex) can be overridden in the livecheck block.
2023-04-21 01:21:38 +02:00
sig {
params(
# Name of formula to inherit livecheck info from.
formula_name: String,
).returns(T.nilable(String))
}
def formula(formula_name = T.unsafe(nil))
case formula_name
when nil
@referenced_formula_name
when String
@referenced_formula_name = formula_name
end
end
# Sets the `@regex` instance variable to the provided `Regexp` or returns the
# `@regex` instance variable when no argument is provided.
2023-04-21 01:21:38 +02:00
sig {
params(
# Regex to use for matching versions in content.
pattern: Regexp,
).returns(T.nilable(Regexp))
}
def regex(pattern = T.unsafe(nil))
case pattern
when nil
@regex
when Regexp
@regex = pattern
end
2020-03-16 01:37:49 +05:30
end
# Sets the `@throttle` instance variable to the provided `Integer` or returns
# the `@throttle` instance variable when no argument is provided.
sig {
params(
# Throttle rate of version patch number to use for bumpable versions.
rate: T.nilable(Integer),
).returns(T.nilable(Integer))
}
def throttle(rate = T.unsafe(nil))
case rate
when nil
@throttle
when Integer
@throttle = rate
end
end
# Sets the `@skip` instance variable to `true` and sets the `@skip_msg`
# instance variable if a `String` is provided. `@skip` is used to indicate
2022-07-02 10:09:25 +02:00
# that the formula/cask/resource should be skipped and the `skip_msg` very
# briefly describes why it is skipped (e.g. "No longer developed or
# maintained").
2023-04-21 01:21:38 +02:00
sig {
params(
# String describing why the formula/cask is skipped.
skip_msg: String,
).returns(T::Boolean)
}
def skip(skip_msg = T.unsafe(nil))
@skip_msg = skip_msg if skip_msg.is_a?(String)
2020-03-16 01:37:49 +05:30
@skip = true
end
2022-07-02 10:09:25 +02:00
# Should `livecheck` skip this formula/cask/resource?
2023-04-21 01:21:38 +02:00
sig { returns(T::Boolean) }
2020-03-16 01:37:49 +05:30
def skip?
@skip
end
# Sets the `@strategy` instance variable to the provided `Symbol` or returns
# the `@strategy` instance variable when no argument is provided. The strategy
# symbols use snake case (e.g. `:page_match`) and correspond to the strategy
2020-08-05 11:54:37 -04:00
# file name.
2023-04-21 01:21:38 +02:00
sig {
params(
# Symbol for the desired strategy.
symbol: Symbol,
block: T.nilable(Proc),
).returns(T.nilable(Symbol))
}
def strategy(symbol = T.unsafe(nil), &block)
@strategy_block = block if block
2020-08-05 11:54:37 -04:00
case symbol
when nil
@strategy
when Symbol
@strategy = symbol
end
end
2023-04-21 01:21:38 +02:00
sig { returns(T.nilable(Proc)) }
attr_reader :strategy_block
# Sets the `@url` instance variable to the provided argument or returns the
# `@url` instance variable when no argument is provided. The argument can be
# a `String` (a URL) or a supported `Symbol` corresponding to a URL in the
2022-07-02 10:09:25 +02:00
# formula/cask/resource (e.g. `:stable`, `:homepage`, `:head`, `:url`).
2023-04-21 01:21:38 +02:00
sig {
params(
# URL to check for version information.
url: T.any(String, Symbol),
).returns(T.nilable(T.any(String, Symbol)))
}
def url(url = T.unsafe(nil))
case url
when nil
@url
when String, :head, :homepage, :stable, :url
2023-04-21 01:21:38 +02:00
@url = url
when Symbol
raise ArgumentError, "#{url.inspect} is not a valid URL shorthand"
2020-05-31 00:10:46 +05:30
end
2020-03-16 01:37:49 +05:30
end
2022-07-02 10:09:25 +02:00
delegate version: :@package_or_resource
2022-08-05 15:51:02 -04:00
delegate arch: :@package_or_resource
private :version, :arch
# Returns a `Hash` of all instance variable values.
# @return [Hash]
2023-04-21 01:21:38 +02:00
sig { returns(T::Hash[String, T.untyped]) }
2020-03-16 01:37:49 +05:30
def to_hash
{
"cask" => @referenced_cask_name,
"formula" => @referenced_formula_name,
2020-03-16 01:37:49 +05:30
"regex" => @regex,
"throttle" => @throttle,
2020-03-16 01:37:49 +05:30
"skip" => @skip,
"skip_msg" => @skip_msg,
2020-08-05 11:54:37 -04:00
"strategy" => @strategy,
2020-03-16 01:37:49 +05:30
"url" => @url,
}
end
end