From a30c335b887d58b022838bf0724f4c244cdd845b Mon Sep 17 00:00:00 2001 From: Paul Eggleton Date: Tue, 4 Jun 2013 09:59:37 +0100 Subject: [PATCH] lib/bb/cache.py: invalidate cache when file checksum entry no longer exists Go through the cached list of file checksums and check if any of the files no longer exist; if any are missing then invalidate the cached recipe, which will force it to be reparsed and thus force the list of files to be collected again. This prevents a warning when moving a file to a different location that is still picked up by the recipe, e.g. moving a file from a "files" subdirectory to one named with the recipe name (${BPN}). Fixes [YOCTO #4474]. Signed-off-by: Paul Eggleton Signed-off-by: Richard Purdie --- lib/bb/cache.py | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/lib/bb/cache.py b/lib/bb/cache.py index 9e89742235e..eee83b7d09c 100644 --- a/lib/bb/cache.py +++ b/lib/bb/cache.py @@ -524,6 +524,15 @@ class Cache(object): self.remove(fn) return False + if hasattr(info_array[0], 'file_checksums'): + for _, fl in info_array[0].file_checksums.items(): + for f in fl.split(): + if not os.path.exists(f): + logger.debug(2, "Cache: %s's file checksum list file %s was removed", + fn, f) + self.remove(fn) + return False + if appends != info_array[0].appends: logger.debug(2, "Cache: appends for %s changed", fn) logger.debug(2, "%s to %s" % (str(appends), str(info_array[0].appends))) -- 2.47.3