[bitbake-devel] [PATCH_V2] GUI error dialog for bitbake

cristiana.voicu cristiana.voicu at intel.com
Mon Sep 30 07:32:56 UTC 2013


On 09/27/2013 02:17 PM, Valentin Popa wrote:
> When the user starts HOB, he/she expects to see some GUI.
> If bitbake signals an erros before HOB starts the error will
> be visible only in console and hob script will terminate.
> This patch allows bitbake to report errors inside a GUI dialog
> when the user wants to use HOB.
> WebHOB starts before bitbake's launch and  a common solution
> for this problem that applies to both HOB and WebHOB is not so obvious.
>
> Signed-off-by: Valentin Popa <valentin.popa at intel.com>
> ---
>   scripts/hob               |  9 ++++++-
>   scripts/show_error_dialog | 63 +++++++++++++++++++++++++++++++++++++++++++++++
>   2 files changed, 71 insertions(+), 1 deletion(-)
>   create mode 100755 scripts/show_error_dialog
>
> diff --git a/scripts/hob b/scripts/hob
> index 8d33ab1..406765f 100755
> --- a/scripts/hob
> +++ b/scripts/hob
> @@ -1,6 +1,13 @@
>   #!/usr/bin/env bash
>   export BB_ENV_EXTRAWHITE="DISABLE_SANITY_CHECKS $BB_ENV_EXTRAWHITE"
> -DISABLE_SANITY_CHECKS=1 bitbake -u hob $@
> +SAVED_ERRORS="$(mktemp)"
> +DISABLE_SANITY_CHECKS=1 bitbake -u hob $@ > $SAVED_ERRORS
>   
>   ret=$?
> +
> +if (( $ret == 1 )); then #there is an error and hob didn't start
> +    show_error_dialog $SAVED_ERRORS
> +fi
> +rm $SAVED_ERRORS
> +
>   exit $ret
> diff --git a/scripts/show_error_dialog b/scripts/show_error_dialog
> new file mode 100755
> index 0000000..beb7cb3
> --- /dev/null
> +++ b/scripts/show_error_dialog
> @@ -0,0 +1,63 @@
> +#!/usr/bin/env python
> +#
> +# BitBake graphical error reporting dialog used by hob script
> +#
> +# Copyright (C) 2013        Intel Corporation
> +#
> +# Authored by Valentin Popa <valentin.popa at lintel.com>
> +# Authored by Andrei Dinu <andrei.adrianx.dinu at intel.com>
> +#
> +# This program is free software; you can redistribute it and/or modify
> +# it under the terms of the GNU General Public License version 2 as
> +# published by the Free Software Foundation.
> +#
> +# This program is distributed in the hope that it will be useful,
> +# but WITHOUT ANY WARRANTY; without even the implied warranty of
> +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> +# GNU General Public License for more details.
> +#
> +# You should have received a copy of the GNU General Public License along
> +# with this program; if not, write to the Free Software Foundation, Inc.,
> +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
> +
> +import sys
> +import os
> +requirements = "FATAL: Gtk+ 2.20.0 or higher & PyGtk 2.21.0 or higher is required"
> +try:
> +    import gtk
> +    import pygtk
> +    pygtk.require('2.0') # to be certain we don't have gtk+ 1.x !?!
> +    gtkver = gtk.gtk_version
> +    pygtkver = gtk.pygtk_version
> +    if gtkver  < (2, 20, 0) or pygtkver < (2, 21, 0):
> +        sys.exit("%s,\nYou have Gtk+ %s and PyGtk %s." % (requirements,
> +                ".".join(map(str, gtkver)),
> +                ".".join(map(str, pygtkver))))
> +except ImportError as exc:
> +    sys.exit("%s (%s)." % (requirements, str(exc)))
> +
> +sys.path.insert(0, os.path.dirname(os.path.dirname(__file__))+"/bitbake/lib")
> +
> +try:
> +    import bb
> +except RuntimeError as exc:
> +    sys.exit(str(exc))
> +
> +from bb.ui.crumbs.hig.crumbsmessagedialog import CrumbsMessageDialog
> +from bb.ui.crumbs.hobwidget import HobButton
> +
> +class HobError(gtk.Window):
> +
> +    def __init__(self, error_log_file):
> +        message = open(error_log_file).readlines()
> +        label = "<b>Hob found an error</b>"
> +        dialog = CrumbsMessageDialog(self, label, gtk.MESSAGE_ERROR, "".join(message))
> +        button = dialog.add_button("Close", gtk.RESPONSE_OK)
> +        HobButton.style_button(button)
> +        button.connect("clicked", lambda w:sys.exit())
> +        dialog.run()
> +        dialog.destroy()
> +
> +if __name__ == "__main__":
> +    HobError(sys.argv[1])
> +
This is OK now. Just to inform, this patch is depending on the [PATCH 
1/2] HOB: HIG compliant message dialogs, in order to work.
Cristiana



More information about the bitbake-devel mailing list