summaryrefslogtreecommitdiffstats
path: root/bitbake
diff options
context:
space:
mode:
authorAníbal Limón <anibal.limon@linux.intel.com>2015-02-13 15:58:09 -0600
committerRichard Purdie <richard.purdie@linuxfoundation.org>2015-02-16 09:13:05 +0000
commit309d92efde484eb8747d40cd32330f5775fd9284 (patch)
tree958b2b0ecee2e8359a64758dd4bbb2cfde163d9a /bitbake
parentbed1b3f47ee1aeb93f38f2f48eca0573cb13581a (diff)
downloadast2050-yocto-poky-309d92efde484eb8747d40cd32330f5775fd9284.zip
ast2050-yocto-poky-309d92efde484eb8747d40cd32330f5775fd9284.tar.gz
bitbake: fetch2: wget latest_versionstring _check_latest_version improvments
In order to reduce code duplication now compile package_regex in _init_regexes instead of make this decision at _check_latest_version, (Bitbake rev: e7284e3ad0e7dd91ed59dfbf8450ef62e89c7e54) Signed-off-by: Aníbal Limón <anibal.limon@linux.intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake')
-rw-r--r--bitbake/lib/bb/fetch2/wget.py51
1 files changed, 25 insertions, 26 deletions
diff --git a/bitbake/lib/bb/fetch2/wget.py b/bitbake/lib/bb/fetch2/wget.py
index 04e2b33..96d895d 100644
--- a/bitbake/lib/bb/fetch2/wget.py
+++ b/bitbake/lib/bb/fetch2/wget.py
@@ -243,26 +243,21 @@ class Wget(FetchMethod):
def _check_latest_version(self, url, package, package_regex, current_version, ud, d):
"""
Return the latest version of a package inside a given directory path
- If error or no version, return None
+ If error or no version, return ""
"""
valid = 0
- version = ('', '', '')
+ version = ['', '', '']
bb.debug(3, "VersionURL: %s" % (url))
soup = BeautifulSoup(self._fetch_index(url, ud, d))
if not soup:
bb.debug(3, "*** %s NO SOUP" % (url))
- return None
+ return ""
- pn_regex = d.getVar('REGEX', True)
- if pn_regex:
- pn_regex = re.compile(pn_regex)
- package_regex = pn_regex
- bb.debug(3, "pn_regex = '%s'" % (pn_regex.pattern))
-
for line in soup.find_all('a', href=True):
- newver = None
- bb.debug(3, "line = '%s'" % (line['href']))
+ bb.debug(3, "line = '%s'" % (str(line)))
+ bb.debug(3, "line['href'] = '%s'" % (line['href']))
+
newver = self._parse_path(package_regex, line['href'])
if not newver:
newver = self._parse_path(package_regex, str(line))
@@ -279,12 +274,12 @@ class Wget(FetchMethod):
bb.debug(3, "*** %s -> UpstreamVersion = %s (CurrentVersion = %s)" %
(package, version[1] or "N/A", current_version[1]))
- if valid and version:
+ if valid:
return re.sub('_', '.', version[1])
- return None
+ return ""
- def _init_regexes(self, package):
+ def _init_regexes(self, package, ud, d):
"""
Match as many patterns as possible such as:
gnome-common-2.20.0.tar.gz (most common format)
@@ -318,7 +313,7 @@ class Wget(FetchMethod):
psuffix_regex = "(tar\.gz|tgz|tar\.bz2|zip|xz|rpm|bz2|orig\.tar\.gz|tar\.xz|src\.tar\.gz|src\.tgz|svnr\d+\.tar\.bz2|stable\.tar\.gz|src\.rpm)"
# match name, version and archive type of a package
- self.package_regex_comp = re.compile("(?P<name>%s?)\.?v?(?P<pver>%s)(?P<arch>%s)?[\.\-](?P<type>%s$)"
+ package_regex_comp = re.compile("(?P<name>%s?)\.?v?(?P<pver>%s)(?P<arch>%s)?[\.\-](?P<type>%s$)"
% (pn_regex, pver_regex, parch_regex, psuffix_regex))
self.suffix_regex_comp = re.compile(psuffix_regex)
@@ -326,13 +321,18 @@ class Wget(FetchMethod):
# "5.7" in http://download.gnome.org/sources/${PN}/5.7/${PN}-${PV}.tar.gz
self.dirver_regex_comp = re.compile("(?P<dirver>[^/]*(\d+\.)*\d+([\-_]r\d+)*)/")
- # make custom regex for search in uri's
- package_custom_regex_comp = None
- version = self._parse_path(self.package_regex_comp, package)
- if version:
- package_custom_regex_comp = re.compile(
- "(?P<name>%s)(?P<pver>%s)(?P<arch>%s)?[\.\-](?P<type>%s)$" %
- (re.escape(version[0]), pver_regex, parch_regex, psuffix_regex))
+ # compile regex, can be specific by package or generic regex
+ pn_regex = d.getVar('REGEX', True)
+ if pn_regex:
+ package_custom_regex_comp = re.compile(pn_regex)
+ else:
+ version = self._parse_path(package_regex_comp, package)
+ if version:
+ package_custom_regex_comp = re.compile(
+ "(?P<name>%s)(?P<pver>%s)(?P<arch>%s)?[\.\-](?P<type>%s)$" %
+ (re.escape(version[0]), pver_regex, parch_regex, psuffix_regex))
+ else:
+ package_custom_regex_comp = package_regex_comp
return package_custom_regex_comp
@@ -347,7 +347,7 @@ class Wget(FetchMethod):
newpath = regex_uri or ud.path
pupver = ""
- package_custom_regex_comp = self._init_regexes(package)
+ package_regex = self._init_regexes(package, ud, d)
current_version = ('', d.getVar('PV', True), '')
@@ -371,6 +371,5 @@ class Wget(FetchMethod):
else:
newuri = newpath
- return self._check_latest_version(newuri, package,
- package_custom_regex_comp or package_regex_comp,
- current_version, ud, d) or ""
+ return self._check_latest_version(newuri, package, package_regex,
+ current_version, ud, d)
OpenPOWER on IntegriCloud