summaryrefslogtreecommitdiff
path: root/meta
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2014-06-18 17:58:56 +0100
committerRichard Purdie <richard.purdie@linuxfoundation.org>2014-06-19 17:55:02 +0100
commit5ed9bb42abf93aa084dd23ca68cc996a94a51a10 (patch)
tree130362b33a7a0de4cff5bc98efddc0a5cefc156c /meta
parent72032f6dd6724663a3417b1d1b666d9a63fcbfdb (diff)
downloadopenembedded-core-5ed9bb42abf93aa084dd23ca68cc996a94a51a10.tar.gz
openembedded-core-5ed9bb42abf93aa084dd23ca68cc996a94a51a10.tar.bz2
openembedded-core-5ed9bb42abf93aa084dd23ca68cc996a94a51a10.zip
sstatesig: Add try/except around the stat calls
Its possible sstate symlinks to other sstate mirrors which then my get removed/cleaned. If we find invalid symlinks, skip over them rather than error with a backtrace. Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta')
-rw-r--r--meta/lib/oe/sstatesig.py10
1 files changed, 8 insertions, 2 deletions
diff --git a/meta/lib/oe/sstatesig.py b/meta/lib/oe/sstatesig.py
index acff2a0569..d58147f78f 100644
--- a/meta/lib/oe/sstatesig.py
+++ b/meta/lib/oe/sstatesig.py
@@ -125,7 +125,10 @@ def find_siginfo(pn, taskname, taskhashlist, d):
foundall = True
break
else:
- filedates[fullpath] = os.stat(fullpath).st_mtime
+ try:
+ filedates[fullpath] = os.stat(fullpath).st_mtime
+ except OSError:
+ continue
if not taskhashlist or (len(filedates) < 2 and not foundall):
# That didn't work, look in sstate-cache
@@ -156,7 +159,10 @@ def find_siginfo(pn, taskname, taskhashlist, d):
if taskhashlist:
hashfiles[hashval] = fullpath
else:
- filedates[fullpath] = os.stat(fullpath).st_mtime
+ try:
+ filedates[fullpath] = os.stat(fullpath).st_mtime
+ except:
+ continue
if taskhashlist:
return hashfiles