diff options
author | Richard Purdie <rpurdie@linux.intel.com> | 2009-05-11 22:34:07 +0100 |
---|---|---|
committer | Richard Purdie <rpurdie@linux.intel.com> | 2009-05-11 22:34:07 +0100 |
commit | 1ca980646deb13b2cf85b17e78de9faba0191dbf (patch) | |
tree | e7b1548cbf0ea8645b108ac13c48b772ed5a3f47 /bitbake/lib/bb/fetch | |
parent | 62d37206681c3049c5ee7590cb9bce59e782ed15 (diff) | |
download | poky-1ca980646deb13b2cf85b17e78de9faba0191dbf.tar.gz |
bitbake: Sync git fetcher with changes upstream
Signed-off-by: Richard Purdie <rpurdie@linux.intel.com>
Diffstat (limited to 'bitbake/lib/bb/fetch')
-rw-r--r-- | bitbake/lib/bb/fetch/git.py | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/bitbake/lib/bb/fetch/git.py b/bitbake/lib/bb/fetch/git.py index 010a4f57a2..4cae1c1879 100644 --- a/bitbake/lib/bb/fetch/git.py +++ b/bitbake/lib/bb/fetch/git.py | |||
@@ -37,9 +37,12 @@ class Git(Fetch): | |||
37 | 37 | ||
38 | def localpath(self, url, ud, d): | 38 | def localpath(self, url, ud, d): |
39 | 39 | ||
40 | ud.proto = "rsync" | ||
41 | if 'protocol' in ud.parm: | 40 | if 'protocol' in ud.parm: |
42 | ud.proto = ud.parm['protocol'] | 41 | ud.proto = ud.parm['protocol'] |
42 | elif not ud.host: | ||
43 | ud.proto = 'file' | ||
44 | else: | ||
45 | ud.proto = "rsync" | ||
43 | 46 | ||
44 | ud.branch = ud.parm.get("branch", "master") | 47 | ud.branch = ud.parm.get("branch", "master") |
45 | 48 | ||
@@ -49,12 +52,9 @@ class Git(Fetch): | |||
49 | elif tag: | 52 | elif tag: |
50 | ud.tag = tag | 53 | ud.tag = tag |
51 | 54 | ||
52 | if not ud.tag: | 55 | if not ud.tag or ud.tag == "master": |
53 | ud.tag = self.latest_revision(url, ud, d) | 56 | ud.tag = self.latest_revision(url, ud, d) |
54 | 57 | ||
55 | if ud.tag == "master": | ||
56 | ud.tag = self.latest_revision(url, ud, d) | ||
57 | |||
58 | ud.localfile = data.expand('git_%s%s_%s.tar.gz' % (ud.host, ud.path.replace('/', '.'), ud.tag), d) | 58 | ud.localfile = data.expand('git_%s%s_%s.tar.gz' % (ud.host, ud.path.replace('/', '.'), ud.tag), d) |
59 | 59 | ||
60 | return os.path.join(data.getVar("DL_DIR", d, True), ud.localfile) | 60 | return os.path.join(data.getVar("DL_DIR", d, True), ud.localfile) |
@@ -90,11 +90,12 @@ class Git(Fetch): | |||
90 | 90 | ||
91 | os.chdir(repodir) | 91 | os.chdir(repodir) |
92 | # Remove all but the .git directory | 92 | # Remove all but the .git directory |
93 | runfetchcmd("rm * -Rf", d) | 93 | if not self._contains_ref(ud.tag, d): |
94 | runfetchcmd("git fetch %s://%s%s%s %s" % (ud.proto, username, ud.host, ud.path, ud.branch), d) | 94 | runfetchcmd("rm * -Rf", d) |
95 | runfetchcmd("git fetch --tags %s://%s%s%s" % (ud.proto, username, ud.host, ud.path), d) | 95 | runfetchcmd("git fetch %s://%s%s%s %s" % (ud.proto, username, ud.host, ud.path, ud.branch), d) |
96 | runfetchcmd("git prune-packed", d) | 96 | runfetchcmd("git fetch --tags %s://%s%s%s" % (ud.proto, username, ud.host, ud.path), d) |
97 | runfetchcmd("git pack-redundant --all | xargs -r rm", d) | 97 | runfetchcmd("git prune-packed", d) |
98 | runfetchcmd("git pack-redundant --all | xargs -r rm", d) | ||
98 | 99 | ||
99 | os.chdir(repodir) | 100 | os.chdir(repodir) |
100 | mirror_tarballs = data.getVar("BB_GENERATE_MIRROR_TARBALLS", d, True) | 101 | mirror_tarballs = data.getVar("BB_GENERATE_MIRROR_TARBALLS", d, True) |
@@ -120,6 +121,10 @@ class Git(Fetch): | |||
120 | def suppports_srcrev(self): | 121 | def suppports_srcrev(self): |
121 | return True | 122 | return True |
122 | 123 | ||
124 | def _contains_ref(self, tag, d): | ||
125 | output = runfetchcmd("git log --pretty=oneline -n 1 %s -- 2> /dev/null | wc -l" % tag, d, quiet=True) | ||
126 | return output.split()[0] != "0" | ||
127 | |||
123 | def _revision_key(self, url, ud, d): | 128 | def _revision_key(self, url, ud, d): |
124 | """ | 129 | """ |
125 | Return a unique key for the url | 130 | Return a unique key for the url |