[totem/introspection: 16/17] Port pythonconsole plugin to libpeas
- From: Philip Withnall <pwithnall src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [totem/introspection: 16/17] Port pythonconsole plugin to libpeas
- Date: Sun, 27 Jun 2010 16:59:35 +0000 (UTC)
commit 881dfe85a7d732b590312bebae440dfc753e3e4e
Author: Philip Withnall <philip tecnocode co uk>
Date: Sun Jun 27 16:49:42 2010 +0100
Port pythonconsole plugin to libpeas
src/plugins/pythonconsole/console.py | 59 ++++++++++++++--------------
src/plugins/pythonconsole/pythonconsole.py | 50 +++++++++++++----------
2 files changed, 58 insertions(+), 51 deletions(-)
---
diff --git a/src/plugins/pythonconsole/console.py b/src/plugins/pythonconsole/console.py
index a2f7a3e..41ae0b6 100644
--- a/src/plugins/pythonconsole/console.py
+++ b/src/plugins/pythonconsole/console.py
@@ -37,20 +37,21 @@ import sys
import re
import traceback
import gobject
-import pango
-import gtk
+from gi.repository import Pango
+from gi.repository import Gtk
+from gi.repository import Gdk
-class PythonConsole(gtk.ScrolledWindow):
+class PythonConsole(Gtk.ScrolledWindow):
def __init__(self, namespace = {}, destroy_cb = None):
- gtk.ScrolledWindow.__init__(self)
+ Gtk.ScrolledWindow.__init__(self)
self.destroy_cb = destroy_cb
- self.set_policy(gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC);
- self.set_shadow_type(gtk.SHADOW_IN)
- self.view = gtk.TextView()
- self.view.modify_font(pango.FontDescription('Monospace'))
+ self.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC);
+ self.set_shadow_type(Gtk.ShadowType.IN)
+ self.view = Gtk.TextView()
+ self.view.modify_font(Pango.Font.description_from_string('Monospace'))
self.view.set_editable(True)
- self.view.set_wrap_mode(gtk.WRAP_WORD_CHAR)
+ self.view.set_wrap_mode(Gtk.WrapMode.CHAR)
self.add(self.view)
self.view.show()
@@ -87,16 +88,16 @@ class PythonConsole(gtk.ScrolledWindow):
def __key_press_event_cb(self, view, event):
- if event.keyval == gtk.keysyms.d and event.state == gtk.gdk.CONTROL_MASK:
+ if event.key.keyval == Gdk.d and event.key.state == Gdk.ModifierType.CONTROL_MASK:
self.destroy()
- elif event.keyval == gtk.keysyms.Return and event.state == gtk.gdk.CONTROL_MASK:
+ elif event.key.keyval == Gdk.Return and event.key.state == Gdk.ModifierType.CONTROL_MASK:
# Get the command
buffer = view.get_buffer()
inp_mark = buffer.get_mark("input")
inp = buffer.get_iter_at_mark(inp_mark)
cur = buffer.get_end_iter()
- line = buffer.get_text(inp, cur)
+ line = buffer.get_text(inp, cur, True)
self.current_command = self.current_command + line + "\n"
self.history_add(line)
@@ -116,7 +117,7 @@ class PythonConsole(gtk.ScrolledWindow):
gobject.idle_add(self.scroll_to_end)
return True
- elif event.keyval == gtk.keysyms.Return:
+ elif event.key.keyval == Gdk.Return:
# Get the marks
buffer = view.get_buffer()
lin_mark = buffer.get_mark("input-line")
@@ -125,7 +126,7 @@ class PythonConsole(gtk.ScrolledWindow):
# Get the command line
inp = buffer.get_iter_at_mark(inp_mark)
cur = buffer.get_end_iter()
- line = buffer.get_text(inp, cur)
+ line = buffer.get_text(inp, cur, True)
self.current_command = self.current_command + line + "\n"
self.history_add(line)
@@ -160,32 +161,32 @@ class PythonConsole(gtk.ScrolledWindow):
gobject.idle_add(self.scroll_to_end)
return True
- elif event.keyval == gtk.keysyms.KP_Down or event.keyval == gtk.keysyms.Down:
+ elif event.key.keyval == Gdk.KP_Down or event.key.keyval == Gdk.Down:
# Next entry from history
view.emit_stop_by_name("key_press_event")
self.history_down()
gobject.idle_add(self.scroll_to_end)
return True
- elif event.keyval == gtk.keysyms.KP_Up or event.keyval == gtk.keysyms.Up:
+ elif event.key.keyval == Gdk.KP_Up or event.key.keyval == Gdk.Up:
# Previous entry from history
view.emit_stop_by_name("key_press_event")
self.history_up()
gobject.idle_add(self.scroll_to_end)
return True
- elif event.keyval == gtk.keysyms.KP_Left or event.keyval == gtk.keysyms.Left or \
- event.keyval == gtk.keysyms.BackSpace:
+ elif event.key.keyval == Gdk.KP_Left or event.key.keyval == Gdk.Left or \
+ event.key.keyval == Gdk.BackSpace:
buffer = view.get_buffer()
inp = buffer.get_iter_at_mark(buffer.get_mark("input"))
cur = buffer.get_iter_at_mark(buffer.get_insert())
return inp.compare(cur) == 0
- elif event.keyval == gtk.keysyms.Home:
+ elif event.key.keyval == Gdk.Home:
# Go to the begin of the command instead of the begin of the line
buffer = view.get_buffer()
inp = buffer.get_iter_at_mark(buffer.get_mark("input"))
- if event.state == gtk.gdk.SHIFT_MASK:
+ if event.key.state == Gdk.ModifierType.SHIFT_MASK:
buffer.move_mark_by_name("insert", inp)
else:
buffer.place_cursor(inp)
@@ -200,7 +201,7 @@ class PythonConsole(gtk.ScrolledWindow):
buffer = self.view.get_buffer()
inp = buffer.get_iter_at_mark(buffer.get_mark("input"))
cur = buffer.get_end_iter()
- return buffer.get_text(inp, cur)
+ return buffer.get_text(inp, cur, True)
def set_command_line(self, command):
buffer = self.view.get_buffer()
@@ -232,15 +233,15 @@ class PythonConsole(gtk.ScrolledWindow):
def scroll_to_end(self):
iter = self.view.get_buffer().get_end_iter()
- self.view.scroll_to_iter(iter, 0.0)
+ self.view.scroll_to_iter(iter, 0.0, False, 0.5, 0.5)
return False
def write(self, text, tag = None):
buffer = self.view.get_buffer()
- if tag is None:
- buffer.insert(buffer.get_end_iter(), text)
- else:
- buffer.insert_with_tags(buffer.get_end_iter(), text, tag)
+ insertion_iter = buffer.get_end_iter()
+ buffer.insert(insertion_iter, text)
+ if tag is not None:
+ buffer.apply_tag(tag, insertion_iter, buffer.get_end_iter())
gobject.idle_add(self.scroll_to_end)
def eval(self, command, display_command = False):
@@ -264,12 +265,12 @@ class PythonConsole(gtk.ScrolledWindow):
buffer.insert(cur, ">>> ")
cur = buffer.get_end_iter()
buffer.move_mark_by_name("input", cur)
- self.view.scroll_to_iter(buffer.get_end_iter(), 0.0)
+ self.view.scroll_to_iter(buffer.get_end_iter(), 0.0, False, 0.5, 0.5)
def __run(self, command):
sys.stdout, self.stdout = self.stdout, sys.stdout
sys.stderr, self.stderr = self.stderr, sys.stderr
-
+
try:
try:
r = eval(command, self.namespace, self.namespace)
@@ -288,7 +289,7 @@ class PythonConsole(gtk.ScrolledWindow):
def destroy(self):
pass
- #gtk.ScrolledWindow.destroy(self)
+ #Gtk.ScrolledWindow.destroy(self)
class OutFile:
"""A fake output file object. It sends output to a TK test widget,
diff --git a/src/plugins/pythonconsole/pythonconsole.py b/src/plugins/pythonconsole/pythonconsole.py
index ede3a47..84971e4 100644
--- a/src/plugins/pythonconsole/pythonconsole.py
+++ b/src/plugins/pythonconsole/pythonconsole.py
@@ -36,9 +36,10 @@ from console import PythonConsole
__all__ = ('PythonConsole', 'OutFile')
-import gtk
-import totem
-import gconf
+from gi.repository import Peas
+from gi.repository import Gtk
+from gi.repository import Totem
+from gi.repository import GConf
import gobject
try:
import rpdb2
@@ -46,6 +47,12 @@ try:
except:
have_rpdb2 = False
+import gettext
+gettext.textdomain("totem")
+
+D_ = gettext.dgettext
+_ = gettext.gettext
+
ui_str = """
<ui>
<menubar name="tmw-menubar">
@@ -59,30 +66,30 @@ ui_str = """
</ui>
"""
-class PythonConsolePlugin(totem.Plugin):
+class PythonConsolePlugin(gobject.GObject, Peas.Activatable):
+ __gtype_name__ = 'PythonConsolePlugin'
+
def __init__(self):
- totem.Plugin.__init__(self)
self.window = None
- def activate(self, totem_object):
+ def do_activate(self, totem_object):
data = dict()
manager = totem_object.get_ui_manager()
- data['action_group'] = gtk.ActionGroup('Python')
+ data['action_group'] = Gtk.ActionGroup(name = 'Python')
- action = gtk.Action('Python', 'Python', _('Python Console Menu'), None)
+ action = Gtk.Action(name = 'Python', label = 'Python', tooltip = _('Python Console Menu'))
data['action_group'].add_action(action)
- action = gtk.Action('PythonConsole', _('_Python Console'),
- _("Show Totem's Python console"),
- 'gnome-mime-text-x-python')
+ action = Gtk.Action(name = 'PythonConsole', label = _('_Python Console'),
+ tooltip = _("Show Totem's Python console"),
+ stock_id = 'gnome-mime-text-x-python')
action.connect('activate', self.show_console, totem_object)
data['action_group'].add_action(action)
- action = gtk.Action('PythonDebugger', _('Python Debugger'),
- _("Enable remote Python debugging with rpdb2"),
- None)
+ action = Gtk.Action(name = 'PythonDebugger', label = _('Python Debugger'),
+ tooltip = _("Enable remote Python debugging with rpdb2"))
if have_rpdb2:
action.connect('activate', self.enable_debugging, totem_object)
else:
@@ -98,16 +105,15 @@ class PythonConsolePlugin(totem.Plugin):
def show_console(self, action, totem_object):
if not self.window:
console = PythonConsole(namespace = {'__builtins__' : __builtins__,
- 'totem' : totem,
+ 'Totem' : Totem,
'totem_object' : totem_object},
destroy_cb = self.destroy_console)
console.set_size_request(600, 400)
- console.eval('print "%s" %% totem_object' % _("You can access the totem object through " \
+ console.eval('print "%s" %% totem_object' % _("You can access the Totem.Object through " \
"\'totem_object\' :\\n%s"), False)
-
- self.window = gtk.Window()
+ self.window = Gtk.Window()
self.window.set_title(_('Totem Python Console'))
self.window.add(console)
self.window.connect('destroy', self.destroy_console)
@@ -118,9 +124,9 @@ class PythonConsolePlugin(totem.Plugin):
def enable_debugging(self, action, totem_object):
msg = _("After you press OK, Totem will wait until you connect to it with winpdb or rpdb2. If you have not set a debugger password in GConf, it will use the default password ('totem').")
- dialog = gtk.MessageDialog(None, 0, gtk.MESSAGE_INFO, gtk.BUTTONS_OK_CANCEL, msg)
- if dialog.run() == gtk.RESPONSE_OK:
- gconfclient = gconf.client_get_default()
+ dialog = Gtk.MessageDialog(None, 0, Gtk.MessageType.INFO, Gtk.ButtonType.OK_CANCEL, msg)
+ if dialog.run() == Gtk.ResponseType.OK:
+ gconfclient = GConf.Client.get_default()
password = gconfclient.get_string('/apps/totem/plugins/pythonconsole/rpdb2_password') or "totem"
def start_debugger(password):
rpdb2.start_embedded_debugger(password)
@@ -133,7 +139,7 @@ class PythonConsolePlugin(totem.Plugin):
self.window.destroy()
self.window = None
- def deactivate(self, totem_object):
+ def do_deactivate(self, totem_object):
data = totem_object.get_data('PythonConsolePluginInfo')
manager = totem_object.get_ui_manager()
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]