Class: Livecheck

Inherits:
Object
  • Object
show all
Defined in:
Library/Homebrew/livecheck.rb

Overview

The Livecheck class implements the DSL methods used in a formula'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.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(formula) ⇒ Livecheck

Returns a new instance of Livecheck.


15
16
17
18
19
20
21
22
# File 'Library/Homebrew/livecheck.rb', line 15

def initialize(formula)
  @formula = formula
  @regex = nil
  @skip = false
  @skip_msg = nil
  @strategy = nil
  @url = nil
end

Instance Attribute Details

#skip_msgString? (readonly)

A very brief description of why the formula is skipped (e.g., No longer developed or maintained).

Returns:


13
14
15
# File 'Library/Homebrew/livecheck.rb', line 13

def skip_msg
  @skip_msg
end

Instance Method Details

#regex(pattern = nil) ⇒ Regexp?

Sets the @regex instance variable to the provided Regexp or returns the @regex instance variable when no argument is provided.

Parameters:

  • pattern (Regexp) (defaults to: nil)

    regex to use for matching versions in content

Returns:

  • (Regexp, nil)

28
29
30
31
32
33
34
35
36
37
# File 'Library/Homebrew/livecheck.rb', line 28

def regex(pattern = nil)
  case pattern
  when nil
    @regex
  when Regexp
    @regex = pattern
  else
    raise TypeError, "Livecheck#regex expects a Regexp"
  end
end

#skip(skip_msg = nil) ⇒ Boolean

Sets the @skip instance variable to true and sets the @skip_msg instance variable if a String is provided. @skip is used to indicate that the formula should be skipped and the skip_msg very briefly describes why the formula is skipped (e.g., No longer developed or maintained).

Parameters:

  • skip_msg (String) (defaults to: nil)

    string describing why the formula is skipped

Returns:

  • (Boolean)

45
46
47
48
49
50
51
52
53
# File 'Library/Homebrew/livecheck.rb', line 45

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

  @skip = true
end

#skip?Boolean

Should livecheck skip this formula?

Returns:

  • (Boolean)

56
57
58
# File 'Library/Homebrew/livecheck.rb', line 56

def skip?
  @skip
end

#strategy(symbol = nil) ⇒ Symbol?

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 file name.

Parameters:

  • symbol (Symbol) (defaults to: nil)

    symbol for the desired strategy

Returns:


66
67
68
69
70
71
72
73
74
75
# File 'Library/Homebrew/livecheck.rb', line 66

def strategy(symbol = nil)
  case symbol
  when nil
    @strategy
  when Symbol
    @strategy = symbol
  else
    raise TypeError, "Livecheck#strategy expects a Symbol"
  end
end

#to_hashHash

Returns a Hash of all instance variable values.

Returns:

  • (Hash)

100
101
102
103
104
105
106
107
108
# File 'Library/Homebrew/livecheck.rb', line 100

def to_hash
  {
    "regex"    => @regex,
    "skip"     => @skip,
    "skip_msg" => @skip_msg,
    "strategy" => @strategy,
    "url"      => @url,
  }
end

#url(val = nil) ⇒ String?

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 (e.g., :stable, :homepage, or :head).

Parameters:

  • val (String, Symbol) (defaults to: nil)

    URL to check for version information

Returns:


83
84
85
86
87
88
89
90
91
92
93
94
95
96
# File 'Library/Homebrew/livecheck.rb', line 83

def url(val = nil)
  @url = case val
  when nil
    return @url
  when :head, :stable, :devel
    @formula.send(val).url
  when :homepage
    @formula.homepage
  when String
    val
  else
    raise TypeError, "Livecheck#url expects a String or valid Symbol"
  end
end