Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/shell/view/ConsoleWindow.py
diff options
context:
space:
mode:
Diffstat (limited to 'shell/view/ConsoleWindow.py')
-rw-r--r--shell/view/ConsoleWindow.py128
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