Source code for stoqlib.gui.dialogs.progressbardialog

# -*- coding: utf-8 -*-
# vi:si:et:sw=4:sts=4:ts=4

##
## Copyright (C) 2011-2013 Async Open Source
##
## This program is free software; you can redistribute it and/or
## modify it under the terms of the GNU Lesser General Public License
## as published by the Free Software Foundation; either version 2
## of the License, or (at your option) any later version.
##
## 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 Lesser General Public License for more details.
##
## You should have received a copy of the GNU Lesser General Public License
## along with this program; if not, write to the Free Software
## Foundation, Inc., or visit: http://www.gnu.org/.
##
##
## Author(s): Stoq Team <stoq-devel@async.com.br>
##

import gtk

from stoqlib.api import api
from stoqlib.gui.base.dialogs import BasicDialog
from stoqlib.gui.widgets.processview import ProcessView
from stoqlib.lib.message import warning
from stoqlib.lib.translation import stoqlib_gettext

_ = stoqlib_gettext


[docs]class ProgressbarDialog(BasicDialog): """Dialogs showing progress of a ProcessView should inherit from this. """ #: Default size for this dialog. size = (400, 300) #: Title for the window. title = None #: Default process and arguments to run. args = [] #: Default output of the process running. log_category = None #: Message that will appear on the progressbar before the process is #: started. start_msg = _(u'Running task...') #: Message that will appear when process succeeds. success_msg = _(u'Task ran successfully!') #: Message that will appear then the process fails. failure_msg = _(u'Task failed!') def __init__(self, title=None, args=None, log_category=None, start_msg=None, success_msg=None, failure_msg=None): """:param title: The title of the window. :param args: Default process and arguments to run. :param log_category: Default process and arguments to run. :param start_msg: Message that will appear on the progressbar before the process is started. :param success_msg: Message that will appear when process succeeds. :param failure_msg: Message that will appear then the process fails. """ self.title = title or self.title if not self.title: raise ValueError('You must define a title for the window.') self.args = args or self.args if not self.args: raise ValueError('You must define the process and arguments for ' 'the process.') self.log_category = log_category or self.log_category if not self.log_category: raise ValueError('You must define a log category to read the ' 'output of the process from.') self.start_msg = start_msg or self.start_msg self.success_msg = success_msg or self.success_msg self.failure_msg = failure_msg or self.failure_msg BasicDialog.__init__(self, size=self.size, title=self.title) self._build_ui() self._execute() def _build_ui(self): self.main_label.set_text(self.start_msg) self.set_ok_label(_("Done")) self.progressbar = gtk.ProgressBar() self.vbox.pack_start(self.progressbar, False, False) self.progressbar.show() self.expander = gtk.Expander(label=_("Details...")) self.expander.set_expanded(False) self.vbox.pack_start(self.expander, True, True) self.expander.show() self.vbox.set_child_packing(self.main, False, False, 0, 0) self.process_view = ProcessView() self.process_view.listen_stdout = False self.process_view.listen_stderr = True self.expander.add(self.process_view) self.process_view.show() self.disable_ok() def _execute(self): self.args.extend(api.db_settings.get_command_line_arguments()) self.process_view.execute_command(self.args) def _parse_process_line(self, line): log_pos = line.find(self.log_category) if log_pos == -1: return line = line[log_pos + len(self.log_category) + 1:] value, text = self.process_line(line) if value and text: self.progressbar.set_fraction(value) self.progressbar.set_text(text) def _finish(self, returncode): if returncode: self.expander.set_expanded(True) warning(self.failure_msg) return self.progressbar.set_text(self.success_msg) self.progressbar.set_fraction(1) self.enable_ok() # # Public API #
[docs] def process_line(self, line): """This method will be called once for each line of the process output, and must return a tuple containing the percentage and message that will be displayed in the progress bar. :param line: The line that must be processed. :returns: A tuple, in which in the first value is the percentage that will be displayed in the progressbar (0 <= value <= 1) and the text that will be displayed in it. """ raise NotImplementedError("Can't define how to parse the output. You " "must implement process_line.")
# # Callbacks #
[docs] def on_process_view__read_line(self, view, line): self._parse_process_line(line)
[docs] def on_process_view__finished(self, view, returncode): self._finish(returncode)