diff options
author | Patrick Ohly <patrick.ohly@intel.com> | 2016-05-12 17:00:10 +0200 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2016-05-14 23:05:14 +0100 |
commit | da467519c2624496ad8f939bf494e8f9aff4d9e3 (patch) | |
tree | 3141ac13ac7a2ca618e451c983621c66951b484f /bitbake | |
parent | ff5d6f8854264914d28b8b0d45c017b17a6ef185 (diff) | |
download | poky-da467519c2624496ad8f939bf494e8f9aff4d9e3.tar.gz |
bitbake: runqueue.py: always emit bb.event.DepTreeGenerated
The data included in the event is useful for implementing a pre-build
check that warns about unexpected components, for example because of
an incorrect configuration or changed dependencies.
Such a check can be done in a .bbclass that gets inherited
globally. But in contrast to a UI, such a class cannot request that
the event shall be emitted, and thus the event has to be emitted
whether there is a consumer or not.
This was done conditionally earlier out of concerns about the
performance impact. But now events are handled more efficiently, so
that concern no longer seems valid: in some simple testing (admittedly
on a fast build workstation), the two lines (generating the data and
emitting the event with it) only took about 0.05 seconds (measured
with timeit). That was for a build with roughly 500 recipes (from
pn-buildlist aka depgraph['pn']), triggered via the command line. That
was even with a consumer of the data active and doing some work, so it
should be even faster when there is no consumer.
(Bitbake rev: 5ddaf5b7ed1001d2dd3f67e7a6d704afa85479d2)
Signed-off-by: Patrick Ohly <patrick.ohly@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake')
-rw-r--r-- | bitbake/lib/bb/runqueue.py | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/bitbake/lib/bb/runqueue.py b/bitbake/lib/bb/runqueue.py index aaaafc594f..5ab7e97088 100644 --- a/bitbake/lib/bb/runqueue.py +++ b/bitbake/lib/bb/runqueue.py | |||
@@ -1126,10 +1126,10 @@ class RunQueue: | |||
1126 | else: | 1126 | else: |
1127 | self.state = runQueueSceneInit | 1127 | self.state = runQueueSceneInit |
1128 | 1128 | ||
1129 | # we are ready to run, see if any UI client needs the dependency info | 1129 | # we are ready to run, emit dependency info to any UI or class which |
1130 | if bb.cooker.CookerFeatures.SEND_DEPENDS_TREE in self.cooker.featureset: | 1130 | # needs it |
1131 | depgraph = self.cooker.buildDependTree(self, self.rqdata.taskData) | 1131 | depgraph = self.cooker.buildDependTree(self, self.rqdata.taskData) |
1132 | bb.event.fire(bb.event.DepTreeGenerated(depgraph), self.cooker.data) | 1132 | bb.event.fire(bb.event.DepTreeGenerated(depgraph), self.cooker.data) |
1133 | 1133 | ||
1134 | if self.state is runQueueSceneInit: | 1134 | if self.state is runQueueSceneInit: |
1135 | dump = self.cooker.configuration.dump_signatures | 1135 | dump = self.cooker.configuration.dump_signatures |