brew/Library/Homebrew/livecheck.rb

125 lines
3.5 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
2020-09-02 12:24:21 -07:00
# The {Livecheck} class implements the DSL methods used in a formula's or cask'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.
2020-03-16 01:37:49 +05:30
class Livecheck
extend Forwardable
2020-09-02 12:24:21 -07:00
# A very brief description of why the formula/cask is skipped (e.g. `No longer
# developed or maintained`).
# @return [String, nil]
2020-03-16 01:37:49 +05:30
attr_reader :skip_msg
2020-09-02 12:24:21 -07:00
def initialize(formula_or_cask)
@formula_or_cask = formula_or_cask
2020-03-16 01:37:49 +05:30
@regex = nil
@skip = false
@skip_msg = nil
2020-08-05 11:54:37 -04:00
@strategy = nil
2020-03-16 01:37:49 +05:30
@url = nil
end
# Sets the `@regex` instance variable to the provided `Regexp` or returns the
# `@regex` instance variable when no argument is provided.
#
# @param pattern [Regexp] regex to use for matching versions in content
# @return [Regexp, nil]
2020-03-16 01:37:49 +05:30
def regex(pattern = nil)
case pattern
when nil
@regex
when Regexp
@regex = pattern
else
raise TypeError, "Livecheck#regex expects a Regexp"
end
2020-03-16 01:37:49 +05:30
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
2020-09-02 12:24:21 -07:00
# that the formula/cask should be skipped and the `skip_msg` very briefly
# describes why it is skipped (e.g. "No longer developed or maintained").
#
2020-09-02 12:24:21 -07:00
# @param skip_msg [String] string describing why the formula/cask is skipped
# @return [Boolean]
2020-03-16 01:37:49 +05:30
def skip(skip_msg = nil)
if skip_msg.is_a?(String)
@skip_msg = skip_msg
elsif skip_msg.present?
raise TypeError, "Livecheck#skip expects a String"
end
2020-03-16 01:37:49 +05:30
@skip = true
end
2020-09-02 12:24:21 -07:00
# Should `livecheck` skip this formula/cask?
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.
#
2020-08-05 11:54:37 -04:00
# @param symbol [Symbol] symbol for the desired strategy
# @return [Symbol, nil]
def strategy(symbol = nil, &block)
@strategy_block = block if block
2020-08-05 11:54:37 -04:00
case symbol
when nil
@strategy
when Symbol
@strategy = symbol
else
raise TypeError, "Livecheck#strategy expects a Symbol"
end
end
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
# formula/cask (e.g. `:stable`, `:homepage`, `:head`, `:url`).
# @param val [String, Symbol] URL to check for version information
# @return [String, nil]
2020-03-16 01:37:49 +05:30
def url(val = nil)
2020-05-31 00:10:46 +05:30
@url = case val
when nil
return @url
when :url
@formula_or_cask.url.to_s
when :head, :stable
2020-09-02 12:24:21 -07:00
@formula_or_cask.send(val).url
2020-05-31 00:10:46 +05:30
when :homepage
2020-09-02 12:24:21 -07:00
@formula_or_cask.homepage
when String
2020-05-31 00:10:46 +05:30
val
else
raise TypeError, "Livecheck#url expects a String or valid Symbol"
2020-05-31 00:10:46 +05:30
end
2020-03-16 01:37:49 +05:30
end
delegate version: :@formula_or_cask
private :version
# Returns a `Hash` of all instance variable values.
# @return [Hash]
2020-03-16 01:37:49 +05:30
def to_hash
{
"regex" => @regex,
"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