diff options
Diffstat (limited to 'shell/view/ConsoleWindow.py')
-rw-r--r-- | shell/view/ConsoleWindow.py | 128 |
1 files changed, 128 insertions, 0 deletions
diff --git a/shell/view/ConsoleWindow.py b/shell/view/ConsoleWindow.py new file mode 100644 index 0000000..4cdbbb1 --- /dev/null +++ b/shell/view/ConsoleWindow.py @@ -0,0 +1,128 @@ +import logging + +import gtk +import dbus +import dbus.service + +class Console(gtk.ScrolledWindow): + def __init__(self): + gtk.ScrolledWindow.__init__(self) + + self._show_debug = False + + self.set_policy(gtk.POLICY_AUTOMATIC, + gtk.POLICY_AUTOMATIC) + + self._textview = gtk.TextView() + self._textview.set_wrap_mode(gtk.WRAP_WORD) + self.add(self._textview) + self._textview.show() + + buf = self._textview.get_buffer() + self._debug_tag = buf.create_tag("debug") + self._debug_tag.set_property("invisible", True) + + def get_show_debug(self): + return self._show_debug + + def set_show_debug(self, show_debug): + self._show_debug = show_debug + self._debug_tag.set_property("invisible", not show_debug) + + def log(self, level, message): + msg = message + '\n' + buf = self._textview.get_buffer() + it = buf.get_end_iter() + + if level == logging.DEBUG: + buf.insert_with_tags(it, msg, self._debug_tag) + else: + buf.insert(it, msg) + +class ConsoleDbusService(dbus.service.Object): + def __init__(self, console, bus_name): + dbus.service.Object.__init__(self, bus_name, '/org/laptop/Sugar/Console') + self._console = console + + @dbus.service.method('org.laptop.Sugar.Console', + in_signature="saias", out_signature="") + def log(self, module_id, levels, messages): + self._console.log(module_id, levels, messages) + +class ConsoleWindow(gtk.Window): + def __init__(self): + gtk.Window.__init__(self) + + self.set_default_size(620, 440) + self.set_type_hint(gtk.gdk.WINDOW_TYPE_HINT_DIALOG) + self.set_title("Console") + self.connect("delete_event", lambda w, e: w.hide_on_delete()) + + vbox = gtk.VBox() + + toolbar = gtk.Toolbar() + + self._debug_toggle = gtk.ToggleToolButton() + self._debug_toggle.connect('toggled', self.__debug_toggled_cb) + self._debug_toggle.set_label('Debug') + toolbar.insert(self._debug_toggle, -1) + self._debug_toggle.show() + + self._ignore_toggle = False + + vbox.pack_start(toolbar, False) + toolbar.show() + + self._nb = gtk.Notebook() + self._nb.connect('switch-page', self.__page_changed_cb) + vbox.pack_start(self._nb) + self._nb.show() + + self.add(vbox) + vbox.show() + + self._consoles = {} + + session_bus = dbus.SessionBus() + bus_name = dbus.service.BusName('org.laptop.Sugar.Console', bus=session_bus) + ConsoleDbusService(self, bus_name) + + def _add_console(self, page_id): + console = Console() + page = self._nb.append_page(console, gtk.Label(page_id)) + console.show() + + self._consoles[page_id] = console + + return console + + def _get_console(self, page_id): + if not self._consoles.has_key(page_id): + console = self._add_console(page_id) + else: + console = self._consoles[page_id] + return console + + def __debug_toggled_cb(self, button): + if not self._ignore_toggle: + console = self._nb.get_nth_page(self._nb.get_current_page()) + if console: + console.set_show_debug(button.get_active()) + + def __page_changed_cb(self, notebook, page, page_num): + console = self._nb.get_nth_page(page_num) + + self._ignore_toggle = True + self._debug_toggle.set_active(console.get_show_debug()) + self._ignore_toggle = False + + def set_page(self, page_id): + page = self._nb.page_num(self._consoles[page_id]) + self._nb.set_current_page(page) + + def log(self, page_id, levels, messages): + console = self._get_console(page_id) + i = 0 + while i < len(levels): + console.log(levels[i], messages[i]) + i += 1 |