diff options
author | Christopher Larson <chris_larson@mentor.com> | 2015-08-03 12:20:43 -0700 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-09-03 12:33:08 +0100 |
commit | 383450c78a46060de9a483d4cce5955136dca807 (patch) | |
tree | aa439a580c052e3dec0fcda39ae0dbe7772d4dc1 /bitbake/lib/bb/build.py | |
parent | 71b0568fa43285f0946fae93fb43cea5f3bbecec (diff) | |
download | openembedded-core-contrib-383450c78a46060de9a483d4cce5955136dca807.tar.gz |
bitbake: build: delete tasks thoroughly
We want addtask to be able to bring back a deleted task, but we don't want its
previous dependencies to come back with it, so rather than marking a task as
deleted and then skipping tasks marked as such, actually delete the task and
its dependency information in deltask.
While we're in that part of the code, also fix a couple 'not foo in bar'
instances to 'foo not in bar', which is preferred in python.
(Bitbake rev: 94b3f3d6bdfbfa47f7eb3c3de64940a145b2ddd1)
Signed-off-by: Christopher Larson <chris_larson@mentor.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake/lib/bb/build.py')
-rw-r--r-- | bitbake/lib/bb/build.py | 23 |
1 files changed, 13 insertions, 10 deletions
diff --git a/bitbake/lib/bb/build.py b/bitbake/lib/bb/build.py index 764163f37f..948c3951f4 100644 --- a/bitbake/lib/bb/build.py +++ b/bitbake/lib/bb/build.py @@ -686,7 +686,7 @@ def stampfile(taskname, d, file_name = None): """ return stamp_internal(taskname, d, file_name) -def add_tasks(tasklist, deltasklist, d): +def add_tasks(tasklist, d): task_deps = d.getVar('_task_deps', False) if not task_deps: task_deps = {} @@ -698,9 +698,6 @@ def add_tasks(tasklist, deltasklist, d): for task in tasklist: task = d.expand(task) - if task in deltasklist: - continue - d.setVarFlag(task, 'task', 1) if not task in task_deps['tasks']: @@ -738,7 +735,7 @@ def addtask(task, before, after, d): d.setVarFlag(task, "task", 1) bbtasks = d.getVar('__BBTASKS', False) or [] - if not task in bbtasks: + if task not in bbtasks: bbtasks.append(task) d.setVar('__BBTASKS', bbtasks) @@ -760,8 +757,14 @@ def deltask(task, d): if task[:3] != "do_": task = "do_" + task - bbtasks = d.getVar('__BBDELTASKS', False) or [] - if not task in bbtasks: - bbtasks.append(task) - d.setVar('__BBDELTASKS', bbtasks) - + bbtasks = d.getVar('__BBTASKS', False) or [] + if task in bbtasks: + bbtasks.remove(task) + d.setVar('__BBTASKS', bbtasks) + + d.delVarFlag(task, 'deps') + for bbtask in d.getVar('__BBTASKS', False) or []: + deps = d.getVarFlag(bbtask, 'deps') or [] + if task in deps: + deps.remove(task) + d.setVarFlag(bbtask, 'deps', deps) |