diff options
| author | Paul Eggleton <paul.eggleton@linux.intel.com> | 2012-05-28 18:10:39 +0100 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2012-06-14 11:27:11 +0100 |
| commit | 5b3a0eac61d39ae37c44eb644f2debf7d99596af (patch) | |
| tree | 583fadbbbdc57d8cb02994732e3f75a0e47f7495 | |
| parent | 4c4924ad1b7a169ea35446ec9fe6fb33eb452014 (diff) | |
| download | poky-5b3a0eac61d39ae37c44eb644f2debf7d99596af.tar.gz | |
hob: handle sanity check failures as a separate event
In order to show a friendlier error message that does not bury the
actual sanity error in our typical preamble about disabling sanity
checks, use a separate event to indicate that sanity checks failed.
This change is intended to work together with the related change to
sanity.bbclass in OE-Core.
Fixes [YOCTO #2336].
(Bitbake rev: 24b631acdaa143a4de39c6e1328849660c66f219)
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
| -rw-r--r-- | bitbake/lib/bb/event.py | 8 | ||||
| -rwxr-xr-x | bitbake/lib/bb/ui/crumbs/builder.py | 7 | ||||
| -rw-r--r-- | bitbake/lib/bb/ui/crumbs/hobeventhandler.py | 6 |
3 files changed, 20 insertions, 1 deletions
diff --git a/bitbake/lib/bb/event.py b/bitbake/lib/bb/event.py index f3fb5213ba..1116c0a7bf 100644 --- a/bitbake/lib/bb/event.py +++ b/bitbake/lib/bb/event.py | |||
| @@ -527,3 +527,11 @@ class SanityCheckPassed(Event): | |||
| 527 | """ | 527 | """ |
| 528 | Event to indicate sanity check is passed | 528 | Event to indicate sanity check is passed |
| 529 | """ | 529 | """ |
| 530 | |||
| 531 | class SanityCheckFailed(Event): | ||
| 532 | """ | ||
| 533 | Event to indicate sanity check has failed | ||
| 534 | """ | ||
| 535 | def __init__(self, msg): | ||
| 536 | Event.__init__(self) | ||
| 537 | self._msg = msg | ||
diff --git a/bitbake/lib/bb/ui/crumbs/builder.py b/bitbake/lib/bb/ui/crumbs/builder.py index 3f6878246c..df85326652 100755 --- a/bitbake/lib/bb/ui/crumbs/builder.py +++ b/bitbake/lib/bb/ui/crumbs/builder.py | |||
| @@ -354,6 +354,7 @@ class Builder(gtk.Window): | |||
| 354 | self.handler.connect("data-generated", self.handler_data_generated_cb) | 354 | self.handler.connect("data-generated", self.handler_data_generated_cb) |
| 355 | self.handler.connect("command-succeeded", self.handler_command_succeeded_cb) | 355 | self.handler.connect("command-succeeded", self.handler_command_succeeded_cb) |
| 356 | self.handler.connect("command-failed", self.handler_command_failed_cb) | 356 | self.handler.connect("command-failed", self.handler_command_failed_cb) |
| 357 | self.handler.connect("sanity-failed", self.handler_sanity_failed_cb) | ||
| 357 | self.handler.connect("recipe-populated", self.handler_recipe_populated_cb) | 358 | self.handler.connect("recipe-populated", self.handler_recipe_populated_cb) |
| 358 | self.handler.connect("package-populated", self.handler_package_populated_cb) | 359 | self.handler.connect("package-populated", self.handler_package_populated_cb) |
| 359 | 360 | ||
| @@ -652,10 +653,14 @@ class Builder(gtk.Window): | |||
| 652 | 653 | ||
| 653 | def handler_command_failed_cb(self, handler, msg): | 654 | def handler_command_failed_cb(self, handler, msg): |
| 654 | if msg: | 655 | if msg: |
| 655 | msg = msg.replace("your local.conf", "Settings") | ||
| 656 | self.show_error_dialog(msg) | 656 | self.show_error_dialog(msg) |
| 657 | self.reset() | 657 | self.reset() |
| 658 | 658 | ||
| 659 | def handler_sanity_failed_cb(self, handler, msg): | ||
| 660 | msg = msg.replace("your local.conf", "Settings") | ||
| 661 | self.show_error_dialog(msg) | ||
| 662 | self.reset() | ||
| 663 | |||
| 659 | def window_sensitive(self, sensitive): | 664 | def window_sensitive(self, sensitive): |
| 660 | self.image_configuration_page.machine_combo.set_sensitive(sensitive) | 665 | self.image_configuration_page.machine_combo.set_sensitive(sensitive) |
| 661 | self.image_configuration_page.image_combo.set_sensitive(sensitive) | 666 | self.image_configuration_page.image_combo.set_sensitive(sensitive) |
diff --git a/bitbake/lib/bb/ui/crumbs/hobeventhandler.py b/bitbake/lib/bb/ui/crumbs/hobeventhandler.py index 424bcfa525..74138cb031 100644 --- a/bitbake/lib/bb/ui/crumbs/hobeventhandler.py +++ b/bitbake/lib/bb/ui/crumbs/hobeventhandler.py | |||
| @@ -42,6 +42,9 @@ class HobHandler(gobject.GObject): | |||
| 42 | "command-failed" : (gobject.SIGNAL_RUN_LAST, | 42 | "command-failed" : (gobject.SIGNAL_RUN_LAST, |
| 43 | gobject.TYPE_NONE, | 43 | gobject.TYPE_NONE, |
| 44 | (gobject.TYPE_STRING,)), | 44 | (gobject.TYPE_STRING,)), |
| 45 | "sanity-failed" : (gobject.SIGNAL_RUN_LAST, | ||
| 46 | gobject.TYPE_NONE, | ||
| 47 | (gobject.TYPE_STRING,)), | ||
| 45 | "generating-data" : (gobject.SIGNAL_RUN_LAST, | 48 | "generating-data" : (gobject.SIGNAL_RUN_LAST, |
| 46 | gobject.TYPE_NONE, | 49 | gobject.TYPE_NONE, |
| 47 | ()), | 50 | ()), |
| @@ -170,6 +173,9 @@ class HobHandler(gobject.GObject): | |||
| 170 | elif isinstance(event, bb.event.SanityCheckPassed): | 173 | elif isinstance(event, bb.event.SanityCheckPassed): |
| 171 | self.run_next_command() | 174 | self.run_next_command() |
| 172 | 175 | ||
| 176 | elif isinstance(event, bb.event.SanityCheckFailed): | ||
| 177 | self.emit("sanity-failed", event._msg) | ||
| 178 | |||
| 173 | elif isinstance(event, logging.LogRecord): | 179 | elif isinstance(event, logging.LogRecord): |
| 174 | if event.levelno >= logging.ERROR: | 180 | if event.levelno >= logging.ERROR: |
| 175 | self.error_msg += event.msg + '\n' | 181 | self.error_msg += event.msg + '\n' |
