diff options
author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-02-14 21:38:17 +0000 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-02-15 12:02:01 +0000 |
commit | 59921ce3ed7a4c0b7f8ef1a101ad9127469bf1fd (patch) | |
tree | 1a405afd7d08177709cc8c4b530c66c0949578a7 /lib | |
parent | 966e3e59ceb1c8b33b5881f291c148ea6513eda0 (diff) | |
download | bitbake-59921ce3ed7a4c0b7f8ef1a101ad9127469bf1fd.tar.gz |
fetch2: Improve lock/done stamp file paths for local files
Currently stamps end up at the top level of DL_DIR even if the files
themselves are in a directory structure. This patch preserves path
components allowing the top level directory to be less populated
which is an advantage for large sstate caches.
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/bb/fetch2/__init__.py | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/lib/bb/fetch2/__init__.py b/lib/bb/fetch2/__init__.py index 3f5de990d..90c894f60 100644 --- a/lib/bb/fetch2/__init__.py +++ b/lib/bb/fetch2/__init__.py @@ -756,6 +756,7 @@ class FetchData(object): self.lockfile = None self.mirrortarball = None self.basename = None + self.basepath = None (self.type, self.host, self.path, self.user, self.pswd, self.parm) = decodeurl(data.expand(url, d)) self.date = self.getSRCDate(d) self.url = url @@ -812,8 +813,14 @@ class FetchData(object): elif self.localfile: self.localpath = self.method.localpath(self.url, self, d) - # Note: These files should always be in DL_DIR whereas localpath may not be. - basepath = d.expand("${DL_DIR}/%s" % os.path.basename(self.localpath or self.basename)) + dldir = d.getVar("DL_DIR", True) + # Note: .done and .lock files should always be in DL_DIR whereas localpath may not be. + if self.localpath and self.localpath.startswith(dldir): + basepath = self.localpath + elif self.localpath: + basepath = dldir + os.sep + os.path.basename(self.localpath) + else: + basepath = dldir + os.sep + (self.basepath or self.basename) self.donestamp = basepath + '.done' self.lockfile = basepath + '.lock' |