summaryrefslogtreecommitdiffstats
path: root/bitbake/lib
diff options
context:
space:
mode:
authorPaul Eggleton <paul.eggleton@linux.intel.com>2012-09-23 14:14:24 +0100
committerRichard Purdie <richard.purdie@linuxfoundation.org>2012-09-24 12:13:51 +0100
commit0bdde689f651a22a2ff925bcdd88755cde592b3d (patch)
tree294ece1da1ad6fe3977bf962b7b80ac6d43399a2 /bitbake/lib
parent1c2634c8d236a0eb1abc2fdc3ee5950ac7a2b345 (diff)
downloadpoky-0bdde689f651a22a2ff925bcdd88755cde592b3d.tar.gz
bitbake: lib/bb/runqueue.py: fix exceptions with -k and failed targets
If a target dependency is marked as failed and yet we are continuing on because -k has been specified, don't try to access the dependency's data in taskData.build_targets since it will have been removed. This fixes "IndexError: list index out of range" errors in this situation. Also, do not print the "unhandled exception" message when SystemExit is raised since we will have reported the actual error already in this case (e.g. when -k has been specified and some targets failed). Fixes [YOCTO #3133]. (Bitbake rev: 70eebc184eb1ab3678be87bed019b5beadecdc89) Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake/lib')
-rw-r--r--bitbake/lib/bb/runqueue.py4
1 files changed, 3 insertions, 1 deletions
diff --git a/bitbake/lib/bb/runqueue.py b/bitbake/lib/bb/runqueue.py
index bc2eb8772e..b90b7e7e4a 100644
--- a/bitbake/lib/bb/runqueue.py
+++ b/bitbake/lib/bb/runqueue.py
@@ -466,7 +466,7 @@ class RunQueueData:
466 # (makes sure sometask runs after targetname's someothertask) 466 # (makes sure sometask runs after targetname's someothertask)
467 idepends = taskData.tasks_idepends[task] 467 idepends = taskData.tasks_idepends[task]
468 for (depid, idependtask) in idepends: 468 for (depid, idependtask) in idepends:
469 if depid in taskData.build_targets: 469 if depid in taskData.build_targets and not depid in taskData.failed_deps:
470 # Won't be in build_targets if ASSUME_PROVIDED 470 # Won't be in build_targets if ASSUME_PROVIDED
471 depdata = taskData.build_targets[depid][0] 471 depdata = taskData.build_targets[depid][0]
472 if depdata is not None: 472 if depdata is not None:
@@ -932,6 +932,8 @@ class RunQueue:
932 return self._execute_runqueue() 932 return self._execute_runqueue()
933 except bb.runqueue.TaskFailure: 933 except bb.runqueue.TaskFailure:
934 raise 934 raise
935 except SystemExit:
936 raise
935 except: 937 except:
936 logger.error("An uncaught exception occured in runqueue, please see the failure below:") 938 logger.error("An uncaught exception occured in runqueue, please see the failure below:")
937 self.state = runQueueComplete 939 self.state = runQueueComplete