diff options
| author | Cristiana Voicu <cristiana.voicu@intel.com> | 2013-01-21 16:50:40 +0200 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-01-21 19:05:31 +0000 |
| commit | 4c1ebc7ca73f4ee069dc471a395073ba9a8ce00e (patch) | |
| tree | c391972b3709b3d551ab46ea677acdfc959de35e | |
| parent | eb9d31db70161415ad3bbe8e865aafccdebb5a8d (diff) | |
| download | poky-4c1ebc7ca73f4ee069dc471a395073ba9a8ce00e.tar.gz | |
bitbake: hob: progress bar changed to busy cursor when you open log file
-the first implementation for this bug used a progress bar, that is shown
during open file process; it revelead that the progress bar stops earlier
-now I have implemented using gtk.show_uri() method, that shows itself a
busy cursor when it opens a file;
-deleted the code for the first implementation
[YOCTO #2997]
(Bitbake rev: 09d1c4c2db124104b9da460547b20a2c2ff07bb3)
Signed-off-by: Cristiana Voicu <cristiana.voicu@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
| -rwxr-xr-x | bitbake/lib/bb/ui/crumbs/builddetailspage.py | 16 | ||||
| -rw-r--r-- | bitbake/lib/bb/ui/crumbs/hig/openinglogdialog.py | 68 | ||||
| -rw-r--r-- | bitbake/lib/bb/ui/crumbs/hobthreads.py | 51 | ||||
| -rwxr-xr-x | bitbake/lib/bb/ui/crumbs/imagedetailspage.py | 16 | ||||
| -rwxr-xr-x | bitbake/lib/bb/ui/crumbs/packageselectionpage.py | 16 |
5 files changed, 6 insertions, 161 deletions
diff --git a/bitbake/lib/bb/ui/crumbs/builddetailspage.py b/bitbake/lib/bb/ui/crumbs/builddetailspage.py index 64e758d7f4..171a7a68ed 100755 --- a/bitbake/lib/bb/ui/crumbs/builddetailspage.py +++ b/bitbake/lib/bb/ui/crumbs/builddetailspage.py | |||
| @@ -30,8 +30,6 @@ from bb.ui.crumbs.runningbuild import RunningBuildTreeView | |||
| 30 | from bb.ui.crumbs.runningbuild import BuildFailureTreeView | 30 | from bb.ui.crumbs.runningbuild import BuildFailureTreeView |
| 31 | from bb.ui.crumbs.hobpages import HobPage | 31 | from bb.ui.crumbs.hobpages import HobPage |
| 32 | from bb.ui.crumbs.hobcolor import HobColors | 32 | from bb.ui.crumbs.hobcolor import HobColors |
| 33 | from bb.ui.crumbs.hobthreads import OpeningLogThread | ||
| 34 | from bb.ui.crumbs.hig.openinglogdialog import OpeningLogDialog | ||
| 35 | 33 | ||
| 36 | class BuildConfigurationTreeView(gtk.TreeView): | 34 | class BuildConfigurationTreeView(gtk.TreeView): |
| 37 | def __init__ (self): | 35 | def __init__ (self): |
| @@ -431,18 +429,8 @@ class BuildDetailsPage (HobPage): | |||
| 431 | 429 | ||
| 432 | def open_log_button_clicked_cb(self, button, log_file): | 430 | def open_log_button_clicked_cb(self, button, log_file): |
| 433 | if log_file: | 431 | if log_file: |
| 434 | self.stop = False | 432 | log_file = "file:///" + log_file |
| 435 | dialog = OpeningLogDialog(title = "Opening Log", | 433 | gtk.show_uri(screen=button.get_screen(), uri=log_file, timestamp=0) |
| 436 | parent = None, | ||
| 437 | flags = gtk.DIALOG_MODAL | ||
| 438 | | gtk.DIALOG_DESTROY_WITH_PARENT | ||
| 439 | | gtk.DIALOG_NO_SEPARATOR) | ||
| 440 | #create a thread to open log file | ||
| 441 | background = OpeningLogThread(dialog, log_file, self) | ||
| 442 | background.start() | ||
| 443 | response = dialog.run() | ||
| 444 | self.stop = True | ||
| 445 | background.join() | ||
| 446 | 434 | ||
| 447 | def failure_activate_file_bug_link_cb(self, button): | 435 | def failure_activate_file_bug_link_cb(self, button): |
| 448 | button.child.emit('activate-link', "http://bugzilla.yoctoproject.org") | 436 | button.child.emit('activate-link', "http://bugzilla.yoctoproject.org") |
diff --git a/bitbake/lib/bb/ui/crumbs/hig/openinglogdialog.py b/bitbake/lib/bb/ui/crumbs/hig/openinglogdialog.py deleted file mode 100644 index f1733156a7..0000000000 --- a/bitbake/lib/bb/ui/crumbs/hig/openinglogdialog.py +++ /dev/null | |||
| @@ -1,68 +0,0 @@ | |||
| 1 | # | ||
| 2 | # BitBake Graphical GTK User Interface | ||
| 3 | # | ||
| 4 | # Copyright (C) 2011-2012 Intel Corporation | ||
| 5 | # | ||
| 6 | # Authored by Joshua Lock <josh@linux.intel.com> | ||
| 7 | # Authored by Dongxiao Xu <dongxiao.xu@intel.com> | ||
| 8 | # Authored by Shane Wang <shane.wang@intel.com> | ||
| 9 | # | ||
| 10 | # This program is free software; you can redistribute it and/or modify | ||
| 11 | # it under the terms of the GNU General Public License version 2 as | ||
| 12 | # published by the Free Software Foundation. | ||
| 13 | # | ||
| 14 | # This program is distributed in the hope that it will be useful, | ||
| 15 | # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 16 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 17 | # GNU General Public License for more details. | ||
| 18 | # | ||
| 19 | # You should have received a copy of the GNU General Public License along | ||
| 20 | # with this program; if not, write to the Free Software Foundation, Inc., | ||
| 21 | # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||
| 22 | |||
| 23 | import gtk | ||
| 24 | import gobject | ||
| 25 | from bb.ui.crumbs.hobwidget import HobAltButton | ||
| 26 | from bb.ui.crumbs.progressbar import HobProgressBar | ||
| 27 | from bb.ui.crumbs.hig.crumbsdialog import CrumbsDialog | ||
| 28 | |||
| 29 | """ | ||
| 30 | The following are convenience classes for implementing GNOME HIG compliant | ||
| 31 | BitBake GUI's | ||
| 32 | In summary: spacing = 12px, border-width = 6px | ||
| 33 | """ | ||
| 34 | |||
| 35 | class OpeningLogDialog (CrumbsDialog): | ||
| 36 | |||
| 37 | def __init__(self, title, parent, flags, buttons=None): | ||
| 38 | super(OpeningLogDialog, self).__init__(title, parent, flags, buttons) | ||
| 39 | |||
| 40 | self.running = False | ||
| 41 | # create visual elements on the dialog | ||
| 42 | self.create_visual_elements() | ||
| 43 | |||
| 44 | def start(self): | ||
| 45 | if not self.running: | ||
| 46 | self.running = True | ||
| 47 | gobject.timeout_add(100, self.pulse) | ||
| 48 | |||
| 49 | def pulse(self): | ||
| 50 | self.progress_bar.pulse() | ||
| 51 | return self.running | ||
| 52 | |||
| 53 | def create_visual_elements(self): | ||
| 54 | hbox = gtk.HBox(False, 12) | ||
| 55 | self.user_label = gtk.Label("The log will open in a text editor") | ||
| 56 | hbox.pack_start(self.user_label, expand=False, fill=False) | ||
| 57 | self.vbox.pack_start(hbox, expand=False, fill=False) | ||
| 58 | |||
| 59 | hbox = gtk.HBox(False, 12) | ||
| 60 | # Progress bar | ||
| 61 | self.progress_bar = HobProgressBar() | ||
| 62 | hbox.pack_start(self.progress_bar) | ||
| 63 | self.start() | ||
| 64 | self.vbox.pack_start(hbox, expand=False, fill=False) | ||
| 65 | |||
| 66 | button = self.add_button("Cancel", gtk.RESPONSE_CANCEL) | ||
| 67 | HobAltButton.style_button(button) | ||
| 68 | self.show_all() | ||
diff --git a/bitbake/lib/bb/ui/crumbs/hobthreads.py b/bitbake/lib/bb/ui/crumbs/hobthreads.py deleted file mode 100644 index 64ef91245a..0000000000 --- a/bitbake/lib/bb/ui/crumbs/hobthreads.py +++ /dev/null | |||
| @@ -1,51 +0,0 @@ | |||
| 1 | #!/usr/bin/env python | ||
| 2 | # | ||
| 3 | # BitBake Graphical GTK User Interface | ||
| 4 | # | ||
| 5 | # Copyright (C) 2012 Intel Corporation | ||
| 6 | # | ||
| 7 | # Authored by Cristiana Voicu <cristiana.voicu@intel.com> | ||
| 8 | # | ||
| 9 | # This program is free software; you can redistribute it and/or modify | ||
| 10 | # it under the terms of the GNU General Public License version 2 as | ||
| 11 | # published by the Free Software Foundation. | ||
| 12 | # | ||
| 13 | # This program is distributed in the hope that it will be useful, | ||
| 14 | # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 15 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 16 | # GNU General Public License for more details. | ||
| 17 | # | ||
| 18 | # You should have received a copy of the GNU General Public License along | ||
| 19 | # with this program; if not, write to the Free Software Foundation, Inc., | ||
| 20 | # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||
| 21 | |||
| 22 | import threading | ||
| 23 | import gtk | ||
| 24 | import subprocess | ||
| 25 | |||
| 26 | # | ||
| 27 | # OpeningLogThread | ||
| 28 | # | ||
| 29 | class OpeningLogThread(threading.Thread): | ||
| 30 | def __init__(self, dialog, log_file, parent): | ||
| 31 | threading.Thread.__init__(self) | ||
| 32 | self.dialog =dialog | ||
| 33 | self.log_file = log_file | ||
| 34 | self.parent = parent | ||
| 35 | |||
| 36 | def run(self): | ||
| 37 | p = subprocess.Popen(['xdg-open',self.log_file]) | ||
| 38 | retcode = p.poll() | ||
| 39 | while (retcode == None): | ||
| 40 | if self.parent.stop: | ||
| 41 | try: | ||
| 42 | p.terminate() | ||
| 43 | except OSError, e: | ||
| 44 | if e.errno == 3: | ||
| 45 | pass # no such process | ||
| 46 | else: | ||
| 47 | raise | ||
| 48 | retcode = p.poll() | ||
| 49 | |||
| 50 | self.dialog.destroy() | ||
| 51 | |||
diff --git a/bitbake/lib/bb/ui/crumbs/imagedetailspage.py b/bitbake/lib/bb/ui/crumbs/imagedetailspage.py index 38fbaaaa33..1b60aa8ed5 100755 --- a/bitbake/lib/bb/ui/crumbs/imagedetailspage.py +++ b/bitbake/lib/bb/ui/crumbs/imagedetailspage.py | |||
| @@ -27,8 +27,6 @@ from bb.ui.crumbs.hobwidget import hic, HobViewTable, HobAltButton, HobButton | |||
| 27 | from bb.ui.crumbs.hobpages import HobPage | 27 | from bb.ui.crumbs.hobpages import HobPage |
| 28 | import subprocess | 28 | import subprocess |
| 29 | from bb.ui.crumbs.hig.crumbsdialog import CrumbsDialog | 29 | from bb.ui.crumbs.hig.crumbsdialog import CrumbsDialog |
| 30 | from bb.ui.crumbs.hobthreads import OpeningLogThread | ||
| 31 | from bb.ui.crumbs.hig.openinglogdialog import OpeningLogDialog | ||
| 32 | 30 | ||
| 33 | # | 31 | # |
| 34 | # ImageDetailsPage | 32 | # ImageDetailsPage |
| @@ -407,18 +405,8 @@ class ImageDetailsPage (HobPage): | |||
| 407 | 405 | ||
| 408 | def open_log_clicked_cb(self, button, log_file): | 406 | def open_log_clicked_cb(self, button, log_file): |
| 409 | if log_file: | 407 | if log_file: |
| 410 | self.stop = False | 408 | log_file = "file:///" + log_file |
| 411 | dialog = OpeningLogDialog(title = "Opening Log", | 409 | gtk.show_uri(screen=button.get_screen(), uri=log_file, timestamp=0) |
| 412 | parent = None, | ||
| 413 | flags = gtk.DIALOG_MODAL | ||
| 414 | | gtk.DIALOG_DESTROY_WITH_PARENT | ||
| 415 | | gtk.DIALOG_NO_SEPARATOR) | ||
| 416 | #create a thread to open log file | ||
| 417 | background = OpeningLogThread(dialog, log_file, self) | ||
| 418 | background.start() | ||
| 419 | response = dialog.run() | ||
| 420 | self.stop = True | ||
| 421 | background.join() | ||
| 422 | 410 | ||
| 423 | def refresh_package_detail_box(self, image_size): | 411 | def refresh_package_detail_box(self, image_size): |
| 424 | self.package_detail.update_line_widgets("Total image size: ", image_size) | 412 | self.package_detail.update_line_widgets("Total image size: ", image_size) |
diff --git a/bitbake/lib/bb/ui/crumbs/packageselectionpage.py b/bitbake/lib/bb/ui/crumbs/packageselectionpage.py index 2da9277bf9..1868ebeddd 100755 --- a/bitbake/lib/bb/ui/crumbs/packageselectionpage.py +++ b/bitbake/lib/bb/ui/crumbs/packageselectionpage.py | |||
| @@ -26,8 +26,6 @@ from bb.ui.crumbs.hobcolor import HobColors | |||
| 26 | from bb.ui.crumbs.hobwidget import HobViewTable, HobNotebook, HobAltButton, HobButton | 26 | from bb.ui.crumbs.hobwidget import HobViewTable, HobNotebook, HobAltButton, HobButton |
| 27 | from bb.ui.crumbs.hoblistmodel import PackageListModel | 27 | from bb.ui.crumbs.hoblistmodel import PackageListModel |
| 28 | from bb.ui.crumbs.hobpages import HobPage | 28 | from bb.ui.crumbs.hobpages import HobPage |
| 29 | from bb.ui.crumbs.hobthreads import OpeningLogThread | ||
| 30 | from bb.ui.crumbs.hig.openinglogdialog import OpeningLogDialog | ||
| 31 | 29 | ||
| 32 | # | 30 | # |
| 33 | # PackageSelectionPage | 31 | # PackageSelectionPage |
| @@ -169,18 +167,8 @@ class PackageSelectionPage (HobPage): | |||
| 169 | 167 | ||
| 170 | def open_log_clicked_cb(self, button, log_file): | 168 | def open_log_clicked_cb(self, button, log_file): |
| 171 | if log_file: | 169 | if log_file: |
| 172 | self.stop = False | 170 | log_file = "file:///" + log_file |
| 173 | dialog = OpeningLogDialog(title = "Opening Log", | 171 | gtk.show_uri(screen=button.get_screen(), uri=log_file, timestamp=0) |
| 174 | parent = None, | ||
| 175 | flags = gtk.DIALOG_MODAL | ||
| 176 | | gtk.DIALOG_DESTROY_WITH_PARENT | ||
| 177 | | gtk.DIALOG_NO_SEPARATOR) | ||
| 178 | #create a thread to open log file | ||
| 179 | background = OpeningLogThread(dialog, log_file, self) | ||
| 180 | background.start() | ||
| 181 | response = dialog.run() | ||
| 182 | self.stop = True | ||
| 183 | background.join() | ||
| 184 | 172 | ||
| 185 | def show_page(self, log_file): | 173 | def show_page(self, log_file): |
| 186 | children = self.button_box.get_children() or [] | 174 | children = self.button_box.get_children() or [] |
