diff options
Diffstat (limited to 'lib/bb/fetch2/git.py')
-rw-r--r-- | lib/bb/fetch2/git.py | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/lib/bb/fetch2/git.py b/lib/bb/fetch2/git.py index 706fff569..374d84679 100644 --- a/lib/bb/fetch2/git.py +++ b/lib/bb/fetch2/git.py @@ -371,25 +371,28 @@ class Git(FetchMethod): by searching through the tags output of ls-remote, comparing versions and returning the highest match. """ - verstring = "" + pupver = ('', '') + tagregex = re.compile(d.getVar('GITTAGREGEX', True) or "(?P<pver>([0-9][\.|_]?)+)") try: output = self._lsremote(ud, d, "refs/tags/*") except bb.fetch2.FetchError or bb.fetch2.NetworkAccess: - return "" + return pupver + verstring = "" + revision = "" for line in output.split("\n"): if not line: break - line = line.split("/")[-1] + tag_head = line.split("/")[-1] # Ignore non-released branches - m = re.search("(alpha|beta|rc|final)+", line) + m = re.search("(alpha|beta|rc|final)+", tag_head) if m: continue # search for version in the line - tag = tagregex.search(line) + tag = tagregex.search(tag_head) if tag == None: continue @@ -398,9 +401,12 @@ class Git(FetchMethod): if verstring and bb.utils.vercmp(("0", tag, ""), ("0", verstring, "")) < 0: continue + verstring = tag + revision = line.split()[0] + pupver = (verstring, revision) - return verstring + return pupver def _build_revision(self, ud, d, name): return ud.revisions[name] |