diff options
| -rw-r--r-- | bitbake/lib/bb/fetch2/__init__.py | 15 | ||||
| -rw-r--r-- | bitbake/lib/bb/fetch2/local.py | 13 |
2 files changed, 19 insertions, 9 deletions
diff --git a/bitbake/lib/bb/fetch2/__init__.py b/bitbake/lib/bb/fetch2/__init__.py index d6ad3bb99a..9fec705ad6 100644 --- a/bitbake/lib/bb/fetch2/__init__.py +++ b/bitbake/lib/bb/fetch2/__init__.py | |||
| @@ -525,6 +525,7 @@ class FetchData(object): | |||
| 525 | self.localpath = None | 525 | self.localpath = None |
| 526 | self.lockfile = None | 526 | self.lockfile = None |
| 527 | self.mirrortarball = None | 527 | self.mirrortarball = None |
| 528 | self.basename = None | ||
| 528 | (self.type, self.host, self.path, self.user, self.pswd, self.parm) = decodeurl(data.expand(url, d)) | 529 | (self.type, self.host, self.path, self.user, self.pswd, self.parm) = decodeurl(data.expand(url, d)) |
| 529 | self.date = self.getSRCDate(d) | 530 | self.date = self.getSRCDate(d) |
| 530 | self.url = url | 531 | self.url = url |
| @@ -573,11 +574,10 @@ class FetchData(object): | |||
| 573 | elif self.localfile: | 574 | elif self.localfile: |
| 574 | self.localpath = self.method.localpath(self.url, self, d) | 575 | self.localpath = self.method.localpath(self.url, self, d) |
| 575 | 576 | ||
| 576 | if self.localfile and self.localpath: | 577 | # Note: These files should always be in DL_DIR whereas localpath may not be. |
| 577 | # Note: These files should always be in DL_DIR whereas localpath may not be. | 578 | basepath = bb.data.expand("${DL_DIR}/%s" % os.path.basename(self.localpath or self.basename), d) |
| 578 | basepath = bb.data.expand("${DL_DIR}/%s" % os.path.basename(self.localpath), d) | 579 | self.donestamp = basepath + '.done' |
| 579 | self.donestamp = basepath + '.done' | 580 | self.lockfile = basepath + '.lock' |
| 580 | self.lockfile = basepath + '.lock' | ||
| 581 | 581 | ||
| 582 | def setup_localpath(self, d): | 582 | def setup_localpath(self, d): |
| 583 | if not self.localpath: | 583 | if not self.localpath: |
| @@ -913,9 +913,6 @@ class Fetch(object): | |||
| 913 | m = ud.method | 913 | m = ud.method |
| 914 | localpath = "" | 914 | localpath = "" |
| 915 | 915 | ||
| 916 | if not ud.localfile: | ||
| 917 | continue | ||
| 918 | |||
| 919 | lf = bb.utils.lockfile(ud.lockfile) | 916 | lf = bb.utils.lockfile(ud.lockfile) |
| 920 | 917 | ||
| 921 | try: | 918 | try: |
| @@ -951,7 +948,7 @@ class Fetch(object): | |||
| 951 | mirrors = mirror_from_string(bb.data.getVar('MIRRORS', self.d, True)) | 948 | mirrors = mirror_from_string(bb.data.getVar('MIRRORS', self.d, True)) |
| 952 | localpath = try_mirrors (self.d, ud, mirrors) | 949 | localpath = try_mirrors (self.d, ud, mirrors) |
| 953 | 950 | ||
| 954 | if not localpath or not os.path.exists(localpath): | 951 | if not localpath or ((not os.path.exists(localpath)) and localpath.find("*") == -1): |
| 955 | raise FetchError("Unable to fetch URL %s from any source." % u, u) | 952 | raise FetchError("Unable to fetch URL %s from any source." % u, u) |
| 956 | 953 | ||
| 957 | if os.path.exists(ud.donestamp): | 954 | if os.path.exists(ud.donestamp): |
diff --git a/bitbake/lib/bb/fetch2/local.py b/bitbake/lib/bb/fetch2/local.py index 77a296ec67..ed9a047d8d 100644 --- a/bitbake/lib/bb/fetch2/local.py +++ b/bitbake/lib/bb/fetch2/local.py | |||
| @@ -40,6 +40,7 @@ class Local(FetchMethod): | |||
| 40 | 40 | ||
| 41 | def urldata_init(self, ud, d): | 41 | def urldata_init(self, ud, d): |
| 42 | # We don't set localfile as for this fetcher the file is already local! | 42 | # We don't set localfile as for this fetcher the file is already local! |
| 43 | ud.basename = os.path.basename(ud.url.split("://")[1].split(";")[0]) | ||
| 43 | return | 44 | return |
| 44 | 45 | ||
| 45 | def localpath(self, url, urldata, d): | 46 | def localpath(self, url, urldata, d): |
| @@ -49,6 +50,9 @@ class Local(FetchMethod): | |||
| 49 | path = url.split("://")[1] | 50 | path = url.split("://")[1] |
| 50 | path = path.split(";")[0] | 51 | path = path.split(";")[0] |
| 51 | newpath = path | 52 | newpath = path |
| 53 | dldirfile = os.path.join(data.getVar("DL_DIR", d, True), os.path.basename(path)) | ||
| 54 | if os.path.exists(dldirfile): | ||
| 55 | return dldirfile | ||
| 52 | if path[0] != "/": | 56 | if path[0] != "/": |
| 53 | filespath = data.getVar('FILESPATH', d, True) | 57 | filespath = data.getVar('FILESPATH', d, True) |
| 54 | if filespath: | 58 | if filespath: |
| @@ -57,8 +61,17 @@ class Local(FetchMethod): | |||
| 57 | filesdir = data.getVar('FILESDIR', d, True) | 61 | filesdir = data.getVar('FILESDIR', d, True) |
| 58 | if filesdir: | 62 | if filesdir: |
| 59 | newpath = os.path.join(filesdir, path) | 63 | newpath = os.path.join(filesdir, path) |
| 64 | if not os.path.exists(newpath) and path.find("*") == -1: | ||
| 65 | return dldirfile | ||
| 60 | return newpath | 66 | return newpath |
| 61 | 67 | ||
| 68 | def need_update(self, url, ud, d): | ||
| 69 | if url.find("*") == -1: | ||
| 70 | return False | ||
| 71 | if os.path.exists(ud.localpath): | ||
| 72 | return False | ||
| 73 | return True | ||
| 74 | |||
| 62 | def download(self, url, urldata, d): | 75 | def download(self, url, urldata, d): |
| 63 | """Fetch urls (no-op for Local method)""" | 76 | """Fetch urls (no-op for Local method)""" |
| 64 | # no need to fetch local files, we'll deal with them in place. | 77 | # no need to fetch local files, we'll deal with them in place. |
