Class: Homebrew::Livecheck::Strategy::Xorg
- Defined in:
- livecheck/strategy/xorg.rb
Overview
The Xorg strategy identifies versions of software at x.org by checking directory listing pages.
X.Org URLs take one of the following formats, among several others:
https://www.x.org/archive/individual/app/example-1.2.3.tar.bz2
https://www.x.org/archive/individual/font/example-1.2.3.tar.bz2
https://www.x.org/archive/individual/lib/libexample-1.2.3.tar.bz2
https://ftp.x.org/archive/individual/lib/libexample-1.2.3.tar.bz2
https://www.x.org/pub/individual/doc/example-1.2.3.tar.gz
https://xorg.freedesktop.org/archive/individual/util/example-1.2.3.tar.xz
The notable differences between URLs are as follows:
www.x.org
andftp.x.org
seem to be interchangeable (we preferwww.x.org
)./archive/
is the current top-level directory and/pub/
will redirect to the same URL using/archive/
instead. (The strategy handles this replacement to avoid the redirection.)- The
/individual/
directory contains a number of directories (e.g. app, data, doc, driver, font, lib, etc.) which contain a number of different archive files.
Since this strategy ends up checking the same directory listing pages for multiple formulae, we've included a simple method of page caching. This prevents livecheck from fetching the same page more than once and also dramatically speeds up these checks. Eventually we hope to implement a more sophisticated page cache that all strategies using PageMatch can use (allowing us to simplify this strategy accordingly).
The default regex identifies versions in archive files found in href
attributes.
Constant Summary collapse
- NICE_NAME =
"X.Org"
- MODULE_REGEX =
This constant is part of a private API. This constant may only be used in the Homebrew/brew repository. Third parties should avoid using this constant if possible, as it may be removed or changed without warning.
A
Regexp
used in determining if the strategy applies to the URL and also as part of extracting the module name from the URL basename. /(?<module_name>.+)-\d+/i
- FILENAME_REGEX =
This constant is part of a private API. This constant may only be used in the Homebrew/brew repository. Third parties should avoid using this constant if possible, as it may be removed or changed without warning.
A
Regexp
used to extract the module name from the URL basename. /^#{MODULE_REGEX.source.strip}/i
- URL_MATCH_REGEX =
This constant is part of a private API. This constant may only be used in the Homebrew/brew repository. Third parties should avoid using this constant if possible, as it may be removed or changed without warning.
The
Regexp
used to determine if the strategy applies to the URL. %r{ ^https?://(?:[^/]+?\.)* # Scheme and any leading subdomains (?:x\.org/(?:[^/]+/)*individual |freedesktop\.org/(?:archive|dist|software) |archive\.mesa3d\.org) /(?:[^/]+/)*#{MODULE_REGEX.source.strip} }ix
Class Method Summary collapse
-
.find_versions(url:, regex: nil, **unused, &block) ⇒ Hash{Symbol => T.untyped}
private
Generates a URL and regex (if one isn't provided) and checks the content at the URL for new versions (using the regex for matching).
-
.generate_input_values(url) ⇒ Hash{Symbol => T.untyped}
private
Extracts information from a provided URL and uses it to generate various input values used by the strategy to check for new versions.
-
.match?(url) ⇒ Boolean
private
Whether the strategy can be applied to the provided URL.
Class Method Details
.find_versions(url:, regex: nil, **unused, &block) ⇒ Hash{Symbol => T.untyped}
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
Generates a URL and regex (if one isn't provided) and checks the content at the URL for new versions (using the regex for matching).
The behavior in this method for matching text in the content using a regex is copied and modified from the PageMatch strategy, so that we can add some simple page caching. If this behavior is expanded to apply to all strategies that use PageMatch to identify versions, then this strategy can be brought in line with the others.
121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 |
# File 'livecheck/strategy/xorg.rb', line 121 def self.find_versions(url:, regex: nil, **unused, &block) generated = generate_input_values(url) generated_url = generated[:url] # Use the cached page content to avoid duplicate fetches cached_content = @page_data[generated_url] match_data = PageMatch.find_versions( url: generated_url, regex: regex || generated[:regex], provided_content: cached_content, **unused, &block ) # Cache any new page content @page_data[generated_url] = match_data[:content] if match_data[:content].present? match_data end |
.generate_input_values(url) ⇒ Hash{Symbol => T.untyped}
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
Extracts information from a provided URL and uses it to generate
various input values used by the strategy to check for new versions.
Some of these values act as defaults and can be overridden in a
livecheck
block.
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 |
# File 'livecheck/strategy/xorg.rb', line 81 def self.generate_input_values(url) values = {} file_name = File.basename(url) match = file_name.match(FILENAME_REGEX) return values if match.blank? # /pub/ URLs redirect to the same URL with /archive/, so we replace # it to avoid the redirection. Removing the filename from the end of # the URL gives us the relevant directory listing page. values[:url] = url.sub("x.org/pub/", "x.org/archive/").delete_suffix(file_name) regex_name = Regexp.escape(T.must(match[:module_name])).gsub("\\-", "-") # Example regex: `/href=.*?example[._-]v?(\d+(?:\.\d+)+)\.t/i` values[:regex] = /href=.*?#{regex_name}[._-]v?(\d+(?:\.\d+)+)\.t/i values end |
.match?(url) ⇒ Boolean
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
Whether the strategy can be applied to the provided URL.
69 70 71 |
# File 'livecheck/strategy/xorg.rb', line 69 def self.match?(url) URL_MATCH_REGEX.match?(url) end |