summaryrefslogtreecommitdiffstats
path: root/bitbake/lib
diff options
context:
space:
mode:
Diffstat (limited to 'bitbake/lib')
-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 04e2b33e12..96d895d6db 100644
--- a/bitbake/lib/bb/fetch2/wget.py
+++ b/bitbake/lib/bb/fetch2/wget.py
@@ -243,26 +243,21 @@ class Wget(FetchMethod):
243 def _check_latest_version(self, url, package, package_regex, current_version, ud, d): 243 def _check_latest_version(self, url, package, package_regex, current_version, ud, d):
244 """ 244 """
245 Return the latest version of a package inside a given directory path 245 Return the latest version of a package inside a given directory path
246 If error or no version, return None 246 If error or no version, return ""
247 """ 247 """
248 valid = 0 248 valid = 0
249 version = ('', '', '') 249 version = ['', '', '']
250 250
251 bb.debug(3, "VersionURL: %s" % (url)) 251 bb.debug(3, "VersionURL: %s" % (url))
252 soup = BeautifulSoup(self._fetch_index(url, ud, d)) 252 soup = BeautifulSoup(self._fetch_index(url, ud, d))
253 if not soup: 253 if not soup:
254 bb.debug(3, "*** %s NO SOUP" % (url)) 254 bb.debug(3, "*** %s NO SOUP" % (url))
255 return None 255 return ""
256 256
257 pn_regex = d.getVar('REGEX', True)
258 if pn_regex:
259 pn_regex = re.compile(pn_regex)
260 package_regex = pn_regex
261 bb.debug(3, "pn_regex = '%s'" % (pn_regex.pattern))
262
263 for line in soup.find_all('a', href=True): 257 for line in soup.find_all('a', href=True):
264 newver = None 258 bb.debug(3, "line = '%s'" % (str(line)))
265 bb.debug(3, "line = '%s'" % (line['href'])) 259 bb.debug(3, "line['href'] = '%s'" % (line['href']))
260
266 newver = self._parse_path(package_regex, line['href']) 261 newver = self._parse_path(package_regex, line['href'])
267 if not newver: 262 if not newver:
268 newver = self._parse_path(package_regex, str(line)) 263 newver = self._parse_path(package_regex, str(line))
@@ -279,12 +274,12 @@ class Wget(FetchMethod):
279 bb.debug(3, "*** %s -> UpstreamVersion = %s (CurrentVersion = %s)" % 274 bb.debug(3, "*** %s -> UpstreamVersion = %s (CurrentVersion = %s)" %
280 (package, version[1] or "N/A", current_version[1])) 275 (package, version[1] or "N/A", current_version[1]))
281 276
282 if valid and version: 277 if valid:
283 return re.sub('_', '.', version[1]) 278 return re.sub('_', '.', version[1])
284 279
285 return None 280 return ""
286 281
287 def _init_regexes(self, package): 282 def _init_regexes(self, package, ud, d):
288 """ 283 """
289 Match as many patterns as possible such as: 284 Match as many patterns as possible such as:
290 gnome-common-2.20.0.tar.gz (most common format) 285 gnome-common-2.20.0.tar.gz (most common format)
@@ -318,7 +313,7 @@ class Wget(FetchMethod):
318 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)" 313 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)"
319 314
320 # match name, version and archive type of a package 315 # match name, version and archive type of a package
321 self.package_regex_comp = re.compile("(?P<name>%s?)\.?v?(?P<pver>%s)(?P<arch>%s)?[\.\-](?P<type>%s$)" 316 package_regex_comp = re.compile("(?P<name>%s?)\.?v?(?P<pver>%s)(?P<arch>%s)?[\.\-](?P<type>%s$)"
322 % (pn_regex, pver_regex, parch_regex, psuffix_regex)) 317 % (pn_regex, pver_regex, parch_regex, psuffix_regex))
323 self.suffix_regex_comp = re.compile(psuffix_regex) 318 self.suffix_regex_comp = re.compile(psuffix_regex)
324 319
@@ -326,13 +321,18 @@ class Wget(FetchMethod):
326 # "5.7" in http://download.gnome.org/sources/${PN}/5.7/${PN}-${PV}.tar.gz 321 # "5.7" in http://download.gnome.org/sources/${PN}/5.7/${PN}-${PV}.tar.gz
327 self.dirver_regex_comp = re.compile("(?P<dirver>[^/]*(\d+\.)*\d+([\-_]r\d+)*)/") 322 self.dirver_regex_comp = re.compile("(?P<dirver>[^/]*(\d+\.)*\d+([\-_]r\d+)*)/")
328 323
329 # make custom regex for search in uri's 324 # compile regex, can be specific by package or generic regex
330 package_custom_regex_comp = None 325 pn_regex = d.getVar('REGEX', True)
331 version = self._parse_path(self.package_regex_comp, package) 326 if pn_regex:
332 if version: 327 package_custom_regex_comp = re.compile(pn_regex)
333 package_custom_regex_comp = re.compile( 328 else:
334 "(?P<name>%s)(?P<pver>%s)(?P<arch>%s)?[\.\-](?P<type>%s)$" % 329 version = self._parse_path(package_regex_comp, package)
335 (re.escape(version[0]), pver_regex, parch_regex, psuffix_regex)) 330 if version:
331 package_custom_regex_comp = re.compile(
332 "(?P<name>%s)(?P<pver>%s)(?P<arch>%s)?[\.\-](?P<type>%s)$" %
333 (re.escape(version[0]), pver_regex, parch_regex, psuffix_regex))
334 else:
335 package_custom_regex_comp = package_regex_comp
336 336
337 return package_custom_regex_comp 337 return package_custom_regex_comp
338 338
@@ -347,7 +347,7 @@ class Wget(FetchMethod):
347 newpath = regex_uri or ud.path 347 newpath = regex_uri or ud.path
348 pupver = "" 348 pupver = ""
349 349
350 package_custom_regex_comp = self._init_regexes(package) 350 package_regex = self._init_regexes(package, ud, d)
351 351
352 current_version = ('', d.getVar('PV', True), '') 352 current_version = ('', d.getVar('PV', True), '')
353 353
@@ -371,6 +371,5 @@ class Wget(FetchMethod):
371 else: 371 else:
372 newuri = newpath 372 newuri = newpath
373 373
374 return self._check_latest_version(newuri, package, 374 return self._check_latest_version(newuri, package, package_regex,
375 package_custom_regex_comp or package_regex_comp, 375 current_version, ud, d)
376 current_version, ud, d) or ""