diff options
author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2011-11-24 17:41:02 +0000 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2011-11-24 22:11:45 +0000 |
commit | b62a7559a31fa1241954746ed67af575d8bd6ca5 (patch) | |
tree | 7e30f05b51575deba4c715e7747fa82d1043ce84 /bitbake | |
parent | 437928dfa4fdcf6abe4b4eb9ca03fd7db31404a0 (diff) | |
download | poky-b62a7559a31fa1241954746ed67af575d8bd6ca5.tar.gz |
data/siggen: Add vardepvalue mechanism to allow the variable dependency code to be forced to specific values
We have a problem if we want to inject specific information into the variable
dependency code. There are cases for example where we want a dependency
on the value of X but it doesn't matter how X was constructed or what
dependencies it might have had, we only care about the absolute value.
With the current code, its near enough impossible to do this.
This patch adds such a mechanism so the user can trigger this with code like:
baselib[vardepvalue] = "${baselib}"
It also refactors some of the code so we do variable lookups once
instead of doing this in two different functions.
[YOCTO #1583]
(Bitbake rev: 6c879b44ccf42dc73fe4467076e114700d7ba81b)
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake')
-rw-r--r-- | bitbake/lib/bb/data.py | 23 | ||||
-rw-r--r-- | bitbake/lib/bb/siggen.py | 3 |
2 files changed, 15 insertions, 11 deletions
diff --git a/bitbake/lib/bb/data.py b/bitbake/lib/bb/data.py index 10188f3807..7c1533cfa9 100644 --- a/bitbake/lib/bb/data.py +++ b/bitbake/lib/bb/data.py | |||
@@ -275,18 +275,21 @@ def update_data(d): | |||
275 | """Performs final steps upon the datastore, including application of overrides""" | 275 | """Performs final steps upon the datastore, including application of overrides""" |
276 | d.finalize() | 276 | d.finalize() |
277 | 277 | ||
278 | def build_dependencies(key, keys, shelldeps, d): | 278 | def build_dependencies(key, keys, shelldeps, vardepvals, d): |
279 | deps = set() | 279 | deps = set() |
280 | vardeps = d.getVarFlag(key, "vardeps", True) | 280 | vardeps = d.getVarFlag(key, "vardeps", True) |
281 | try: | 281 | try: |
282 | if d.getVarFlag(key, "func"): | 282 | value = d.getVar(key, False) |
283 | if key in vardepvals: | ||
284 | value = d.getVarFlag(key, "vardepvalue", True) | ||
285 | elif d.getVarFlag(key, "func"): | ||
283 | if d.getVarFlag(key, "python"): | 286 | if d.getVarFlag(key, "python"): |
284 | parsedvar = d.expandWithRefs(d.getVar(key, False), key) | 287 | parsedvar = d.expandWithRefs(value, key) |
285 | parser = bb.codeparser.PythonParser(key, logger) | 288 | parser = bb.codeparser.PythonParser(key, logger) |
286 | parser.parse_python(parsedvar.value) | 289 | parser.parse_python(parsedvar.value) |
287 | deps = deps | parser.references | 290 | deps = deps | parser.references |
288 | else: | 291 | else: |
289 | parsedvar = d.expandWithRefs(d.getVar(key, False), key) | 292 | parsedvar = d.expandWithRefs(value, key) |
290 | parser = bb.codeparser.ShellParser(key, logger) | 293 | parser = bb.codeparser.ShellParser(key, logger) |
291 | parser.parse_shell(parsedvar.value) | 294 | parser.parse_shell(parsedvar.value) |
292 | deps = deps | shelldeps | 295 | deps = deps | shelldeps |
@@ -295,7 +298,7 @@ def build_dependencies(key, keys, shelldeps, d): | |||
295 | deps = deps | parsedvar.references | 298 | deps = deps | parsedvar.references |
296 | deps = deps | (keys & parser.execs) | (keys & parsedvar.execs) | 299 | deps = deps | (keys & parser.execs) | (keys & parsedvar.execs) |
297 | else: | 300 | else: |
298 | parser = d.expandWithRefs(d.getVar(key, False), key) | 301 | parser = d.expandWithRefs(value, key) |
299 | deps |= parser.references | 302 | deps |= parser.references |
300 | deps = deps | (keys & parser.execs) | 303 | deps = deps | (keys & parser.execs) |
301 | deps |= set((vardeps or "").split()) | 304 | deps |= set((vardeps or "").split()) |
@@ -303,7 +306,7 @@ def build_dependencies(key, keys, shelldeps, d): | |||
303 | except: | 306 | except: |
304 | bb.note("Error expanding variable %s" % key) | 307 | bb.note("Error expanding variable %s" % key) |
305 | raise | 308 | raise |
306 | return deps | 309 | return deps, value |
307 | #bb.note("Variable %s references %s and calls %s" % (key, str(deps), str(execs))) | 310 | #bb.note("Variable %s references %s and calls %s" % (key, str(deps), str(execs))) |
308 | #d.setVarFlag(key, "vardeps", deps) | 311 | #d.setVarFlag(key, "vardeps", deps) |
309 | 312 | ||
@@ -311,12 +314,14 @@ def generate_dependencies(d): | |||
311 | 314 | ||
312 | keys = set(key for key in d.keys() if not key.startswith("__")) | 315 | keys = set(key for key in d.keys() if not key.startswith("__")) |
313 | shelldeps = set(key for key in keys if d.getVarFlag(key, "export") and not d.getVarFlag(key, "unexport")) | 316 | shelldeps = set(key for key in keys if d.getVarFlag(key, "export") and not d.getVarFlag(key, "unexport")) |
317 | vardepvals = set(key for key in keys if d.getVarFlag(key, "vardepvalue")) | ||
314 | 318 | ||
315 | deps = {} | 319 | deps = {} |
320 | values = {} | ||
316 | 321 | ||
317 | tasklist = bb.data.getVar('__BBTASKS', d) or [] | 322 | tasklist = bb.data.getVar('__BBTASKS', d) or [] |
318 | for task in tasklist: | 323 | for task in tasklist: |
319 | deps[task] = build_dependencies(task, keys, shelldeps, d) | 324 | deps[task], values[task] = build_dependencies(task, keys, shelldeps, vardepvals, d) |
320 | newdeps = deps[task] | 325 | newdeps = deps[task] |
321 | seen = set() | 326 | seen = set() |
322 | while newdeps: | 327 | while newdeps: |
@@ -325,11 +330,11 @@ def generate_dependencies(d): | |||
325 | newdeps = set() | 330 | newdeps = set() |
326 | for dep in nextdeps: | 331 | for dep in nextdeps: |
327 | if dep not in deps: | 332 | if dep not in deps: |
328 | deps[dep] = build_dependencies(dep, keys, shelldeps, d) | 333 | deps[dep], values[dep] = build_dependencies(dep, keys, shelldeps, vardepvals, d) |
329 | newdeps |= deps[dep] | 334 | newdeps |= deps[dep] |
330 | newdeps -= seen | 335 | newdeps -= seen |
331 | #print "For %s: %s" % (task, str(taskdeps[task])) | 336 | #print "For %s: %s" % (task, str(taskdeps[task])) |
332 | return tasklist, deps | 337 | return tasklist, deps, values |
333 | 338 | ||
334 | def inherits_class(klass, d): | 339 | def inherits_class(klass, d): |
335 | val = getVar('__inherit_cache', d) or [] | 340 | val = getVar('__inherit_cache', d) or [] |
diff --git a/bitbake/lib/bb/siggen.py b/bitbake/lib/bb/siggen.py index 9231291b43..758074287d 100644 --- a/bitbake/lib/bb/siggen.py +++ b/bitbake/lib/bb/siggen.py | |||
@@ -72,11 +72,10 @@ class SignatureGeneratorBasic(SignatureGenerator): | |||
72 | 72 | ||
73 | def _build_data(self, fn, d): | 73 | def _build_data(self, fn, d): |
74 | 74 | ||
75 | tasklist, gendeps = bb.data.generate_dependencies(d) | 75 | tasklist, gendeps, lookupcache = bb.data.generate_dependencies(d) |
76 | 76 | ||
77 | taskdeps = {} | 77 | taskdeps = {} |
78 | basehash = {} | 78 | basehash = {} |
79 | lookupcache = {} | ||
80 | 79 | ||
81 | for task in tasklist: | 80 | for task in tasklist: |
82 | data = d.getVar(task, False) | 81 | data = d.getVar(task, False) |