diff options
author | Paul Eggleton <paul.eggleton@linux.intel.com> | 2010-12-16 16:25:13 +0000 |
---|---|---|
committer | Richard Purdie <rpurdie@linux.intel.com> | 2010-12-20 14:54:02 +0000 |
commit | 1993ca1f8790ff5bddc347ff22c78fd1c618739a (patch) | |
tree | fbe75d51a3e582e57069f305ff8518adab4d1aa2 /meta | |
parent | 2ec7757a48f298232bf9918a55b46503d5d21025 (diff) | |
download | openembedded-core-1993ca1f8790ff5bddc347ff22c78fd1c618739a.tar.gz openembedded-core-1993ca1f8790ff5bddc347ff22c78fd1c618739a.tar.bz2 openembedded-core-1993ca1f8790ff5bddc347ff22c78fd1c618739a.zip |
sanity.bbclass: allow minimisation of impact of more invasive sanity checks
Add a mechanism to avoid running more invasive checks every time bitbake is
invoked. Adds a file in conf/ (i.e. under user's build directory) that
tracks a new variable SANITY_VERSION (set in sanity.conf) as well as TMPDIR
and SSTATE_DIR, allowing checks to be run when these are changed.
Fixes [BUGID #562]
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
Diffstat (limited to 'meta')
-rw-r--r-- | meta/classes/sanity.bbclass | 48 | ||||
-rw-r--r-- | meta/conf/sanity.conf | 1 |
2 files changed, 48 insertions, 1 deletions
diff --git a/meta/classes/sanity.bbclass b/meta/classes/sanity.bbclass index 6dc4716af4..969cc2e59b 100644 --- a/meta/classes/sanity.bbclass +++ b/meta/classes/sanity.bbclass @@ -21,6 +21,18 @@ def check_conf_exists(fn, data): return True return False +def check_sanity_sstate_dir_change(): + # Sanity checks to be done when the value of SSTATE_DIR changes + return "" + +def check_sanity_tmpdir_change(): + # Sanity checks to be done when the value of TMPDIR changes + return "" + +def check_sanity_version_change(): + # Sanity checks to be done when SANITY_VERSION changes + return "" + def check_sanity(e): from bb import note, error, data, __version__ @@ -173,10 +185,44 @@ def check_sanity(e): if os.path.exists('%s/libc.so.6' % lib32path) and not os.path.exists('/usr/include/gnu/stubs-32.h'): messages = messages + "You have a 32-bit libc, but no 32-bit headers. You must install the 32-bit libc headers.\n" + tmpdir = data.getVar('TMPDIR', e.data, True) + sstate_dir = data.getVar('SSTATE_DIR', e.data, True) + + # Check saved sanity info + last_sanity_version = 0 + last_tmpdir = "" + last_sstate_dir = "" + sanityverfile = 'conf/sanity_info' + if os.path.exists(sanityverfile): + f = file(sanityverfile, 'r') + for line in f: + if line.startswith('SANITY_VERSION'): + last_sanity_version = int(line.split()[1]) + if line.startswith('TMPDIR'): + last_tmpdir = line.split()[1] + if line.startswith('SSTATE_DIR'): + last_sstate_dir = line.split()[1] + + sanity_version = int(data.getVar('SANITY_VERSION', e.data, True) or 1) + if last_sanity_version < sanity_version: + messages = messages + check_sanity_version_change() + messages = messages + check_sanity_tmpdir_change() + messages = messages + check_sanity_sstate_dir_change() + else: + if last_tmpdir != tmpdir: + messages = messages + check_sanity_tmpdir_change() + if last_sstate_dir != sstate_dir: + messages = messages + check_sanity_sstate_dir_change() + + if os.path.exists("conf"): + f = file(sanityverfile, 'w') + f.write("SANITY_VERSION %s\n" % sanity_version) + f.write("TMPDIR %s\n" % tmpdir) + f.write("SSTATE_DIR %s\n" % sstate_dir) + # # Check that TMPDIR hasn't changed location since the last time we were run # - tmpdir = data.getVar('TMPDIR', e.data, True) checkfile = os.path.join(tmpdir, "saved_tmpdir") if os.path.exists(checkfile): f = file(checkfile, "r") diff --git a/meta/conf/sanity.conf b/meta/conf/sanity.conf index eab7619022..1fbeb61aad 100644 --- a/meta/conf/sanity.conf +++ b/meta/conf/sanity.conf @@ -7,6 +7,7 @@ BB_MIN_VERSION = "1.8.10" SANITY_ABIFILE = "${TMPDIR}/abi_version" +SANITY_VERSION = "1" POKY_CONF_VERSION = "1" LAYER_CONF_VERSION = "3" SITE_CONF_VERSION = "1" |