[pybliographer/wip/gtk3: 1/42] ui: Initial port to gtk+3
- From: Germán Poo-Caamaño <gpoo src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [pybliographer/wip/gtk3: 1/42] ui: Initial port to gtk+3
- Date: Sat, 7 Oct 2017 01:17:46 +0000 (UTC)
commit 5e3f28089d089609dc7f3cc97c04da2ac98ec62c
Author: Germán Poo-Caamaño <gpoo gnome org>
Date: Wed Apr 24 02:55:20 2013 -0700
ui: Initial port to gtk+3
Pyblio/ConfDir/GnomeUI.py | 8 +-
Pyblio/GnomeUI/Common.py | 84 ++--
Pyblio/GnomeUI/Compat.py | 25 +-
Pyblio/GnomeUI/Config.py | 113 +++---
Pyblio/GnomeUI/Document.py | 144 ++++---
Pyblio/GnomeUI/Editor.py | 216 +++++-----
Pyblio/GnomeUI/Entry.py | 23 +-
Pyblio/GnomeUI/Fields.py | 60 ++--
Pyblio/GnomeUI/FileSelector.py | 36 +-
Pyblio/GnomeUI/Format.py | 6 +-
Pyblio/GnomeUI/Index.py | 77 ++--
Pyblio/GnomeUI/Medline.py | 5 +-
Pyblio/GnomeUI/OpenURL.py | 12 +-
Pyblio/GnomeUI/Pybliographic.py | 4 +-
Pyblio/GnomeUI/Search.py | 25 +-
Pyblio/GnomeUI/Sort.py | 15 +-
Pyblio/GnomeUI/Utils.py | 63 ++--
Pyblio/GnomeUI/__init__.py | 24 +-
Pyblio/GnomeUI/glade/pyblio.glade.in | 626 ---------------------------
Pyblio/GnomeUI/glade/pyblio.ui.in | 778 ++++++++++++++++++++++++++++++++++
scripts/pybliographic.py | 5 +-
21 files changed, 1259 insertions(+), 1090 deletions(-)
---
diff --git a/Pyblio/ConfDir/GnomeUI.py b/Pyblio/ConfDir/GnomeUI.py
index 6739aa4..8872077 100644
--- a/Pyblio/ConfDir/GnomeUI.py
+++ b/Pyblio/ConfDir/GnomeUI.py
@@ -1,7 +1,7 @@
from Pyblio import Config, Fields
from Pyblio.GnomeUI import Utils, Editor
-import gtk
+from gi.repository import Gtk
Config.define ('gnomeui/default', """ Graphical description of the
default field. """)
@@ -45,8 +45,8 @@ Config.define ('gnomeui/multiline',
-Config.set ('gnomeui/monospaced',
- gtk.gdk.Font ('-*-*-*-r-normal-*-*-*-*-*-c-*-iso8859-1'))
+#Config.set ('gnomeui/monospaced',
+# gtk.gdk.Font ('-*-*-*-r-normal-*-*-*-*-*-c-*-iso8859-1'))
@@ -58,7 +58,7 @@ Fields.URL.widget = Editor.URL
Fields.Reference.widget = Editor.Reference
Fields.Date.widget = Editor.Date
-Fields.Date.justification = gtk.JUSTIFY_RIGHT
+Fields.Date.justification = Gtk.JUSTIFY_RIGHT
for f, w in (('author', 150),
('editor', 150),
diff --git a/Pyblio/GnomeUI/Common.py b/Pyblio/GnomeUI/Common.py
index 83971b9..9397f17 100644
--- a/Pyblio/GnomeUI/Common.py
+++ b/Pyblio/GnomeUI/Common.py
@@ -25,7 +25,7 @@ Class fileschooserbutton implements a widget similar to
File Chooser Button from gtk: it calls a
File Chooser Dialog to allow entering and editing an URL.
-Class filechooserdialog subclasses gtk.FileChooserDialog and
+Class filechooserdialog subclasses Gtk.FileChooserDialog and
adds some fields to enter additional information for an URL.
@@ -36,23 +36,25 @@ Class filechooserdialog subclasses gtk.FileChooserDialog and
RESPONSE_COPY = 1
RESPONSE_VIEW = 2
-import gobject, gtk, gtk.gdk, pango, sys
+from gi.repository import GObject, Gtk, Gdk, Pango
+# import gobject, gtk, Gtk.gdk, pango, sys
+import sys
from Pyblio import Fields, Resource
def get_icon_theme (widget):
- if gtk.widget_has_screen (widget):
- return gtk.icon_theme_get_for_screen (gtk.widget_get_screen (widget))
- return gtk.icon_theme_get_default ();
+ if Gtk.widget_has_screen (widget):
+ return Gtk.icon_theme_get_for_screen (Gtk.widget_get_screen (widget))
+ return Gtk.IconTheme.get_default ();
-class filechooserbutton (gtk.Button):
+class filechooserbutton (Gtk.Button):
def __init__ (self, URL=None, action='enter/edit', parent=None):
- gtk.Button.__init__ (self)
+ GObject.GObject.__init__ (self)
- g_error = gobject.GError ()
+ g_error = GObject.GError ()
self.parent_widget = parent
self.url = URL or Fields.URL ()
self.newuri = None
@@ -61,20 +63,20 @@ class filechooserbutton (gtk.Button):
assert action in Resource.CHOOSER_ACTIONS, "Invalid file chooser action"
self.connect ("clicked", self.cb_clicked)
- self.box = gtk.HBox (False, 4)
+ self.box = Gtk.HBox (False, 4)
self.add (self.box)
- self.image = gtk.Image ()
- pixbuf = self.render_icon (gtk.STOCK_NEW,
- gtk.ICON_SIZE_MENU)
+ self.image = Gtk.Image ()
+ pixbuf = self.render_icon (Gtk.STOCK_NEW,
+ Gtk.IconSize.MENU)
self.image.set_from_pixbuf (pixbuf)
self.box.pack_start (self.image, False, False, 0)
- self.label = gtk.Label (self.url.get_url () or _('Enter/Select an URL'))
- self.label.set_ellipsize (pango.ELLIPSIZE_START)
+ self.label = Gtk.Label(label=self.url.get_url () or _('Enter/Select an URL'))
+ self.label.set_ellipsize (Pango.EllipsizeMode.START)
self.label.set_alignment (0.0, 0.5)
self.box.pack_start (self.label)
- self.sep = gtk.VSeparator ()
+ self.sep = Gtk.VSeparator ()
self.box.pack_start (self.sep, False, False, 0)
- self.icon = gtk.image_new_from_stock (gtk.STOCK_SAVE, gtk.ICON_SIZE_MENU)
+ self.icon = Gtk.Image.new_from_stock (Gtk.STOCK_SAVE, Gtk.IconSize.MENU)
self.box.pack_start (self.icon, False, False, 0)
self.title = "Enter/Edit URL"
@@ -94,7 +96,7 @@ class filechooserbutton (gtk.Button):
def cb_clicked (self, *args):
self.dialog = filechooserdialog (self.url, self.title)
- self.dialog.set_position(gtk.WIN_POS_CENTER_ON_PARENT)
+ self.dialog.set_position(Gtk.WindowPosition.CENTER_ON_PARENT)
self.dialog.set_transient_for (
self.parent_widget or self.get_toplevel ())
@@ -102,7 +104,7 @@ class filechooserbutton (gtk.Button):
print 'NEW URI:', response, self.newuri
self.dialog.destroy ()
- if response == gtk.RESPONSE_OK:
+ if response == Gtk.ResponseType.OK:
pass
elif response == RESPONSE_VIEW:
print 'RESPONSE VIEW'
@@ -118,14 +120,14 @@ class filechooserbutton (gtk.Button):
return self.newuri
-class filechooserdialog (gtk.FileChooserDialog):
+class filechooserdialog (Gtk.FileChooserDialog):
def __init__ (self, url, title):
- gtk.FileChooserDialog.__init__ (
- self, title, None, gtk.FILE_CHOOSER_ACTION_SAVE,
+ GObject.GObject.__init__ (
+ self, title, None, Gtk.FileChooserAction.SAVE,
backend="gnomevfs")
- tips = gtk.Tooltips ()
+ tips = Gtk.Tooltips ()
self.set_local_only (False)
@@ -136,55 +138,55 @@ class filechooserdialog (gtk.FileChooserDialog):
## self.set_current_folder (self.uri)
## self.set_current_name (self.uri)
- accelerator = gtk.AccelGroup ()
+ accelerator = Gtk.AccelGroup ()
self.add_accel_group (accelerator)
- b = self.add_button (gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT)
- b.add_accelerator ('clicked', accelerator, gtk.keysyms.Escape, 0, 0)
+ b = self.add_button (Gtk.STOCK_CANCEL, Gtk.ResponseType.REJECT)
+ b.add_accelerator ('clicked', accelerator, Gdk.KEY_Escape, 0, 0)
- b = self.add_button (gtk.STOCK_OK, gtk.RESPONSE_OK)
- b.add_accelerator ('clicked', accelerator, gtk.keysyms.Return, 0, 0)
+ b = self.add_button (Gtk.STOCK_OK, Gtk.ResponseType.OK)
+ b.add_accelerator ('clicked', accelerator, Gdk.KEY_Return, 0, 0)
- b = self.add_button (gtk.STOCK_COPY, RESPONSE_COPY)
- b.add_accelerator ('clicked', accelerator, gtk.keysyms.c, gtk.gdk.CONTROL_MASK, 0)
+ b = self.add_button (Gtk.STOCK_COPY, RESPONSE_COPY)
+ b.add_accelerator ('clicked', accelerator, Gdk.KEY_c, Gdk.ModifierType.CONTROL_MASK, 0)
- b = self.add_button (gtk.STOCK_FIND, RESPONSE_VIEW)
- b.add_accelerator ('clicked', accelerator, gtk.keysyms.v, gtk.gdk.CONTROL_MASK, 0)
+ b = self.add_button (Gtk.STOCK_FIND, RESPONSE_VIEW)
+ b.add_accelerator ('clicked', accelerator, Gdk.KEY_v, Gdk.ModifierType.CONTROL_MASK, 0)
# added widgets
- vbox = gtk.VBox ()
- hbox = gtk.HBox ()
+ vbox = Gtk.VBox ()
+ hbox = Gtk.HBox ()
vbox.pack_start (hbox)
hbox.set_spacing (6)
hbox.set_border_width (6)
- self.invalid_w = gtk.ToggleButton (_('Invalid'))
+ self.invalid_w = Gtk.ToggleButton (_('Invalid'))
hbox.pack_start (self.invalid_w, expand=False)
tips.set_tip (self.invalid_w, "Set this to indicate an invalid URL",
"An invalid url may not usually be used, "
"but be kept for historical purposes.")
self.invalid_w.set_active (self.URI.invalid or False)
- self.inexact_w = gtk.ToggleButton (_('Inexact'))
+ self.inexact_w = Gtk.ToggleButton (_('Inexact'))
hbox.pack_start (self.inexact_w, expand=False)
tips.set_tip (self.inexact_w, "Indicates an URL that is not the resource proper",
"An inexact URL usually requires manual intervention.")
self.inexact_w.set_active (self.URI.inexact or False)
- hbox.pack_start (gtk.Label (_(' Date accessed:')), False)
- self.date_w = gtk.Entry ()
+ hbox.pack_start (Gtk.Label(label=_(' Date accessed:')), False)
+ self.date_w = Gtk.Entry ()
hbox.pack_start (self.date_w)
tips.set_tip (self.date_w, "The date (and time) the resource has been accessed.",
"This information is often required"
" by bibliographical standards.")
self.date_w.set_text (self.URI.date or '')
- hbox = gtk.HBox ()
+ hbox = Gtk.HBox ()
vbox.pack_start (hbox)
hbox.set_spacing (6)
hbox.set_border_width (6)
- hbox.pack_start (gtk.Label (_('Note:')), False)
- self.note_w = gtk.Entry ()
+ hbox.pack_start (Gtk.Label(label=_('Note:')), False)
+ self.note_w = Gtk.Entry ()
hbox.pack_start (self.note_w)
tips.set_tip (self.note_w, "A note e.g. about the resource or its accessability.",
"Information that might help the user")
@@ -194,7 +196,7 @@ class filechooserdialog (gtk.FileChooserDialog):
self.show_all ()
def run (self):
- response = gtk.FileChooserDialog.run (self)
+ response = Gtk.FileChooserDialog.run (self)
uri = self.get_uri ()
invalid = self.invalid_w.get_active ()
inexact = self.inexact_w.get_active ()
diff --git a/Pyblio/GnomeUI/Compat.py b/Pyblio/GnomeUI/Compat.py
index dd1ea0d..1257567 100644
--- a/Pyblio/GnomeUI/Compat.py
+++ b/Pyblio/GnomeUI/Compat.py
@@ -27,22 +27,23 @@ Compatability module
"""
# gnome-python (2.x)
-try:
- from gnome.ui import gnome_error_dialog_parented
-except ImportError:
- from gnome.ui import error_dialog_parented as gnome_error_dialog_parented
-
-error_dialog_parented = gnome_error_dialog_parented
+#try:
+# from gnome.ui import gnome_error_dialog_parented
+#except ImportError:
+# from gnome.ui import error_dialog_parented as gnome_error_dialog_parented
+#
+#error_dialog_parented = gnome_error_dialog_parented
+error_dialog_parented = str
# gnome-python (2.x)
-try:
- import gnomevfs
-except ImportError:
- import gnome.vfs as gnomevfs
-
-get_mime_type = gnomevfs.get_mime_type
+#try:
+# import gnomevfs
+#except ImportError:
+# import gnome.vfs as gnomevfs
+#get_mime_type = gnomevfs.get_mime_type
+get_mime_type = str
# Local Variables:
diff --git a/Pyblio/GnomeUI/Config.py b/Pyblio/GnomeUI/Config.py
index 2d8628c..b21f732 100644
--- a/Pyblio/GnomeUI/Config.py
+++ b/Pyblio/GnomeUI/Config.py
@@ -22,8 +22,7 @@
# TO DO:
# List view troubles
-import gobject, gtk, gtk.glade
-import gnome.ui
+from gi.repository import GObject, Gtk
import copy, os.path, re, string
@@ -49,11 +48,11 @@ class ConfigDialog (Utils.GladeWindow):
self.dialog = self.xml.get_widget ('config1')
content = self.xml.get_widget ('dialog-vbox1')
- self.w = gtk.Notebook ()
+ self.w = Gtk.Notebook ()
content.pack_start (self.w)
-## tooltips = gtk.Tooltips ()
+## tooltips = Gtk.Tooltips ()
## tooltips.enable ()
self.warning = 0
@@ -71,7 +70,7 @@ class ConfigDialog (Utils.GladeWindow):
keys = Config.keys_in_domain (string.lower (dom))
keys.sort ()
- table = gtk.VBox (spacing=6)
+ table = Gtk.VBox (spacing=6)
table.set_border_width (12)
for item in keys:
@@ -80,12 +79,12 @@ class ConfigDialog (Utils.GladeWindow):
continue
nice = string.capitalize (string.split (item, '/') [1])
- label = gtk.Label()
+ label = Gtk.Label()
label.set_use_markup(True)
label.set_markup('<b>%s</b>' % (nice))
label.set_alignment(xalign=0.5, yalign=0)
- hbox = gtk.HBox (spacing = 12)
+ hbox = Gtk.HBox (spacing = 12)
hbox.pack_start (label,False)
desc = data.description
@@ -96,11 +95,11 @@ class ConfigDialog (Utils.GladeWindow):
# Create the edition widget...
edit = data.type.w (data.type, self, item, help_text=desc)
if edit.allow_help:
- label = gtk.Label ()
+ label = Gtk.Label ()
label.set_line_wrap (True)
label.set_text(desc)
hbox.pack_start(label, False)
- hbox = gtk.HBox (spacing = 6)
+ hbox = Gtk.HBox (spacing = 6)
hbox.set_border_width (6)
cw [item] = edit
@@ -115,12 +114,12 @@ class ConfigDialog (Utils.GladeWindow):
# items should not be spread vertically, however
if cw:
# Put the complete table in a scrolled window
- scroll = gtk.ScrolledWindow ()
- scroll.set_policy (gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
+ scroll = Gtk.ScrolledWindow ()
+ scroll.set_policy (Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC)
scroll.add_with_viewport (table)
- self.w.append_page (scroll, gtk.Label (dom))
+ self.w.append_page (scroll, Gtk.Label(label=dom))
self.page.append (cw)
self.show()
@@ -203,7 +202,7 @@ class StringConfig (BaseConfig):
def __init__ (self, dtype, props, key=None, parent=None, help_text=''):
BaseConfig.__init__ (self, dtype, props, key, parent)
- self.w = gtk.Entry ()
+ self.w = Gtk.Entry ()
if self.key:
text = Config.get (key).data
@@ -240,8 +239,8 @@ class IntegerConfig (StringConfig):
vmin = 0
vmax = +100
- adj = gtk.Adjustment (0, vmin, vmax, 1, 10, 0)
- self.w = gtk.SpinButton (adj, 1, 0)
+ adj = Gtk.Adjustment (0, vmin, vmax, 1, 10, 0)
+ self.w = Gtk.SpinButton (adj, 1, 0)
if self.key:
value = Config.get (key).data
@@ -274,8 +273,8 @@ class BooleanConfig (BaseConfig):
def __init__ (self, dtype, props, key=None, parent=None, help_text=''):
BaseConfig.__init__ (self, dtype, props, key, parent)
self.allow_help = False
- self.w = gtk.HBox (spacing=6)
- self.button = gtk.CheckButton ()
+ self.w = Gtk.HBox (spacing=6)
+ self.button = Gtk.CheckButton ()
self.w.pack_start (self.button, False)
if self.key:
@@ -283,10 +282,10 @@ class BooleanConfig (BaseConfig):
self.button.set_active(value)
self.button.connect ('clicked', self.update, True)
- description = gtk.Label()
+ description = Gtk.Label()
description.set_use_markup(True)
description.set_line_wrap(True)
- description.set_justify(gtk.JUSTIFY_LEFT) #default?
+ description.set_justify(Gtk.Justification.LEFT) #default?
description.set_markup('%s' % (help_text))
description.set_alignment(xalign=0.5, yalign=0.5)
self.w.pack_start (description, False, True)
@@ -317,7 +316,7 @@ class ElementConfig (BaseConfig):
data = str(Config.get (key).data)
else: data = ''
- self.m = gtk.combo_box_new_text ()
+ self.m = Gtk.ComboBoxText ()
self.items = dtype.get ()
ix = 0
@@ -331,7 +330,7 @@ class ElementConfig (BaseConfig):
self.m.set_active (select)
self.m.connect ('changed', self.update, True)
- self.w = gtk.HBox(spacing = 12)
+ self.w = Gtk.HBox(spacing = 12)
self.w.pack_start(self.m, True, True, padding=12)
self.w.show_all ()
return
@@ -349,7 +348,7 @@ class TupleConfig (BaseConfig):
def __init__ (self, dtype, props, key=None, parent=None, help_text=''):
BaseConfig.__init__ (self, dtype, props, key, parent)
- self.w = gtk.VBox (spacing = 6)
+ self.w = Gtk.VBox (spacing = 6)
self.sub = []
self.resize = False
@@ -404,19 +403,19 @@ class ListConfig (BaseConfig):
def __init__ (self, dtype, props, key=None, parent=None, help_text=''):
BaseConfig.__init__ (self, dtype, props, key, parent)
- self.w = gtk.VBox (spacing = 6)
- h = gtk.HBox (spacing = 6)
- scroll = gtk.ScrolledWindow ()
- scroll.set_policy (gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
+ self.w = Gtk.VBox (spacing = 6)
+ h = Gtk.HBox (spacing = 6)
+ scroll = Gtk.ScrolledWindow ()
+ scroll.set_policy (Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC)
- self.m = gtk.ListStore(gobject.TYPE_STRING, gobject.TYPE_PYOBJECT)
- self.v = gtk.TreeView(self.m)
+ self.m = Gtk.ListStore(GObject.TYPE_STRING, GObject.TYPE_PYOBJECT)
+ self.v = Gtk.TreeView(self.m)
self.v.set_reorderable (True)
self.v.set_headers_visible (False)
- rend = gtk.CellRendererText ()
- col = gtk.TreeViewColumn ('', rend, text=0)
+ rend = Gtk.CellRendererText ()
+ col = Gtk.TreeViewColumn ('', rend, text=0)
col.set_resizable(True)
- #col.set_sizing(gtk.TREE_VIEW_COLUMN_AUTOSIZE)
+ #col.set_sizing(Gtk.TreeViewColumnSizing.AUTOSIZE)
col.set_min_width(200)
self.v.append_column (col)
self.s = self.v.get_selection()
@@ -424,15 +423,15 @@ class ListConfig (BaseConfig):
scroll.add (self.v)
h.pack_start (scroll, True, True)
- bbox = gtk.VButtonBox ()
+ bbox = Gtk.VButtonBox ()
- button = gtk.Button (_("Add"))
+ button = Gtk.Button (_("Add"))
bbox.pack_start (button)
button.connect ('clicked', self.add_cb)
- button = gtk.Button (_("Update"))
+ button = Gtk.Button (_("Update"))
bbox.pack_start (button)
button.connect ('clicked', self.update_cb)
- button = gtk.Button (_("Remove"))
+ button = Gtk.Button (_("Remove"))
bbox.pack_start (button)
button.connect ('clicked', self.remove_cb)
@@ -514,25 +513,25 @@ class DictConfig (BaseConfig):
def __init__ (self, dtype, props, key=None, parent=None, help_text=''):
BaseConfig.__init__ (self, dtype, props, key, parent)
- self.w = gtk.VBox (spacing = 6)
- h = gtk.HBox (spacing = 6)
- scroll = gtk.ScrolledWindow ()
- scroll.set_policy (gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
-
- self.m = gtk.ListStore(gobject.TYPE_STRING,
- gobject.TYPE_STRING,
- gobject.TYPE_PYOBJECT)
- self.v = gtk.TreeView(self.m)
-
- rend = gtk.CellRendererText()
- col = gtk.TreeViewColumn('Key', rend, text=0)
+ self.w = Gtk.VBox (spacing = 6)
+ h = Gtk.HBox (spacing = 6)
+ scroll = Gtk.ScrolledWindow ()
+ scroll.set_policy (Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC)
+
+ self.m = Gtk.ListStore(GObject.TYPE_STRING,
+ GObject.TYPE_STRING,
+ GObject.TYPE_PYOBJECT)
+ self.v = Gtk.TreeView(self.m)
+
+ rend = Gtk.CellRendererText()
+ col = Gtk.TreeViewColumn('Key', rend, text=0)
col.set_resizable(True)
- #col.set_sizing(gtk.TREE_VIEW_COLUMN_AUTOSIZE)
+ #col.set_sizing(Gtk.TreeViewColumnSizing.AUTOSIZE)
col.set_min_width(100)
self.v.append_column(col)
- rend = gtk.CellRendererText()
- col = gtk.TreeViewColumn('Value', rend, text=1)
+ rend = Gtk.CellRendererText()
+ col = Gtk.TreeViewColumn('Value', rend, text=1)
self.v.append_column(col)
self.s = self.v.get_selection()
@@ -541,26 +540,26 @@ class DictConfig (BaseConfig):
scroll.add (self.v)
h.pack_start (scroll, True, True)
- bbox = gtk.VButtonBox ()
+ bbox = Gtk.VButtonBox ()
- button = gtk.Button (_("Set"))
+ button = Gtk.Button (_("Set"))
bbox.pack_start (button)
button.connect ('clicked', self.update_cb)
- button = gtk.Button (_("Remove"))
+ button = Gtk.Button (_("Remove"))
bbox.pack_start (button)
button.connect ('clicked', self.remove_cb)
h.pack_start (bbox, False, False)
self.w.pack_start (h)
- self.w.pack_start (gtk.HSeparator (), expand = False, fill = False)
+ self.w.pack_start (Gtk.HSeparator (), expand = False, fill = False)
# Bottom
- table = gtk.Table (2, 2, homogeneous = False)
+ table = Gtk.Table (2, 2, homogeneous = False)
table.set_row_spacings (6)
table.set_col_spacings (6)
- table.attach (gtk.Label (_("Key:")), 0, 1, 0, 1,
+ table.attach (Gtk.Label(label=_("Key:")), 0, 1, 0, 1,
xoptions = 0, yoptions = 0)
- table.attach (gtk.Label (_("Value:")), 0, 1, 1, 2,
+ table.attach (Gtk.Label(label=_("Value:")), 0, 1, 1, 2,
xoptions = 0, yoptions = 0)
self.keyw = dtype.key.w (dtype.key, props, parent=self)
diff --git a/Pyblio/GnomeUI/Document.py b/Pyblio/GnomeUI/Document.py
index 7ef89a3..bd29375 100644
--- a/Pyblio/GnomeUI/Document.py
+++ b/Pyblio/GnomeUI/Document.py
@@ -23,15 +23,15 @@
''' This module defines a Document class '''
-import gobject
+from gi.repository import GObject
-from gnome import ui
+# from gnome import ui
+from gettext import gettext as _
+# import gnome
+from gi.repository import Gtk
+# import Gtk.glade
-import gnome
-import gtk
-import gtk.glade
-
-from gtk import gdk
+from gi.repository import Gdk
from Pyblio.GnomeUI import Editor, Entry, FileSelector, Format
from Pyblio.GnomeUI import Index, OpenURL, Search, Utils
@@ -133,12 +133,12 @@ class Document (Connector.Publisher):
def __init__ (self, database):
- self.uim = gtk.UIManager ()
+ self.uim = Gtk.UIManager ()
self.recents = None
self.viewables = None
- self.actiongroup = gtk.ActionGroup ('Main')
+ self.actiongroup = Gtk.ActionGroup ('Main')
self.actiongroup.add_actions ([
# id stock label accel tooltip callback
@@ -150,38 +150,38 @@ class Document (Connector.Publisher):
('HelpMenu', None, _('_Help')),
('Recent', None, _('Recent documents')),
- ('New', gtk.STOCK_NEW, None, None, None, self.new_document),
- ('Open', gtk.STOCK_OPEN, None, None, _('Open a file'), self.ui_open_document),
+ ('New', Gtk.STOCK_NEW, None, None, None, self.new_document),
+ ('Open', Gtk.STOCK_OPEN, None, None, _('Open a file'), self.ui_open_document),
('Open_URL', None, _('Open _Location'), '<control>l', None, self.ui_open_location),
- ('Save', gtk.STOCK_SAVE, None, None, _('Save the current file'), self.save_document),
- ('Save_As', gtk.STOCK_SAVE_AS, None, None, None, self.save_document_as),
- ('Close', gtk.STOCK_CLOSE, None, None, None, self.close_document),
- ('Quit', gtk.STOCK_QUIT, None, None, None, self.exit_application),
+ ('Save', Gtk.STOCK_SAVE, None, None, _('Save the current file'), self.save_document),
+ ('Save_As', Gtk.STOCK_SAVE_AS, None, None, None, self.save_document_as),
+ ('Close', Gtk.STOCK_CLOSE, None, None, None, self.close_document),
+ ('Quit', Gtk.STOCK_QUIT, None, None, None, self.exit_application),
('Merge', None, _('Merge With...'), '<control>g', None, self.merge_database),
('Medline', None, _('Medline Query...'), '<control>m', None, self.query_database),
- ('Cut', gtk.STOCK_CUT, None, None, None, self.cut_entry),
- ('Copy', gtk.STOCK_COPY, None, None, None, self.copy_entry),
- ('Paste', gtk.STOCK_PASTE, None, None, None, self.paste_entry),
- ('Clear', gtk.STOCK_CLEAR, None, None, None, self.clear_entries),
- ('Add', gtk.STOCK_ADD, None, '<shift><control>n', _('Add a new entry'), self.add_entry),
- ('Edit', gtk.STOCK_EDIT, None, '<shift><control>o', None, self.edit_entry),
- ('Delete', gtk.STOCK_DELETE, None, None, None, self.delete_entry),
- ('Find', gtk.STOCK_FIND, None, None, None, self.find_entries),
+ ('Cut', Gtk.STOCK_CUT, None, None, None, self.cut_entry),
+ ('Copy', Gtk.STOCK_COPY, None, None, None, self.copy_entry),
+ ('Paste', Gtk.STOCK_PASTE, None, None, None, self.paste_entry),
+ ('Clear', Gtk.STOCK_CLEAR, None, None, None, self.clear_entries),
+ ('Add', Gtk.STOCK_ADD, None, '<shift><control>n', _('Add a new entry'), self.add_entry),
+ ('Edit', Gtk.STOCK_EDIT, None, '<shift><control>o', None, self.edit_entry),
+ ('Delete', Gtk.STOCK_DELETE, None, None, None, self.delete_entry),
+ ('Find', Gtk.STOCK_FIND, None, None, None, self.find_entries),
('Sort', None, _('S_ort...'), None, None, self.sort_entries),
- ('Cite', gtk.STOCK_JUMP_TO, _('Cite...'), None, _('Cite key(s)'), self.lyx_cite),
- ('Format', gtk.STOCK_EXECUTE, _('Format...'), None, None, self.format_entries),
+ ('Cite', Gtk.STOCK_JUMP_TO, _('Cite...'), None, _('Cite key(s)'), self.lyx_cite),
+ ('Format', Gtk.STOCK_EXECUTE, _('Format...'), None, None, self.format_entries),
('Fields', None, _('Fields...'), None, None, self.set_fields),
- ('Preferences', gtk.STOCK_PREFERENCES, None, None, None, self.set_preferences),
+ ('Preferences', Gtk.STOCK_PREFERENCES, None, None, None, self.set_preferences),
('Forget', None, _('Forget all changes'), None, None, self.forget_changes_cb),
- ('Contents', gtk.STOCK_HELP, None, None, None, self.on_documentation),
- ('About', gtk.STOCK_ABOUT, None, None, None, self.about),
+ ('Contents', Gtk.STOCK_HELP, None, None, None, self.on_documentation),
+ ('About', Gtk.STOCK_ABOUT, None, None, None, self.about),
('ViewResource', None, _('_Resource'), None, None, self.view_entry),
])
@@ -198,44 +198,48 @@ class Document (Connector.Publisher):
self.uim.ensure_update ()
- gp = os.path.join(Utils.glade_root, 'pyblio.glade')
+ gp = os.path.join(Utils.glade_root, 'pyblio.ui')
- self.xml = gtk.glade.XML (gp, 'main', domain = 'pybliographer')
- self.xml.signal_autoconnect (self)
+ self.xml = Gtk.Builder()
+ self.xml.set_translation_domain('pybliographer')
+ self.xml.add_from_file(gp)
+ self.xml.connect_signals(self)
+ #self.xml = Gtk.glade.XML (gp, 'main', domain = 'pybliographer')
+ #self.xml.signal_autoconnect (self)
- self.w = self.xml.get_widget ('main')
- self.paned = self.xml.get_widget ('main_pane')
+ self.w = self.xml.get_object ('main')
+ self.paned = self.xml.get_object ('main_pane')
- self.w.set_menus (self.uim.get_widget ('/Menubar'))
- self.w.set_toolbar (self.uim.get_widget ('/Toolbar'))
+ #self.w.set_menus (self.uim.get_object ('/Menubar'))
+ #self.w.set_toolbar (self.uim.get_object ('/Toolbar'))
self.w.add_accel_group (self.uim.get_accel_group ())
- self.w.add_events (gdk.KEY_PRESS_MASK)
+ self.w.add_events (Gdk.EventMask.KEY_PRESS_MASK)
- self.w_save_btn = self.xml.get_widget ('_w_save_btn')
- self.w_save_mnu = self.xml.get_widget ('_w_save_mnu')
+ self.w_save_btn = self.xml.get_object ('_w_save_btn')
+ self.w_save_mnu = self.xml.get_object ('_w_save_mnu')
# We manually add a simple search area
t = self.uim.get_widget ('/Toolbar')
- h = gtk.HBox()
+ h = Gtk.HBox()
- i = gtk.Image()
- i.set_from_stock(gtk.STOCK_FIND, gtk.ICON_SIZE_LARGE_TOOLBAR)
- h.pack_start(i, False, False)
+ i = Gtk.Image()
+ i.set_from_stock(Gtk.STOCK_FIND, Gtk.IconSize.LARGE_TOOLBAR)
+ h.pack_start(i, False, False, False)
# create a tooltips object
-## self.toolbartips = gtk.Tooltips()
+## self.toolbartips = Gtk.Tooltips()
- self.quick_search = gtk.Entry()
+ self.quick_search = Gtk.Entry()
self.quick_search.connect('activate', self.simple_search)
- h.pack_start(self.quick_search, False, False)
+ h.pack_start(self.quick_search, False, False, False)
## self.toolbartips.set_tip(self.quick_search, _('Quick search'))
if Config.get ('gnome/tooltips').data:
self.quick_search.set_tooltip_text (_('Quick search'))
- i = gtk.ToolItem()
+ i = Gtk.ToolItem()
i.add(h)
t.insert(i, -1)
@@ -262,7 +266,7 @@ class Document (Connector.Publisher):
self.paned.add2 (self.display.w)
# Status bar
- self.statusbar = self.xml.get_widget ('statusbar')
+ self.statusbar = self.xml.get_object ('statusbar')
# set window size
ui_width = Utils.config.get_int ('/apps/pybliographic/ui/width') or -1
@@ -341,7 +345,7 @@ class Document (Connector.Publisher):
self.uim.remove_action_group (self.recents)
self.recents_mid = []
- self.recents = gtk.ActionGroup ('Recent')
+ self.recents = Gtk.ActionGroup ('Recent')
self.uim.insert_action_group (self.recents, 1)
@@ -353,13 +357,13 @@ class Document (Connector.Publisher):
self.recents_mid.append (mid)
- action = gtk.Action (str (mid), quoted, None, None)
+ action = Gtk.Action (str (mid), quoted, None, None)
self.recents.add_action (action)
action.connect ('activate', self._history_open_cb, item)
self.uim.add_ui (mid, '/Menubar/File/Recent', str (mid),
- str (mid), gtk.UI_MANAGER_MENUITEM, False)
+ str (mid), Gtk.UIManagerItemType.MENUITEM, False)
return
@@ -453,7 +457,10 @@ class Document (Connector.Publisher):
self.actiongroup.get_action ('Save').set_property ('sensitive', self.changed)
- self.statusbar.set_default (text)
+ # FIXME: Check port to Gtk3
+ # self.statusbar.set_default (text)
+ ctx_id = self.statusbar.get_context_id('default')
+ self.statusbar.push (ctx_id, text)
return
@@ -637,7 +644,7 @@ class Document (Connector.Publisher):
# remove the old autosave object
if self.data.key is not None and self.source_id:
- gobject.source_remove (self.source_id)
+ GObject.source_remove (self.source_id)
# remove old autosave file if exists
if self.data.key:
@@ -681,7 +688,7 @@ class Document (Connector.Publisher):
# create autosave object if needed
if Config.get ('base/autosave').data:
savetimeout = Config.get ('base/autosave interval').data
- self.source_id = gobject.timeout_add (savetimeout * 60 * 1000, self.autosave, url, self.data.id)
+ self.source_id = GObject.timeout_add (savetimeout * 60 * 1000, self.autosave, url, self.data.id)
return
@@ -778,7 +785,7 @@ class Document (Connector.Publisher):
# remove the old autosave object
if self.data.key is not None and self.source_id:
- gobject.source_remove (self.source_id)
+ GObject.source_remove (self.source_id)
# remove old autosave file
if self.data.key:
@@ -820,7 +827,7 @@ class Document (Connector.Publisher):
# create the new autosave object if needed
if Config.get ('base/autosave').data:
savetimeout = Config.get ('base/autosave interval').data
- self.source_id = gobject.timeout_add (savetimeout * 60 * 1000, self.autosave, url, self.data.id)
+ self.source_id = GObject.timeout_add (savetimeout * 60 * 1000, self.autosave, url, self.data.id)
return
@@ -838,7 +845,7 @@ class Document (Connector.Publisher):
answer = self.confirm ()
# remove autosave object with closing
if answer and self.source_id:
- gobject.source_remove (self.source_id)
+ GObject.source_remove (self.source_id)
# remove old autosave file
if answer and self.data.key:
@@ -1133,7 +1140,7 @@ class Document (Connector.Publisher):
self.uim.remove_action_group (self.viewables)
self.viewables_id = []
- self.viewables = gtk.ActionGroup ('Viewables')
+ self.viewables = Gtk.ActionGroup ('Viewables')
self.uim.insert_action_group (self.viewables, 1)
viewables = Resource.get_viewables (entry)
@@ -1143,21 +1150,21 @@ class Document (Connector.Publisher):
text = u"%s %s" % (key.upper (), value)
mergeid = self.uim.new_merge_id ()
self.viewables_id.append (mergeid)
- action = gtk.Action (str(mergeid), text, None, None)
+ action = Gtk.Action (str(mergeid), text, None, None)
self.viewables.add_action (action)
action.connect ('activate', self.view_entry, (entry, key, url, value))
self.uim.add_ui (mergeid, '/Menubar/ViewMenu/ViewResource', str(mergeid),
- str(mergeid), gtk.UI_MANAGER_MENUITEM, False)
+ str(mergeid), Gtk.UIManagerItemType.MENUITEM, False)
self.uim.add_ui (mergeid, '/Popup/ViewResource', str(mergeid),
- str(mergeid), gtk.UI_MANAGER_MENUITEM, False)
+ str(mergeid), Gtk.UIManagerItemType.MENUITEM, False)
return
def key_pressed (self, app, event):
# filter out special keys
- if event.keyval == gtk.keysyms.Escape:
+ if event.keyval == Gdk.KEY_Escape:
# the Esc key restores view to "all entries"
self.limit_view (None, None)
self.quick_search.set_text('')
@@ -1198,9 +1205,9 @@ class Document (Connector.Publisher):
# Save the graphical aspect of the interface
# 1.- Window size
- alloc = self.w.get_allocation ()
- Utils.config.set_int ('/apps/pybliographic/ui/width', alloc [2])
- Utils.config.set_int ('/apps/pybliographic/ui/height', alloc [3])
+ width, height = self.w.get_size ()
+ Utils.config.set_int ('/apps/pybliographic/ui/width', width)
+ Utils.config.set_int ('/apps/pybliographic/ui/height', height)
# 2.- Proportion between list and text
height = self.paned.get_position ()
@@ -1212,13 +1219,12 @@ class Document (Connector.Publisher):
return
def on_documentation (self, *args):
- import gobject
+ from gi.repository import GObject
- timestamp = gtk.gdk.CURRENT_TIME
+ timestamp = Gdk.CURRENT_TIME
try:
- gtk.show_uri (None, "help:pybliographer", timestamp)
-
- except gobject.GError, msg:
+ Gtk.show_uri (None, "help:pybliographer", timestamp)
+ except GObject.GError, msg:
self.w.error (_("Can't display documentation:\n%s") % msg)
return
diff --git a/Pyblio/GnomeUI/Editor.py b/Pyblio/GnomeUI/Editor.py
index ccbb30a..5839e53 100644
--- a/Pyblio/GnomeUI/Editor.py
+++ b/Pyblio/GnomeUI/Editor.py
@@ -23,8 +23,12 @@
# entry editor for more than 50 chars
# added: Note taking widget
-import copy, gobject, gtk, re, string
-from gnome import ui
+from gettext import gettext as _
+
+from gi.repository import GObject, Gtk
+# import copy, gobject, gtk, re, string
+import copy, re, string
+# from gnome import ui
from Pyblio import Base, Config, Connector, Exceptions, Fields, Key, Types
from Pyblio.GnomeUI import Common, Compat, FieldsInfo, FileSelector, Mime, Utils
@@ -45,10 +49,10 @@ class BaseField(Connector.Publisher):
''' common class to each specialized field editor '''
def __init__(self, entry, field, content, j):
- self.w = gtk.VBox()
+ self.w = Gtk.VBox()
- h = gtk.HBox(spacing=5)
- self.w.pack_start(gtk.Label(field), False, False)
+ h = Gtk.HBox(spacing=5)
+ self.w.pack_start(Gtk.Label(field, True, True, 0), False, False)
field = string.lower(field)
self.field = field
@@ -57,14 +61,14 @@ class BaseField(Connector.Publisher):
self.edit = None
expand = self.create_widget(h)
- img = gtk.Image()
+ img = Gtk.Image()
if self.loss:
- img.set_from_stock(gtk.STOCK_CANCEL,
- gtk.ICON_SIZE_BUTTON)
+ img.set_from_stock(Gtk.STOCK_CANCEL,
+ Gtk.IconSize.BUTTON)
else:
- img.set_from_stock(gtk.STOCK_APPLY,
- gtk.ICON_SIZE_BUTTON)
+ img.set_from_stock(Gtk.STOCK_APPLY,
+ Gtk.IconSize.BUTTON)
h.pack_start(img, False, False)
@@ -73,17 +77,17 @@ class BaseField(Connector.Publisher):
flag = 0
if expand:
- flag = gtk.EXPAND | gtk.FILL
+ flag = Gtk.AttachOptions.EXPAND | Gtk.AttachOptions.FILL
content.attach(self.w, 0, 1, j, j + 1, yoptions=flag)
def key_handler (self, widget, ev):
- if ev.keyval == gtk.gdk.Return and \
- ev.state == gtk.gdk.CONTROL_MASK:
+ if ev.keyval == Gdk.Return and \
+ ev.state == Gdk.ModifierType.CONTROL_MASK:
widget.emit_stop_by_name ('key_press_event')
self.issue ('apply')
- elif ev.keyval == gtk.gdk.Tab and \
- ev.state == gtk.gdk.CONTROL_MASK:
+ elif ev.keyval == Gdk.Tab and \
+ ev.state == Gdk.ModifierType.CONTROL_MASK:
widget.emit_stop_by_name ('key_press_event')
self.issue ('next')
@@ -144,7 +148,7 @@ class Entry (TextBase):
def create_widget (self, h):
if len (self.string) < 50:
- self.edit = gtk.Entry ()
+ self.edit = Gtk.Entry ()
self.edit.set_text(self.string.decode('latin-1'))
self.edit.set_editable (True)
self.edit.show ()
@@ -154,13 +158,13 @@ class Entry (TextBase):
h.pack_start (self.edit)
return 0
- w = gtk.ScrolledWindow ()
- w.set_policy (gtk.POLICY_NEVER,
- gtk.POLICY_AUTOMATIC)
+ w = Gtk.ScrolledWindow ()
+ w.set_policy (Gtk.PolicyType.NEVER,
+ Gtk.PolicyType.AUTOMATIC)
- self.edit = gtk.TextView ()
+ self.edit = Gtk.TextView ()
self.edit.set_editable (True)
- self.edit.set_wrap_mode (gtk.WRAP_WORD)
+ self.edit.set_wrap_mode (Gtk.WrapMode.WORD)
self.buff = self.edit.get_buffer ()
self.buff.set_text(self.string.decode('latin-1'))
@@ -196,12 +200,12 @@ class Entry (TextBase):
class Text (TextBase):
def create_widget (self, h):
- w = gtk.ScrolledWindow ()
- w.set_policy (gtk.POLICY_NEVER,
- gtk.POLICY_AUTOMATIC)
- self.edit = gtk.TextView ()
+ w = Gtk.ScrolledWindow ()
+ w.set_policy (Gtk.PolicyType.NEVER,
+ Gtk.PolicyType.AUTOMATIC)
+ self.edit = Gtk.TextView ()
self.edit.set_editable (True)
- self.edit.set_wrap_mode (gtk.WRAP_WORD)
+ self.edit.set_wrap_mode (Gtk.WrapMode.WORD)
self.buff = self.edit.get_buffer ()
self.buff.set_text (self.string.decode('latin-1'))
@@ -231,11 +235,11 @@ class Text (TextBase):
class AuthorGroup (BaseField):
def create_widget (self, h):
- w = gtk.ScrolledWindow ()
- w.set_policy (gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
+ w = Gtk.ScrolledWindow ()
+ w.set_policy (Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC)
- self.edit = gtk.TextView ()
- self.edit.set_wrap_mode (gtk.WRAP_WORD)
+ self.edit = Gtk.TextView ()
+ self.edit.set_wrap_mode (Gtk.WrapMode.WORD)
self.edit.set_editable (True)
self.buff = self.edit.get_buffer ()
@@ -299,9 +303,9 @@ class AuthorGroup (BaseField):
class Date (BaseField):
def create_widget (self, h):
- hbox = gtk.HBox (False, 5)
+ hbox = Gtk.HBox (False, 5)
- self.day = gtk.Entry ()
+ self.day = Gtk.Entry ()
(width, height) = self.day.size_request ()
self.day.set_size_request (width / 4, height)
self.day.set_max_length (2)
@@ -309,25 +313,25 @@ class Date (BaseField):
if self.initial [0]:
self.day.set_text (str (self.initial [0]).decode ('latin-1'))
hbox.pack_start (self.day)
- hbox.pack_start (gtk.Label (_("Day")), False, False)
+ hbox.pack_start (Gtk.Label(label=_("Day")), False, False)
- self.month = gtk.Entry ()
+ self.month = Gtk.Entry ()
self.month.set_size_request (width / 4, height)
self.month.set_max_length (2)
if self.initial [1]:
self.month.set_text (str (self.initial [1]).decode ('latin-1'))
hbox.pack_start (self.month)
- hbox.pack_start (gtk.Label (_("Month")), False, False)
+ hbox.pack_start (Gtk.Label(label=_("Month")), False, False)
- self.year = gtk.Entry ()
+ self.year = Gtk.Entry ()
self.year.set_max_length (4)
self.year.set_size_request (width / 3, height)
if self.initial [2]:
self.year.set_text (str (self.initial [2]).decode ('latin-1'))
hbox.pack_start (self.year)
- hbox.pack_start (gtk.Label (_("Year")), False, False)
+ hbox.pack_start (Gtk.Label(label=_("Year")), False, False)
hbox.show_all ()
h.pack_start (hbox)
@@ -394,10 +398,10 @@ class Reference (BaseField):
(Mime.SYM_KEY, 0, Mime.KEY),
)
- box = gtk.HBox ()
+ box = Gtk.HBox ()
box.set_border_width (5)
- self.edit = gtk.Label ()
+ self.edit = Gtk.Label ()
self.edit.justify = False
self.edit.set_line_wrap (True)
@@ -406,9 +410,9 @@ class Reference (BaseField):
#self.edit.set_editable (True)
self.edit.set_text (self.string)
- self.edit.drag_dest_set (gtk.DEST_DEFAULT_ALL,
+ self.edit.drag_dest_set (Gtk.DestDefaults.ALL,
accept,
- gtk.gdk.ACTION_COPY)
+ Gdk.DragAction.COPY)
self.edit.connect ('drag_data_received', self.drag_received)
@@ -416,7 +420,7 @@ class Reference (BaseField):
h.pack_start (box)
# A delete button
- button = gtk.Button (_('Delete'), gtk.STOCK_DELETE)
+ button = Gtk.Button (_('Delete'), Gtk.STOCK_DELETE)
button.connect ('clicked', self._delete)
h.pack_start (button, False, False)
@@ -493,13 +497,13 @@ class URL (BaseField):
## h.pack_start (self.edit)
self.newurl = None
- self.box = gtk.HBox (spacing=6)
- self.edit = gtk.Entry ()
+ self.box = Gtk.HBox (spacing=6)
+ self.edit = Gtk.Entry ()
self.edit.set_editable (True)
self.old_url = self.string.decode ('latin-1')
self.edit.set_text (self.old_url)
self.box.pack_start (self.edit)
- self.button = gtk.Button (_('Browse...'))
+ self.button = Gtk.Button (_('Browse...'))
self.button.connect ("clicked", self.cb_clicked)
self.box.pack_start (self.button, False)
h.pack_start (self.box)
@@ -541,17 +545,17 @@ class RealEditor (Connector.Publisher):
self.fields.sort ()
- self.w = gtk.VBox ()
- table = gtk.Table (2, 2)
+ self.w = Gtk.VBox ()
+ table = Gtk.Table (2, 2)
table.set_border_width (5)
table.set_col_spacings (5)
- table.attach (gtk.Label (_("Entry type")),
+ table.attach (Gtk.Label(label=_("Entry type")),
0, 1, 0, 1, yoptions = 0)
- table.attach (gtk.Label (_("Key")),
+ table.attach (Gtk.Label(label=_("Key")),
1, 2, 0, 1, yoptions = 0)
- self.key = gtk.Entry ()
+ self.key = Gtk.Entry ()
self.key.set_editable (True)
if self.entry.key:
@@ -562,12 +566,12 @@ class RealEditor (Connector.Publisher):
# The list store will hold both the identifier and the type of
# each entry
- liststore = gtk.ListStore (gobject.TYPE_STRING,
- gobject.TYPE_PYOBJECT)
+ liststore = Gtk.ListStore (GObject.TYPE_STRING,
+ GObject.TYPE_PYOBJECT)
- self.menu = gtk.ComboBox (liststore)
+ self.menu = Gtk.ComboBox (liststore)
- cell = gtk.CellRendererText()
+ cell = Gtk.CellRendererText()
self.menu.pack_start (cell, True)
self.menu.add_attribute (cell, 'text', 0)
@@ -591,21 +595,21 @@ class RealEditor (Connector.Publisher):
table.show_all ()
self.w.pack_start (table, False, False)
- self.newfield_area = gtk.HBox (spacing = 5)
+ self.newfield_area = Gtk.HBox (spacing = 5)
self.newfield_area.set_border_width (5)
self.newfield = ui.Entry ('newfield')
self.newfield_area.pack_start (self.newfield)
- b = gtk.Button (_("Create Field"))
+ b = Gtk.Button (_("Create Field"))
b.connect ('clicked', self.create_field)
self.newfield_area.pack_start (b)
# navigation buttons
- self.backward_b = gtk.Button(_('Back'))
+ self.backward_b = Gtk.Button(_('Back'))
self.backward_b.connect ('clicked', self.back_cb)
self.newfield_area.pack_start (self.backward_b)
- self.forward_b = gtk.Button(_('Next'))
+ self.forward_b = Gtk.Button(_('Next'))
self.forward_b.connect ('clicked', self.next_cb)
self.newfield_area.pack_start (self.forward_b)
@@ -614,7 +618,7 @@ class RealEditor (Connector.Publisher):
self.newfield_area.show_all ()
# Notebook
- self.notebook = gtk.Notebook ()
+ self.notebook = Gtk.Notebook ()
self.notebook.show ()
self.notebook.connect ('switch-page', self.switch_page_cb)
@@ -673,15 +677,15 @@ class RealEditor (Connector.Publisher):
node = self.lt_nodes [self.lt_current]
key = node['key']
if self.entry.has_key(key) and self.entry[key]:
- dialog = gtk.MessageDialog(
- self.w.get_toplevel(), gtk.DIALOG_DESTROY_WITH_PARENT,
- gtk.MESSAGE_WARNING, gtk.BUTTONS_OK_CANCEL,
+ dialog = Gtk.MessageDialog(
+ self.w.get_toplevel(), Gtk.DialogFlags.DESTROY_WITH_PARENT,
+ Gtk.MessageType.WARNING, Gtk.ButtonsType.OK_CANCEL,
"Text will be lost if you click OK.")
dialog.set_transient_for (self.dialogue.w)
rc = dialog.run()
dialog.destroy()
- if rc == gtk.RESPONSE_CANCEL:
+ if rc == Gtk.ResponseType.CANCEL:
return
self.lt_delete (self.lt_current)
@@ -732,7 +736,7 @@ class RealEditor (Connector.Publisher):
self.content = []
for i in range (len(names)):
- label = gtk.Label (names [i])
+ label = Gtk.Label(label=names [i])
if i == 0:
table = [x.name.lower() for x
in self.entry.type.mandatory
@@ -767,10 +771,10 @@ class RealEditor (Connector.Publisher):
def add_type1_widget (self, label, table, pos):
if len (table) == 0: return
- scroll = gtk.ScrolledWindow ()
- scroll.set_policy (gtk.POLICY_AUTOMATIC,
- gtk.POLICY_AUTOMATIC)
- content = gtk.Table (1, len (table))
+ scroll = Gtk.ScrolledWindow ()
+ scroll.set_policy (Gtk.PolicyType.AUTOMATIC,
+ Gtk.PolicyType.AUTOMATIC)
+ content = Gtk.Table (1, len (table))
scroll.add_with_viewport (content)
j = 0
@@ -963,12 +967,12 @@ class NativeEditor(Connector.Publisher):
self.original = database.get_native(entry)
- self.w = gtk.ScrolledWindow()
- self.w.set_policy(gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
+ self.w = Gtk.ScrolledWindow()
+ self.w.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC)
- self.w_txt = gtk.TextView()
+ self.w_txt = Gtk.TextView()
self.w_txt.set_editable(True)
- self.w_txt.set_wrap_mode(gtk.WRAP_WORD)
+ self.w_txt.set_wrap_mode(Gtk.WrapMode.WORD)
self.w.add(self.w_txt)
@@ -1015,7 +1019,7 @@ class Editor(Connector.Publisher):
with no key.
"""
def __init__(self, database, entry, parent=None, title=None):
- self.w = gtk.Dialog()
+ self.w = Gtk.Dialog()
self.w.set_resizable(True)
if title: self.w.set_title(title)
@@ -1026,7 +1030,7 @@ class Editor(Connector.Publisher):
if parent: self.w.set_transient_for(parent)
- self.apply_b = gtk.Button(stock=gtk.STOCK_APPLY)
+ self.apply_b = Gtk.Button(stock=Gtk.STOCK_APPLY)
self.apply_b.connect('clicked', self.apply_changes)
self.apply_b.show()
@@ -1034,31 +1038,31 @@ class Editor(Connector.Publisher):
self.has_native = hasattr(database, 'get_native')
if self.has_native:
- self.native_b = gtk.Button(_("Native Editing"))
+ self.native_b = Gtk.Button(_("Native Editing"))
self.native_b.connect('clicked', self.toggle_native)
self.native_b.show()
- self.close_b = gtk.Button(stock=gtk.STOCK_CANCEL)
+ self.close_b = Gtk.Button(stock=Gtk.STOCK_CANCEL)
self.close_bid = self.close_b.connect(
'clicked', self.close_dialog)
self.close_b.show()
# Use Escape to abort, Ctrl-Return to accept
- accelerator = gtk.AccelGroup()
+ accelerator = Gtk.AccelGroup()
self.w.add_accel_group(accelerator)
self.close_b.add_accelerator(
- 'clicked', accelerator, gtk.keysyms.Escape, 0, 0)
+ 'clicked', accelerator, Gdk.KEY_Escape, 0, 0)
self.apply_b.add_accelerator(
- 'clicked', accelerator, gtk.keysyms.Return,
- gtk.gdk.CONTROL_MASK, 0)
+ 'clicked', accelerator, Gdk.KEY_Return,
+ Gdk.ModifierType.CONTROL_MASK, 0)
# for use with annotations
- self.del_b = gtk.Button(stock=gtk.STOCK_DELETE)
+ self.del_b = Gtk.Button(stock=Gtk.STOCK_DELETE)
self.del_b.connect ('clicked', self.del_cb, None)
self.del_b.set_sensitive(False)
self.w.action_area.add(self.del_b)
- self.new_b = gtk.Button(stock=gtk.STOCK_NEW)
+ self.new_b = Gtk.Button(stock=Gtk.STOCK_NEW)
self.new_b.connect('clicked', self.add_cb, None)
self.new_b.set_sensitive(False)
self.w.action_area.add(self.new_b)
@@ -1133,7 +1137,7 @@ class Editor(Connector.Publisher):
self.editor.Subscribe('apply', self.apply_changes)
self.editor.Subscribe('next', self.next_item)
- self.w.vbox.pack_start(self.editor.w)
+ self.w.vbox.pack_start(self.editor.w, True, True, 0)
# set window size
if ui_width != -1 and ui_height != -1:
@@ -1203,10 +1207,10 @@ class LT_Widget_1:
self.dialogue = dialogue
self.node = None
- self.page = gtk.ScrolledWindow ()
- self.label = gtk.Label (_('Notes'))
- self.page.set_policy (gtk.POLICY_AUTOMATIC,
- gtk.POLICY_AUTOMATIC)
+ self.page = Gtk.ScrolledWindow ()
+ self.label = Gtk.Label(label=_('Notes'))
+ self.page.set_policy (Gtk.PolicyType.AUTOMATIC,
+ Gtk.PolicyType.AUTOMATIC)
self.display_list (self.entry, self.editor.lt_nodes)
self.page.set_data ('pyblio-owner', self)
@@ -1217,12 +1221,12 @@ class LT_Widget_1:
#self.enable_buttons()
def display_list (self, entry, nodes):
- content = gtk.VBox()
+ content = Gtk.VBox()
for i in range (len(nodes)):
node = nodes[i]
key = node['key']
- vbox = gtk.VBox()
- anno_label = gtk.Label()
+ vbox = Gtk.VBox()
+ anno_label = Gtk.Label()
anno_label.set_alignment (0, 0.5)
if node.get('mandatory', False):
l = '<b>%s</b> <span color="red">%s</span>' %(
@@ -1236,12 +1240,12 @@ class LT_Widget_1:
else: t = ''
l = min (len(t), 150)
- text_label = gtk.Label(t[0:l])
+ text_label = Gtk.Label(label=t[0:l])
text_label.set_line_wrap (True)
text_label.set_size_request ( 500, 45) ## XXX
text_label.set_alignment (0.1, .2)
vbox.pack_start (text_label)
- ebox = gtk.Button()
+ ebox = Gtk.Button()
ebox.add (vbox)
ebox.connect ('clicked', self.lt_select_detail, i)
content.pack_start(ebox, False, False)
@@ -1273,16 +1277,16 @@ class LT_Widget_2:
self.position = position + 1
self.dialogue = dialogue
self.node = None
- self.page = gtk.ScrolledWindow()
- self.page.set_policy (gtk.POLICY_AUTOMATIC,
- gtk.POLICY_AUTOMATIC)
- self.buff = gtk.TextBuffer()
- self.content = gtk.TextView(self.buff)
- self.label = gtk.Label()
+ self.page = Gtk.ScrolledWindow()
+ self.page.set_policy (Gtk.PolicyType.AUTOMATIC,
+ Gtk.PolicyType.AUTOMATIC)
+ self.buff = Gtk.TextBuffer()
+ self.content = Gtk.TextView(self.buff)
+ self.label = Gtk.Label()
self.page.add(self.content)
self.content.grab_focus()
self.page.set_data ('pyblio-owner', self)
- self.content.set_wrap_mode (gtk.WRAP_WORD)
+ self.content.set_wrap_mode (Gtk.WrapMode.WORD)
self.buff.connect('changed', self.changed_cb)
self.hidden = True
@@ -1343,17 +1347,17 @@ class LT_Widget_2:
class LT_Dialog_1 :
def __init__ (self, parent=None):
- self.dialog = gtk.Dialog(
+ self.dialog = Gtk.Dialog(
_('New Annotation Name'), parent, 0,
- (gtk.STOCK_OK, gtk.RESPONSE_ACCEPT,
- gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT))
+ (Gtk.STOCK_OK, Gtk.ResponseType.ACCEPT,
+ Gtk.STOCK_CANCEL, Gtk.ResponseType.REJECT))
self.dialog.vbox.set_border_width (24)
self.dialog.vbox. pack_start (
- gtk.Label (
+ Gtk.Label(label=
_('Name of the new annotation:')),
True, True, 6)
- self.options = gtk.combo_box_new_text ()
+ self.options = Gtk.ComboBoxText ()
self.dialog.vbox.pack_start (self.options, True, True, 12)
self.fields = [ x for x in Config.get ('base/fields').data
@@ -1364,7 +1368,7 @@ class LT_Dialog_1 :
self.options.set_active (0)
self.options.connect ('changed', self.changed)
- self.dialog.set_default_response(gtk.RESPONSE_ACCEPT)
+ self.dialog.set_default_response(Gtk.ResponseType.ACCEPT)
self.value = self.fields[0]
def changed (self, *args):
@@ -1374,7 +1378,7 @@ class LT_Dialog_1 :
def run (self):
self.dialog.show_all()
r = self.dialog.run()
- if r == gtk.RESPONSE_ACCEPT:
+ if r == Gtk.ResponseType.ACCEPT:
name= self.value
else:
name = None
diff --git a/Pyblio/GnomeUI/Entry.py b/Pyblio/GnomeUI/Entry.py
index c9d75a6..967c6c6 100644
--- a/Pyblio/GnomeUI/Entry.py
+++ b/Pyblio/GnomeUI/Entry.py
@@ -19,10 +19,7 @@
#
#
-from gtk import *
-from gnome import ui
-
-import pango, gnome, gobject
+from gi.repository import Gdk, Gtk, Pango, GObject
import string
@@ -36,29 +33,29 @@ class Entry:
def __init__ (self):
''' Create the graphical widget '''
- self.text = TextView ()
+ self.text = Gtk.TextView ()
self.buff = self.text.get_buffer ()
self.tag = {}
self.tag ['title'] = \
self.buff.create_tag ('title',
- weight = pango.WEIGHT_BOLD)
+ weight = Pango.Weight.BOLD)
self.tag ['field'] = \
self.buff.create_tag ('field',
indent = -20,
- style = pango.STYLE_OBLIQUE)
+ style = Pango.Style.OBLIQUE)
self.tag ['body'] = \
self.buff.create_tag ('body',
left_margin = 20)
- self.w = ScrolledWindow ()
- self.w.set_policy (POLICY_AUTOMATIC, POLICY_AUTOMATIC)
+ self.w = Gtk.ScrolledWindow ()
+ self.w.set_policy (Gtk.PolicyType.AUTOMATIC, Gtk.PolicyType.AUTOMATIC)
self.w.add (self.text)
self.text.set_editable (False)
self.text.set_cursor_visible (False)
- self.text.set_wrap_mode (WRAP_WORD)
+ self.text.set_wrap_mode (Gtk.WrapMode.WORD)
self.text.set_left_margin (5)
self.text.set_right_margin (5)
@@ -97,14 +94,14 @@ class Entry:
anchor = self.buff.create_child_anchor (iter)
- button = Button ('...')
+ button = Gtk.Button ('...')
button.show ()
def url_open (w, url):
try:
- gnome.url_show (url)
+ Gtk.show_uri(None, url, Gdk.CURRENT_TIME)
- except gobject.GError, msg:
+ except GObject.GError, msg:
d = MessageDialog (None,
DIALOG_MODAL |
diff --git a/Pyblio/GnomeUI/Fields.py b/Pyblio/GnomeUI/Fields.py
index b8c5ec3..dae002e 100644
--- a/Pyblio/GnomeUI/Fields.py
+++ b/Pyblio/GnomeUI/Fields.py
@@ -27,7 +27,7 @@ bibliography '''
# cleaning up
-import gobject, gtk
+from gi.repository import GObject, Gtk
import copy, os, re, string
@@ -60,7 +60,7 @@ class FieldsDialog (Utils.GladeWindow):
self.dialog = self.xml.get_widget ('fields1')
self.w = self.xml.get_widget ('notebook')
-## tooltips = gtk.Tooltips ()
+## tooltips = Gtk.Tooltips ()
## tooltips.enable ()
self.warning = 0
@@ -120,17 +120,17 @@ class FieldsDialog (Utils.GladeWindow):
def init_page_1 (self):
self.fields1 = self.xml.get_widget('f_list_1')
- rend = gtk.CellRendererText()
- col = gtk.TreeViewColumn(_('Name'), rend, text = 0)
+ rend = Gtk.CellRendererText()
+ col = Gtk.TreeViewColumn(_('Name'), rend, text = 0)
self.fields1.append_column(col)
- rend = gtk.CellRendererText()
- col = gtk.TreeViewColumn(_('Type'), rend, text = 1)
+ rend = Gtk.CellRendererText()
+ col = Gtk.TreeViewColumn(_('Type'), rend, text = 1)
self.fields1.append_column(col)
- self.fm = gtk.ListStore(gobject.TYPE_STRING, gobject.TYPE_STRING,
- gobject.TYPE_STRING, gobject.TYPE_PYOBJECT)
- self.sfm = gtk.TreeModelSort(self.fm)
- self.sfm.set_sort_column_id(2, gtk.SORT_ASCENDING)
+ self.fm = Gtk.ListStore(GObject.TYPE_STRING, GObject.TYPE_STRING,
+ GObject.TYPE_STRING, GObject.TYPE_PYOBJECT)
+ self.sfm = Gtk.TreeModelSort(self.fm)
+ self.sfm.set_sort_column_id(2, Gtk.SortType.ASCENDING)
self.fields1.set_model(self.sfm)
self.s1 = self.fields1.get_selection()
self.s1.connect ('changed', self.list_1_select)
@@ -141,7 +141,7 @@ class FieldsDialog (Utils.GladeWindow):
self.name1 = self.xml.get_widget('name1')
self.menu1 = self.xml.get_widget('type1')
- menu = gtk.Menu ()
+ menu = Gtk.Menu ()
self.menu1.set_menu (menu)
self.menu_items = _typename.keys ()
for item in self.menu_items:
@@ -223,17 +223,17 @@ class FieldsDialog (Utils.GladeWindow):
# PAGE 2
self.entries2 = self.xml.get_widget('e_list_2')
- self.em = gtk.ListStore(gobject.TYPE_STRING,
- gobject.TYPE_PYOBJECT,
- gobject.TYPE_STRING )
+ self.em = Gtk.ListStore(GObject.TYPE_STRING,
+ GObject.TYPE_PYOBJECT,
+ GObject.TYPE_STRING )
self.entries = copy.copy (Config.get ('base/entries').data)
for i in self.entries.itervalues():
self.em.append ((i.name, i, i.name.lower()))
- self.sem = gtk.TreeModelSort(self.em)
- self.sem.set_sort_column_id(2, gtk.SORT_ASCENDING)
+ self.sem = Gtk.TreeModelSort(self.em)
+ self.sem.set_sort_column_id(2, Gtk.SortType.ASCENDING)
self.entries2.set_model(self.sem)
- rend = gtk.CellRendererText()
- col = gtk.TreeViewColumn(_('Entry type'), rend, text = 0)
+ rend = Gtk.CellRendererText()
+ col = Gtk.TreeViewColumn(_('Entry type'), rend, text = 0)
self.entries2.append_column(col)
self.name2 = self.xml.get_widget('name2')
self.s2 = self.entries2.get_selection()
@@ -296,25 +296,25 @@ class FieldsDialog (Utils.GladeWindow):
self.flist3a = self.xml.get_widget ('f_list_3a')
self.flist3a.set_model (self.sfm)
- rend = gtk.CellRendererText()
- col = gtk.TreeViewColumn(_('Available'), rend, text = 0)
+ rend = Gtk.CellRendererText()
+ col = Gtk.TreeViewColumn(_('Available'), rend, text = 0)
self.flist3a.append_column(col)
self.s3a = self.flist3a.get_selection()
self.label3 = self.xml.get_widget ('entry_type_label')
self.flist3b = self.xml.get_widget ('f_list_3b')
- rend = gtk.CellRendererToggle()
+ rend = Gtk.CellRendererToggle()
rend.connect('toggled', self.toggle_mandatory)
- col = gtk.TreeViewColumn('X', rend, active = 1)
+ col = Gtk.TreeViewColumn('X', rend, active = 1)
self.flist3b.append_column(col)
- rend = gtk.CellRendererText()
- col = gtk.TreeViewColumn(_('Associated'), rend, text = 2)
+ rend = Gtk.CellRendererText()
+ col = Gtk.TreeViewColumn(_('Associated'), rend, text = 2)
self.flist3b.append_column(col)
- self.sm = gtk.ListStore(gobject.TYPE_STRING,
- gobject.TYPE_BOOLEAN,
- gobject.TYPE_STRING,
- gobject.TYPE_PYOBJECT)
- self.ssm = gtk.TreeModelSort(self.sm)
- self.ssm.set_sort_column_id(0, gtk.SORT_ASCENDING)
+ self.sm = Gtk.ListStore(GObject.TYPE_STRING,
+ GObject.TYPE_BOOLEAN,
+ GObject.TYPE_STRING,
+ GObject.TYPE_PYOBJECT)
+ self.ssm = Gtk.TreeModelSort(self.sm)
+ self.ssm.set_sort_column_id(0, Gtk.SortType.ASCENDING)
self.flist3b.set_model(self.ssm)
self.s3b = self.flist3b.get_selection()
self.label3.set_markup (
diff --git a/Pyblio/GnomeUI/FileSelector.py b/Pyblio/GnomeUI/FileSelector.py
index 6cd7310..c4f096d 100644
--- a/Pyblio/GnomeUI/FileSelector.py
+++ b/Pyblio/GnomeUI/FileSelector.py
@@ -20,17 +20,17 @@
#
import string, os, urlparse
+import gettext
+_ = gettext.gettext
-from gnome import ui
-
-import gtk
+from gi.repository import Gtk, GObject, Gdk
from Pyblio import Open, Types, Base, Fields, Config, Autoload
from Pyblio.GnomeUI import Utils
-class URLFileSelection (gtk.FileChooserDialog):
+class URLFileSelection (Gtk.FileChooserDialog):
''' Extended file selection dialog, with an URL field and a type
selector. '''
@@ -40,19 +40,19 @@ class URLFileSelection (gtk.FileChooserDialog):
modal = True, has_auto = True, is_save = False,
directory = None, show_type=True):
- gtk.FileChooserDialog.__init__ (self)
+ GObject.GObject.__init__ (self)
- accelerator = gtk.AccelGroup ()
+ accelerator = Gtk.AccelGroup ()
self.add_accel_group (accelerator)
- b = self.add_button (gtk.STOCK_OK, gtk.RESPONSE_OK)
- b.add_accelerator ('clicked', accelerator, gtk.keysyms.Return, 0, 0)
+ b = self.add_button (Gtk.STOCK_OK, Gtk.ResponseType.OK)
+ b.add_accelerator ('clicked', accelerator, Gdk.KEY_Return, 0, 0)
- b = self.add_button (gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT)
- b.add_accelerator ('clicked', accelerator, gtk.keysyms.Escape, 0, 0)
+ b = self.add_button (Gtk.STOCK_CANCEL, Gtk.ResponseType.REJECT)
+ b.add_accelerator ('clicked', accelerator, Gdk.KEY_Escape, 0, 0)
if is_save:
- self.set_action(gtk.FILE_CHOOSER_ACTION_SAVE)
+ self.set_action(Gtk.FileChooserAction.SAVE)
self.set_local_only (False)
@@ -70,15 +70,15 @@ class URLFileSelection (gtk.FileChooserDialog):
if show_type:
# type selector
- hbox = gtk.HBox ()
+ hbox = Gtk.HBox ()
hbox.set_spacing (5)
hbox.set_border_width (5)
- hbox.pack_start (gtk.Label (_("Bibliography type:")),
- expand = False, fill = False)
+ hbox.pack_start (Gtk.Label(label=_("Bibliography type:")),
+ expand=False, fill=False, padding=False)
- self.menu = gtk.combo_box_new_text ()
+ self.menu = Gtk.ComboBoxText ()
- hbox.pack_start (self.menu)
+ hbox.pack_start (self.menu, False, False, False)
self.set_extra_widget (hbox)
@@ -115,12 +115,12 @@ class URLFileSelection (gtk.FileChooserDialog):
def run (self):
- ret = gtk.FileSelection.run (self)
+ ret = Gtk.FileChooserDialog.run (self)
file = self.get_filename ()
self.destroy ()
- if ret != gtk.RESPONSE_OK: return (None, None)
+ if ret != Gtk.ResponseType.OK: return (None, None)
URLFileSelection.defaultdir = os.path.dirname (file)
diff --git a/Pyblio/GnomeUI/Format.py b/Pyblio/GnomeUI/Format.py
index e1831a5..0f2797f 100644
--- a/Pyblio/GnomeUI/Format.py
+++ b/Pyblio/GnomeUI/Format.py
@@ -21,8 +21,8 @@
''' Defines a Dialog to format a subset of entries as a bibliography '''
-import gtk
-from gnome import ui
+from gi.repository import Gtk
+# from gnome import ui
import string, os
@@ -52,7 +52,7 @@ class FormatDialog (Connector.Publisher, Utils.GladeWindow):
Utils.GladeWindow.__init__ (self, parent)
# Fill the output format drop-down menu
- menu = gtk.Menu ()
+ menu = Gtk.Menu ()
self._w_menu.set_menu (menu)
outlist = Autoload.available ('output')
diff --git a/Pyblio/GnomeUI/Index.py b/Pyblio/GnomeUI/Index.py
index e9942b6..1b790dd 100644
--- a/Pyblio/GnomeUI/Index.py
+++ b/Pyblio/GnomeUI/Index.py
@@ -33,8 +33,9 @@
from Pyblio import Config, Connector, Fields, Resource
from Pyblio import Types, Sort, userformat, version
-from gnome import ui
-import gobject, gtk, gtk.gdk, os.path, pango
+from gi.repository import GObject, Gtk, Gdk, GdkPixbuf, Pango
+
+import os.path
from Pyblio.GnomeUI import FieldsInfo, Mime, Utils
@@ -62,20 +63,20 @@ class Index (Connector.Publisher):
fields = fields or Config.get ('gnome/columns').data
self.fields = map (lower, fields)
- self.model = apply (gtk.ListStore,
- (gobject.TYPE_STRING,) * len (fields) + (gobject.TYPE_OBJECT,))
+ self.model = apply (Gtk.ListStore,
+ (GObject.TYPE_STRING,) * len (fields) + (GObject.TYPE_OBJECT,))
- self.list = gtk.TreeView ()
+ self.list = Gtk.TreeView ()
self.list.set_model (self.model)
self.selinfo = self.list.get_selection ()
- self.selinfo.set_mode (gtk.SELECTION_MULTIPLE)
+ self.selinfo.set_mode (Gtk.SelectionMode.MULTIPLE)
i = 0
- self.gvpixbuf = gtk.gdk.pixbuf_new_from_file(
+ self.gvpixbuf = GdkPixbuf.Pixbuf.new_from_file(
os.path.join (version.pybdir, 'pixmaps', 'pybliographic-viewer.png'))
if True:
- rend = gtk.CellRendererPixbuf ()
- col = gtk.TreeViewColumn ('P', rend, pixbuf = len(fields))
+ rend = Gtk.CellRendererPixbuf ()
+ col = Gtk.TreeViewColumn ('P', rend, pixbuf = len(fields))
col.set_fixed_width (22)
self.list.append_column (col)
i += 1
@@ -83,9 +84,9 @@ class Index (Connector.Publisher):
i, self.prefix_columns = 0, i
for f in fields:
- renderer = gtk.CellRendererText ()
- renderer.set_property ('ellipsize', pango.ELLIPSIZE_END)
- col = gtk.TreeViewColumn (f, renderer, text=i)
+ renderer = Gtk.CellRendererText ()
+ renderer.set_property ('ellipsize', Pango.EllipsizeMode.END)
+ col = Gtk.TreeViewColumn (f, renderer, text=i)
col.set_resizable (True)
col.set_clickable (True)
@@ -97,16 +98,16 @@ class Index (Connector.Publisher):
w = Utils.config.get_int (k)
if w:
- col.set_sizing (gtk.TREE_VIEW_COLUMN_FIXED)
+ col.set_sizing (Gtk.TreeViewColumnSizing.FIXED)
col.set_fixed_width (w)
col.connect ('clicked', self.click_column, i)
self.list.append_column (col)
i = i + 1
- self.w = gtk.ScrolledWindow ()
+ self.w = Gtk.ScrolledWindow ()
- self.w.set_policy (gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC)
+ self.w.set_policy (Gtk.PolicyType.AUTOMATIC, Gtk.PolicyType.AUTOMATIC)
self.w.add (self.list)
self.access = []
@@ -130,14 +131,15 @@ class Index (Connector.Publisher):
(Mime.SYM_ENTRY, 0, Mime.ENTRY),
)
- self.list.drag_dest_set (gtk.DEST_DEFAULT_ALL, accept,
- gtk.gdk.ACTION_COPY | gtk.gdk.ACTION_MOVE)
- self.list.connect ("drag_data_received", self.drag_received)
+ # FIXME: Port drag-and-drop to Gtk3
+ #self.list.drag_dest_set (Gtk.DestDefaults.ALL, accept,
+ # Gdk.DragAction.COPY | Gdk.DragAction.MOVE)
+ #self.list.connect ("drag_data_received", self.drag_received)
- self.list.drag_source_set (gtk.gdk.BUTTON1_MASK | gtk.gdk.BUTTON3_MASK,
- targets, gtk.gdk.ACTION_COPY | gtk.gdk.ACTION_MOVE)
- self.list.connect ('drag_data_get', self.dnd_drag_data_get)
+ #self.list.drag_source_set (Gdk.ModifierType.BUTTON1_MASK | Gdk.ModifierType.BUTTON3_MASK,
+ # targets, Gdk.DragAction.COPY | Gdk.DragAction.MOVE)
+ #self.list.connect ('drag_data_get', self.dnd_drag_data_get)
# Copy/Paste configuration
@@ -151,17 +153,18 @@ class Index (Connector.Publisher):
# the clipboard, and the primary. Therefore, we should be able
# to paste into every kind of editor/application.
- self.list.selection_add_target ("PRIMARY",
- Mime.SYM_STRING,
- Mime.STRING)
+ # FIXME: Port to Gtk3
+ #self.list.selection_add_target ("PRIMARY",
+ # Mime.SYM_STRING,
+ # Mime.STRING)
- self.list.selection_add_target ("CLIPBOARD",
- Mime.SYM_STRING,
- Mime.STRING)
+ #self.list.selection_add_target ("CLIPBOARD",
+ # Mime.SYM_STRING,
+ # Mime.STRING)
- self.list.selection_add_target (Mime.SYM_APP,
- Mime.SYM_ENTRY,
- Mime.ENTRY)
+ #self.list.selection_add_target (Mime.SYM_APP,
+ # Mime.SYM_ENTRY,
+ # Mime.ENTRY)
return
@@ -267,7 +270,7 @@ class Index (Connector.Publisher):
else:
return
- if context.action == gtk.gdk.ACTION_MOVE:
+ if context.action == Gdk.DragAction.MOVE:
self.issue ('drag-moved', entries)
return
@@ -368,9 +371,11 @@ class Index (Connector.Publisher):
iter = self.model.append ()
- apply (self.model.set, [iter] + row)
+ print [iter], row
+ # apply (self.model.set, [iter] + row)
+ self.model.set([iter] + row)
- self.access.append (entry)
+ # self.access.append (entry)
entry = iterator.next ()
@@ -440,10 +445,10 @@ class Index (Connector.Publisher):
entries = []
- def retrieve (model, path, iter):
+ def retrieve (model, path, iter, entries):
entries.append (self.access [path [0]])
- self.selinfo.selected_foreach (retrieve)
+ self.selinfo.selected_foreach (retrieve, entries)
return entries
@@ -458,7 +463,7 @@ class Index (Connector.Publisher):
def button_press (self, clist, event, *arg):
''' handler for double-click and right mouse button '''
- if not (event.type == gtk.gdk.BUTTON_PRESS and
+ if not (event.type == Gdk.EventType.BUTTON_PRESS and
event.button == 3): return
self._w_popup.popup (None, None, None, event.button, event.time)
diff --git a/Pyblio/GnomeUI/Medline.py b/Pyblio/GnomeUI/Medline.py
index 1406222..fdc79b4 100644
--- a/Pyblio/GnomeUI/Medline.py
+++ b/Pyblio/GnomeUI/Medline.py
@@ -19,8 +19,7 @@
#
#
-from gnome import ui
-import gtk
+from gi.repository import Gtk
from Pyblio.GnomeUI import Utils
@@ -117,7 +116,7 @@ class MedlineUI (Utils.GladeWindow):
ret = self._w_medline.run ()
- if ret != gtk.RESPONSE_OK:
+ if ret != Gtk.ResponseType.OK:
self._w_medline.destroy ()
return None
diff --git a/Pyblio/GnomeUI/OpenURL.py b/Pyblio/GnomeUI/OpenURL.py
index d809c4a..97a0365 100644
--- a/Pyblio/GnomeUI/OpenURL.py
+++ b/Pyblio/GnomeUI/OpenURL.py
@@ -21,9 +21,9 @@
''' Defines a Dialog to open URL '''
-import gobject
-import gtk
-from gnome import ui
+from gi.repository import GObject
+from gi.repository import Gtk
+# from gnome import ui
import string, os
@@ -44,10 +44,10 @@ class OpenDialog (Connector.Publisher, Utils.GladeWindow):
Utils.GladeWindow.__init__ (self, parent)
- liststore = gtk.ListStore (gobject.TYPE_STRING)
+ liststore = Gtk.ListStore (GObject.TYPE_STRING)
menu = self._w_combobox
menu.set_model (liststore)
- cell = gtk.CellRendererText()
+ cell = Gtk.CellRendererText()
menu.pack_start(cell, True)
menu.add_attribute(cell, 'text', 0)
@@ -82,7 +82,7 @@ class OpenDialog (Connector.Publisher, Utils.GladeWindow):
def run (self):
ret = self._w_openurl.run ()
- if ret != gtk.RESPONSE_OK:
+ if ret != Gtk.ResponseType.OK:
self._w_openurl.destroy ()
return (None, None)
diff --git a/Pyblio/GnomeUI/Pybliographic.py b/Pyblio/GnomeUI/Pybliographic.py
index 89286d7..4113627 100644
--- a/Pyblio/GnomeUI/Pybliographic.py
+++ b/Pyblio/GnomeUI/Pybliographic.py
@@ -26,7 +26,7 @@ import copy, os, stat
from Pyblio.GnomeUI import Document, Utils
from Pyblio import Base, Config
-from gtk import *
+from gi.repository import Gtk
class Pybliographic:
''' Main class holding all the documents and performing
@@ -139,6 +139,6 @@ class Pybliographic:
doc.w.destroy ()
self.documents.remove (doc)
- main_quit ()
+ Gtk.main_quit ()
return
diff --git a/Pyblio/GnomeUI/Search.py b/Pyblio/GnomeUI/Search.py
index 0c5c5cd..0e116f9 100644
--- a/Pyblio/GnomeUI/Search.py
+++ b/Pyblio/GnomeUI/Search.py
@@ -24,8 +24,9 @@
import os
-from gnome import ui
-import gtk, gobject
+# from gnome import ui
+# import gtk, gobject
+from gi.repository import Gtk, GObject
import string, re, sys, traceback, copy
@@ -58,11 +59,11 @@ class SearchDialog (Connector.Publisher, Utils.GladeWindow):
# the tree model contains a string that explains the query,
# and a python object representing the actual query.
- self._model = gtk.TreeStore (str, gobject.TYPE_PYOBJECT)
+ self._model = Gtk.TreeStore (str, GObject.TYPE_PYOBJECT)
self._w_tree.set_model (self._model)
# the view does not display the python column, of course.
- col = gtk.TreeViewColumn ('field', gtk.CellRendererText (), text = 0)
+ col = Gtk.TreeViewColumn ('field', Gtk.CellRendererText (), text = 0)
self._w_tree.append_column (col)
self._w_tree.expand_all ()
@@ -82,7 +83,7 @@ class SearchDialog (Connector.Publisher, Utils.GladeWindow):
[' - type - ', ' - key - '])
# connect a menu to the right button
- self.menu = gtk.Menu ()
+ self.menu = Gtk.Menu ()
self.delete_button = Utils.popup_add (self.menu, _("Delete"),
self.search_delete)
self.menu.show ()
@@ -136,9 +137,9 @@ class SearchDialog (Connector.Publisher, Utils.GladeWindow):
etype, value, tb = sys.exc_info ()
traceback.print_exception (etype, value, tb)
- d = gtk.MessageDialog (self._w_search,
- gtk.DIALOG_DESTROY_WITH_PARENT | gtk.DIALOG_MODAL,
- gtk.MESSAGE_ERROR, gtk.BUTTONS_OK,
+ d = Gtk.MessageDialog (self._w_search,
+ Gtk.DialogFlags.DESTROY_WITH_PARENT | Gtk.DialogFlags.MODAL,
+ Gtk.MessageType.ERROR, Gtk.ButtonsType.OK,
_("internal error during evaluation"))
d.run ()
d.destroy ()
@@ -190,9 +191,9 @@ class SearchDialog (Connector.Publisher, Utils.GladeWindow):
error = 1
if error:
- d = gtk.MessageDialog (self._w_search,
- gtk.DIALOG_DESTROY_WITH_PARENT | gtk.DIALOG_MODAL,
- gtk.MESSAGE_ERROR, gtk.BUTTONS_OK,
+ d = Gtk.MessageDialog (self._w_search,
+ Gtk.DialogFlags.DESTROY_WITH_PARENT | Gtk.DialogFlags.MODAL,
+ Gtk.MessageType.ERROR, Gtk.ButtonsType.OK,
_("while compiling %s\nerror: %s") %
(match, err [0]))
d.run ()
@@ -244,7 +245,7 @@ class SearchDialog (Connector.Publisher, Utils.GladeWindow):
''' Called when the user right-clicks in the query tree '''
- if (event.type != gtk.gdk.BUTTON_PRESS or
+ if (event.type != Gdk.EventType.BUTTON_PRESS or
event.button != 3): return
self.menu.popup (None, None, None, event.button, event.time)
diff --git a/Pyblio/GnomeUI/Sort.py b/Pyblio/GnomeUI/Sort.py
index 40b65d1..03ef6c8 100644
--- a/Pyblio/GnomeUI/Sort.py
+++ b/Pyblio/GnomeUI/Sort.py
@@ -23,8 +23,9 @@
import os, string
-import gtk, gobject
-from gnome import ui
+from gi.repository import Gtk, GObject
+# import gtk, gobject
+# from gnome import ui
from Pyblio import Connector, Sort, Config, version
from Pyblio.GnomeUI import Utils
@@ -57,27 +58,27 @@ class SortDialog (Connector.Publisher, Utils.GladeWindow):
Utils.GladeWindow.__init__ (self, parent)
- self._model = gtk.ListStore (gtk.gdk.Pixbuf, str, gobject.TYPE_PYOBJECT, int)
+ self._model = Gtk.ListStore (GdkPixbuf.Pixbuf, str, GObject.TYPE_PYOBJECT, int)
self._w_tree.set_model (self._model)
# Only the first two rows are visibles, the others are for
# internal bookkeeping.
- col = gtk.TreeViewColumn ('Direction', gtk.CellRendererPixbuf (), pixbuf = 0)
+ col = Gtk.TreeViewColumn ('Direction', Gtk.CellRendererPixbuf (), pixbuf = 0)
self._w_tree.append_column (col)
- col = gtk.TreeViewColumn ('Field', gtk.CellRendererText (), text = 1)
+ col = Gtk.TreeViewColumn ('Field', Gtk.CellRendererText (), text = 1)
self._w_tree.append_column (col)
self._w_sort.show ()
self._icon = {0: None}
- for id, stock in ((1, gtk.STOCK_GO_UP), (-1, gtk.STOCK_GO_DOWN)):
+ for id, stock in ((1, Gtk.STOCK_GO_UP), (-1, Gtk.STOCK_GO_DOWN)):
self._icon [id] = self._w_tree.render_icon (stock_id = stock,
- size = gtk.ICON_SIZE_MENU,
+ size = Gtk.IconSize.MENU,
detail = None)
diff --git a/Pyblio/GnomeUI/Utils.py b/Pyblio/GnomeUI/Utils.py
index bf0a78c..4d5e38c 100644
--- a/Pyblio/GnomeUI/Utils.py
+++ b/Pyblio/GnomeUI/Utils.py
@@ -23,14 +23,15 @@
import os
-import gtk, pango
-import gtk.glade
+from gi.repository import Gtk, Pango, Gdk
+# import gtk, pango
+# import Gtk.glade
-from gnome import ui
+# from gnome import ui
from Pyblio import Config, version
-import gconf
+from gi.repository import GConf
class Callback:
@@ -40,11 +41,11 @@ class Callback:
def __init__ (self, question, parent = None, cancel_add = False):
self.dialog = \
- gtk.MessageDialog (parent,
- gtk.DIALOG_MODAL |
- gtk.DIALOG_DESTROY_WITH_PARENT,
- gtk.MESSAGE_QUESTION,
- gtk.BUTTONS_YES_NO,
+ Gtk.MessageDialog (parent,
+ Gtk.DialogFlags.MODAL |
+ Gtk.DialogFlags.DESTROY_WITH_PARENT,
+ Gtk.MessageType.QUESTION,
+ Gtk.ButtonsType.YES_NO,
question)
if cancel_add:
self.dialog.add_button(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL)
@@ -53,9 +54,9 @@ class Callback:
def answer (self):
res = self.dialog.run ()
- if res == gtk.RESPONSE_YES:
+ if res == Gtk.RESPONSE_YES:
res = True
- elif res == gtk.RESPONSE_NO:
+ elif res == Gtk.RESPONSE_NO:
res = False
else:
res = 2
@@ -96,7 +97,7 @@ class GladeWindow:
def __init__ (self, parent = None, window = None):
gp = os.path.join(glade_root, self.gladeinfo ['file'])
- self.xml = gtk.glade.XML (gp, window, domain = "pybliographer")
+ self.xml = Gtk.glade.XML (gp, window, domain = "pybliographer")
self.xml.signal_autoconnect (self)
for w in self.xml.get_widget_prefix ('_w_'):
@@ -131,27 +132,29 @@ class GladeWindow:
return
-config = gconf.client_get_default ()
+config = GConf.Client.get_default ()
cursor = {
- 'clock' : gtk.gdk.Cursor (gtk.gdk.WATCH),
- 'normal': gtk.gdk.Cursor (gtk.gdk.LEFT_PTR),
+ 'clock' : Gdk.Cursor.new(Gdk.CursorType.WATCH),
+ 'normal': Gdk.Cursor.new(Gdk.CursorType.LEFT_PTR),
}
def set_cursor (self, name):
+ # FIXME: Port to Gtk3
+ return
window = self.get_toplevel ().window
if not window: return
window.set_cursor (cursor [name])
- while gtk.events_pending ():
- gtk.main_iteration (False)
+ while Gtk.events_pending ():
+ Gtk.main_iteration (False)
return
-##_tooltips = gtk.Tooltips ()
+##_tooltips = Gtk.Tooltips ()
##def set_tip (w, text):
@@ -168,7 +171,7 @@ def set_cursor (self, name):
def popup_add (menu, item, action = None, argument = None):
''' Helper to add a new menu entry '''
- tmp = gtk.MenuItem (item)
+ tmp = Gtk.MenuItem (item)
if action:
tmp.connect ('activate', action, argument)
@@ -180,19 +183,19 @@ def popup_add (menu, item, action = None, argument = None):
def error_dialog (title, err, parent = None):
dialog = \
- gtk.MessageDialog (parent,
- gtk.DIALOG_MODAL |
- gtk.DIALOG_DESTROY_WITH_PARENT,
- gtk.MESSAGE_ERROR,
+ Gtk.MessageDialog (parent,
+ Gtk.DialogFlags.MODAL |
+ Gtk.DialogFlags.DESTROY_WITH_PARENT,
+ Gtk.MessageType.ERROR,
message_format = title)
- b = dialog.add_button (gtk.STOCK_OK, gtk.RESPONSE_OK)
+ b = dialog.add_button (Gtk.STOCK_OK, Gtk.ResponseType.OK)
b.set_property ('has_default', True)
- buff = gtk.TextBuffer ()
- title = buff.create_tag ('title', weight = pango.WEIGHT_BOLD)
+ buff = Gtk.TextBuffer ()
+ title = buff.create_tag ('title', weight = Pango.Weight.BOLD)
- text = gtk.TextView ()
+ text = Gtk.TextView ()
text.set_editable (False)
text.set_cursor_visible (False)
text.set_buffer (buff)
@@ -205,9 +208,9 @@ def error_dialog (title, err, parent = None):
buff.insert (iter, str (err))
- holder = gtk.ScrolledWindow ()
- holder.set_policy (gtk.POLICY_AUTOMATIC,
- gtk.POLICY_AUTOMATIC)
+ holder = Gtk.ScrolledWindow ()
+ holder.set_policy (Gtk.PolicyType.AUTOMATIC,
+ Gtk.PolicyType.AUTOMATIC)
holder.add (text)
dialog.vbox.pack_start (holder)
diff --git a/Pyblio/GnomeUI/__init__.py b/Pyblio/GnomeUI/__init__.py
index 01d5aba..b24f5a3 100644
--- a/Pyblio/GnomeUI/__init__.py
+++ b/Pyblio/GnomeUI/__init__.py
@@ -23,35 +23,33 @@
# are not passed to Gnome
import sys, string
+import gettext
+
+_ = gettext.gettext
files = sys.argv [2:]
sys.argv = sys.argv [:2] + ['--'] + files
# correctly identify the program
-import pygtk
-pygtk.require ('2.0')
-
-import gnome, gtk
-import gnome.ui
+from gi.repository import Gtk
from Pyblio import version
-prg = gnome.init ('pybliographer', version.version)
-prg.set_property (gnome.PARAM_APP_DATADIR, version.datadir)
+# prg = Gtk.Application (application_id='pybliographer') #, version.version)
+# Gtk.init()
+# prg.set_property (gnome.PARAM_APP_DATADIR, version.datadir)
def _vnum (t):
return string.join (map (str, t), '.')
-ui_version = _("This is Pybliographic %s [Python %s, Gtk %s, PyGTK %s]") % (
+ui_version = _("This is Pybliographic %s [Python %s, Gtk %s]") % (
version.version, _vnum (sys.version_info [:3]),
- _vnum (gtk.gtk_version), _vnum (gtk.pygtk_version))
-
+ _vnum (Gtk._version))
+
# clean up our garbage
sys.argv = sys.argv [:2] + files
del sys, files
-import gtk.glade
-
-gtk.glade.bindtextdomain ("pybliographer", version.localedir)
+# Gtk.glade.bindtextdomain ("pybliographer", version.localedir)
diff --git a/Pyblio/GnomeUI/glade/pyblio.ui.in b/Pyblio/GnomeUI/glade/pyblio.ui.in
new file mode 100644
index 0000000..1525559
--- /dev/null
+++ b/Pyblio/GnomeUI/glade/pyblio.ui.in
@@ -0,0 +1,778 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<interface>
+ <!-- interface-requires gtk+ 3.0 -->
+ <object class="GtkWindow" id="main">
+ <property name="can_focus">False</property>
+ <property name="title" translatable="yes">Pybliographer</property>
+ <property name="icon">@icondir@/pybliographic.png</property>
+ <signal name="key-press-event" handler="key_pressed" swapped="no"/>
+ <signal name="delete-event" handler="close_or_exit" swapped="no"/>
+ <child>
+ <object class="GtkBox" id="box1">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="orientation">vertical</property>
+ <child>
+ <object class="GtkMenuBar" id="menubar1">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <child>
+ <object class="GtkMenuItem" id="menuitem1">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="label" translatable="yes">_File</property>
+ <property name="use_underline">True</property>
+ <child type="submenu">
+ <object class="GtkMenu" id="menu1">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem1">
+ <property name="label">gtk-new</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">new1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem2">
+ <property name="label">gtk-open</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">open1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem3">
+ <property name="label">gtk-save</property>
+ <property name="use_action_appearance">True</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">merge_with1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem4">
+ <property name="label">gtk-save-as</property>
+ <property name="use_action_appearance">True</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">medline_query1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem41">
+ <property name="label">gtk-save</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">_w_save_mnu</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem42">
+ <property name="label">gtk-save-as</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">save_as1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkSeparatorMenuItem" id="separatormenuitem20">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem43">
+ <property name="label">gtk-save-as</property>
+ <property name="use_action_appearance">True</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">previous_documents</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkSeparatorMenuItem" id="separatormenuitem1">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem50">
+ <property name="label">gtk-close</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">close1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem5">
+ <property name="label">gtk-quit</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">quit1</property>
+ </object>
+ </child>
+ </object>
+ </child>
+ </object>
+ </child>
+ <child>
+ <object class="GtkMenuItem" id="menuitem2">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="label" translatable="yes">_Edit</property>
+ <property name="use_underline">True</property>
+ <child type="submenu">
+ <object class="GtkMenu" id="menu2">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem6">
+ <property name="label">gtk-cut</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">cut1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem7">
+ <property name="label">gtk-copy</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">copy1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem8">
+ <property name="label">gtk-paste</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">paste1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem9">
+ <property name="label">gtk-clear</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">clear1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkSeparatorMenuItem" id="separatormenuitem11">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem91">
+ <property name="label">gtk-close</property>
+ <property name="use_action_appearance">True</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">add1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem92">
+ <property name="label">gtk-edit</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">edit1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem93">
+ <property name="label">gtk-delete</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">delete1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkSeparatorMenuItem" id="separatormenuitem12">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem94">
+ <property name="label">gtk-find</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">find1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem95">
+ <property name="label">gtk-sort</property>
+ <property name="use_action_appearance">True</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">sort1</property>
+ </object>
+ </child>
+ </object>
+ </child>
+ </object>
+ </child>
+ <child>
+ <object class="GtkMenuItem" id="menuitem3">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="label" translatable="yes">_View</property>
+ <property name="use_underline">True</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkMenuItem" id="menuitem4">
+ <property name="use_action_appearance">True</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="label" translatable="yes">_Help</property>
+ <property name="use_underline">True</property>
+ <property name="related_action">cite1</property>
+ <child type="submenu">
+ <object class="GtkMenu" id="menu44">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem441">
+ <property name="label">gtk-about</property>
+ <property name="use_action_appearance">True</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">cite2</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem442">
+ <property name="label">gtk-about</property>
+ <property name="use_action_appearance">True</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">format1</property>
+ </object>
+ </child>
+ </object>
+ </child>
+ </object>
+ </child>
+ <child>
+ <object class="GtkMenuItem" id="menuitem5">
+ <property name="use_action_appearance">True</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="label" translatable="yes">_Help</property>
+ <property name="use_underline">True</property>
+ <property name="related_action">settings1</property>
+ <child type="submenu">
+ <object class="GtkMenu" id="menu55">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem551">
+ <property name="label">gtk-about</property>
+ <property name="use_action_appearance">True</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">fields1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem552">
+ <property name="label">gtk-preferences</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">preferences2</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkSeparatorMenuItem" id="separatormenuitem13">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem553">
+ <property name="label">gtk-preferences</property>
+ <property name="use_action_appearance">True</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">forget_all_changes1</property>
+ </object>
+ </child>
+ </object>
+ </child>
+ </object>
+ </child>
+ <child>
+ <object class="GtkMenuItem" id="menuitem6">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="label" translatable="yes">_Help</property>
+ <property name="use_underline">True</property>
+ <child type="submenu">
+ <object class="GtkMenu" id="menu3">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem61">
+ <property name="label">gtk-about</property>
+ <property name="use_action_appearance">True</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">documentation_open</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkImageMenuItem" id="imagemenuitem62">
+ <property name="label">gtk-about</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_underline">True</property>
+ <property name="use_stock">True</property>
+ <property name="related_action">about1</property>
+ </object>
+ </child>
+ </object>
+ </child>
+ </object>
+ </child>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="position">0</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkToolbar" id="toolbar1">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="border_width">2</property>
+ <property name="toolbar_style">both</property>
+ <child>
+ <object class="GtkToolButton" id="button2">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="tooltip_text" translatable="yes">Open File</property>
+ <property name="use_action_appearance">False</property>
+ <property name="stock_id">gtk-open</property>
+ <signal name="clicked" handler="ui_open_document" swapped="no"/>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="homogeneous">True</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkToolButton" id="_w_save_btn">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="tooltip_text" translatable="yes">Save File</property>
+ <property name="use_action_appearance">False</property>
+ <property name="stock_id">gtk-save</property>
+ <signal name="clicked" handler="save_document" swapped="no"/>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="homogeneous">True</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkToolItem" id="toolitem1">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_action_appearance">False</property>
+ <child>
+ <object class="GtkVSeparator" id="vseparator3">
+ <property name="height_request">20</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ </object>
+ </child>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkToolButton" id="button4">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_action_appearance">False</property>
+ <property name="stock_id">gtk-add</property>
+ <signal name="clicked" handler="add_entry" swapped="no"/>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="homogeneous">True</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkToolItem" id="toolitem2">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_action_appearance">False</property>
+ <child>
+ <object class="GtkVSeparator" id="vseparator1">
+ <property name="height_request">20</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ </object>
+ </child>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkToolButton" id="button5">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_action_appearance">False</property>
+ <property name="stock_id">gtk-find</property>
+ <signal name="clicked" handler="find_entries" swapped="no"/>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="homogeneous">True</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkToolButton" id="button6">
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="use_action_appearance">False</property>
+ <property name="label" translatable="yes">Cite</property>
+ <property name="use_underline">True</property>
+ <property name="stock_id">gtk-jump-to</property>
+ <signal name="clicked" handler="lyx_cite" swapped="no"/>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="homogeneous">True</property>
+ </packing>
+ </child>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="position">1</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkVPaned" id="main_pane">
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <child>
+ <placeholder/>
+ </child>
+ <child>
+ <placeholder/>
+ </child>
+ </object>
+ <packing>
+ <property name="expand">True</property>
+ <property name="fill">True</property>
+ <property name="position">2</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkStatusbar" id="statusbar">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="position">3</property>
+ </packing>
+ </child>
+ </object>
+ </child>
+ </object>
+ <object class="GtkActionGroup" id="actiongroup1">
+ <child>
+ <object class="GtkAction" id="file1">
+ <property name="name">file1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="new1">
+ <property name="name">new1</property>
+ <property name="label" translatable="yes">_New</property>
+ <signal handler="new_document" last_modification_time="Sun, 08 Jun 2003 11:32:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="open1">
+ <property name="name">open1</property>
+ <signal handler="ui_open_document" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="merge_with1">
+ <property name="stock_id">gtk-convert</property>
+ <property name="name">merge_with1</property>
+ <property name="label" translatable="yes">Merge With...</property>
+ <signal handler="merge_database" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ <accelerator key="g" modifiers="GDK_CONTROL_MASK"/>
+ </child>
+ <child>
+ <object class="GtkAction" id="medline_query1">
+ <property name="name">medline_query1</property>
+ <property name="label" translatable="yes">Medline Query...</property>
+ <signal handler="query_database" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ <accelerator key="m" modifiers="GDK_CONTROL_MASK"/>
+ </child>
+ <child>
+ <object class="GtkAction" id="_w_save_mnu">
+ <property name="name">_w_save_mnu</property>
+ <signal handler="save_document" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="save_as1">
+ <property name="name">save_as1</property>
+ <signal handler="save_document_as" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="previous_documents">
+ <property name="name">previous_documents</property>
+ <property name="label" translatable="yes">Previous Documents</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="close1">
+ <property name="name">close1</property>
+ <signal handler="close_document" last_modification_time="Mon, 09 Jun 2003 18:50:24 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="quit1">
+ <property name="name">quit1</property>
+ <signal handler="exit_application" last_modification_time="Mon, 09 Jun 2003 18:50:24 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="edit1">
+ <property name="name">edit1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="cut1">
+ <property name="name">cut1</property>
+ <signal handler="cut_entry" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="copy1">
+ <property name="name">copy1</property>
+ <signal handler="copy_entry" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="paste1">
+ <property name="name">paste1</property>
+ <signal handler="paste_entry" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="clear1">
+ <property name="name">clear1</property>
+ <signal handler="clear_entries" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="add1">
+ <property name="stock_id">gtk-add</property>
+ <property name="name">add1</property>
+ <property name="label" translatable="yes">_Add...</property>
+ <signal handler="add_entry" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="edit2">
+ <property name="name">edit2</property>
+ <property name="label" translatable="yes">_Edit...</property>
+ <signal handler="edit_entry" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="delete1">
+ <property name="stock_id">gtk-remove</property>
+ <property name="name">delete1</property>
+ <property name="label" translatable="yes">_Delete...</property>
+ <signal handler="delete_entry" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ <accelerator key="Delete" modifiers="0"/>
+ </child>
+ <child>
+ <object class="GtkAction" id="find1">
+ <property name="name">find1</property>
+ <signal handler="find_entries" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="sort1">
+ <property name="stock_id">gtk-sort-ascending</property>
+ <property name="name">sort1</property>
+ <property name="label" translatable="yes">S_ort...</property>
+ <signal handler="sort_entries" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="cite1">
+ <property name="name">cite1</property>
+ <property name="label" translatable="yes">Cite</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="cite2">
+ <property name="stock_id">gtk-jump-to</property>
+ <property name="name">cite2</property>
+ <property name="label" translatable="yes">Cite...</property>
+ <signal handler="lyx_cite" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="format1">
+ <property name="stock_id">gtk-execute</property>
+ <property name="name">format1</property>
+ <property name="label" translatable="yes">Format...</property>
+ <signal handler="format_entries" last_modification_time="Mon, 09 Jun 2003 18:56:54 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="settings1">
+ <property name="name">settings1</property>
+ <property name="label" translatable="yes">Settings</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="fields1">
+ <property name="name">fields1</property>
+ <property name="label" translatable="yes">Fields...</property>
+ <signal handler="set_fields" last_modification_time="Mon, 09 Jun 2003 19:02:17 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="preferences2">
+ <property name="name">preferences2...</property>
+ <signal handler="set_preferences" last_modification_time="Mon, 09 Jun 2003 19:02:17 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="forget_all_changes1">
+ <property name="name">forget_all_changes1</property>
+ <property name="label" translatable="yes">Forget all changes</property>
+ <signal handler="forget_changes_cb" last_modification_time="Wed, 12 Nov 2003 14:32:19 GMT"
name="activate"/>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="help1">
+ <property name="name">help1</property>
+ </object>
+ </child>
+ <child>
+ <object class="GtkAction" id="documentation_open">
+ <property name="stock_id">gtk-help</property>
+ <property name="name">documentation_open</property>
+ <property name="label" translatable="yes">Contents</property>
+ <signal handler="on_documentation" last_modification_time="Tue, 06 Jan 2004 13:25:15 GMT"
name="activate"/>
+ </object>
+ <accelerator key="F1" modifiers="0"/>
+ </child>
+ <child>
+ <object class="GtkAction" id="about1">
+ <property name="name">about1</property>
+ <signal handler="about" last_modification_time="Mon, 09 Jun 2003 19:02:17 GMT" name="activate"/>
+ </object>
+ </child>
+ </object>
+</interface>
diff --git a/scripts/pybliographic.py b/scripts/pybliographic.py
index 78a7442..340a8a7 100644
--- a/scripts/pybliographic.py
+++ b/scripts/pybliographic.py
@@ -43,7 +43,8 @@ elif pyblio_path:
else:
main.new_document ()
-import gtk
+# import gtk
+from gi.repository import Gtk
-gtk.main ()
+Gtk.main ()
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]