diff options
author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2022-08-10 14:34:22 +0100 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2022-08-12 11:49:29 +0100 |
commit | 7bd328f9d24b4fb23c7d5de50bddbb60828c9ffc (patch) | |
tree | 243a5d896a1b005deb35bd5d7bb167b86d0cdd23 /bitbake/lib/bb/parse/parse_py | |
parent | e19ce4191d94646e35386a5f2179c02ef8dc1cb6 (diff) | |
download | poky-7bd328f9d24b4fb23c7d5de50bddbb60828c9ffc.tar.gz |
bitbake: BBHandler/cooker: Implement recipe and global classes
We have some confusion for users since some classes are meant to work
in the configuration space (or "globally") and some are meant to be
selected by recipes individually.
The cleanest way I could find to clarify this is to create "classes-global"
and "classes-recipe" directories which contain the approproate classes and
have bitbake switch scope between them at the appropriate point during
parsing. The existing "classes" directory is always searched as a fallback.
Once a class is moved to a specific directory, it will no longer be found
in the incorrect context. A good example from OE is that
INHERIT += "testimage"
will no longer work but
IMAGE_CLASSES += "testimage"
will, which makes the global scope cleaner by only including it where it
is useful and intended to be used (images).
(Bitbake rev: f33ce7e742f46635658c400b82558cf822690b5e)
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake/lib/bb/parse/parse_py')
-rw-r--r-- | bitbake/lib/bb/parse/parse_py/BBHandler.py | 29 |
1 files changed, 18 insertions, 11 deletions
diff --git a/bitbake/lib/bb/parse/parse_py/BBHandler.py b/bitbake/lib/bb/parse/parse_py/BBHandler.py index 1189114341..18e6868387 100644 --- a/bitbake/lib/bb/parse/parse_py/BBHandler.py +++ b/bitbake/lib/bb/parse/parse_py/BBHandler.py | |||
@@ -44,17 +44,24 @@ def inherit(files, fn, lineno, d): | |||
44 | __inherit_cache = d.getVar('__inherit_cache', False) or [] | 44 | __inherit_cache = d.getVar('__inherit_cache', False) or [] |
45 | files = d.expand(files).split() | 45 | files = d.expand(files).split() |
46 | for file in files: | 46 | for file in files: |
47 | if not os.path.isabs(file) and not file.endswith(".bbclass"): | 47 | classtype = d.getVar("__bbclasstype", False) |
48 | file = os.path.join('classes', '%s.bbclass' % file) | 48 | origfile = file |
49 | 49 | for t in ["classes-" + classtype, "classes"]: | |
50 | if not os.path.isabs(file): | 50 | file = origfile |
51 | bbpath = d.getVar("BBPATH") | 51 | if not os.path.isabs(file) and not file.endswith(".bbclass"): |
52 | abs_fn, attempts = bb.utils.which(bbpath, file, history=True) | 52 | file = os.path.join(t, '%s.bbclass' % file) |
53 | for af in attempts: | 53 | |
54 | if af != abs_fn: | 54 | if not os.path.isabs(file): |
55 | bb.parse.mark_dependency(d, af) | 55 | bbpath = d.getVar("BBPATH") |
56 | if abs_fn: | 56 | abs_fn, attempts = bb.utils.which(bbpath, file, history=True) |
57 | file = abs_fn | 57 | for af in attempts: |
58 | if af != abs_fn: | ||
59 | bb.parse.mark_dependency(d, af) | ||
60 | if abs_fn: | ||
61 | file = abs_fn | ||
62 | |||
63 | if os.path.exists(file): | ||
64 | break | ||
58 | 65 | ||
59 | if not os.path.exists(file): | 66 | if not os.path.exists(file): |
60 | raise ParseError("Could not inherit file %s" % (file), fn, lineno) | 67 | raise ParseError("Could not inherit file %s" % (file), fn, lineno) |