Merge branch 'dev' into 'master'
ExceptionHook port to GTK3 See merge request !25
This commit is contained in:
commit
f8a314b5f2
|
@ -0,0 +1,139 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!-- Generated with glade 3.19.0 -->
|
||||||
|
<interface>
|
||||||
|
<requires lib="gtk+" version="3.12"/>
|
||||||
|
<object class="GtkDialog" id="ExceptionDialog">
|
||||||
|
<property name="can_focus">False</property>
|
||||||
|
<property name="title" translatable="yes">Exception</property>
|
||||||
|
<property name="window_position">center</property>
|
||||||
|
<property name="icon_name">dialog-error</property>
|
||||||
|
<property name="type_hint">dialog</property>
|
||||||
|
<property name="gravity">center</property>
|
||||||
|
<child internal-child="vbox">
|
||||||
|
<object class="GtkBox" id="dialog-vbox">
|
||||||
|
<property name="can_focus">False</property>
|
||||||
|
<property name="margin_left">12</property>
|
||||||
|
<property name="margin_right">12</property>
|
||||||
|
<property name="margin_top">12</property>
|
||||||
|
<property name="margin_bottom">13</property>
|
||||||
|
<property name="orientation">vertical</property>
|
||||||
|
<property name="spacing">2</property>
|
||||||
|
<child internal-child="action_area">
|
||||||
|
<object class="GtkButtonBox" id="dialog-action_area">
|
||||||
|
<property name="can_focus">False</property>
|
||||||
|
<property name="margin_top">5</property>
|
||||||
|
<property name="layout_style">end</property>
|
||||||
|
<child>
|
||||||
|
<object class="GtkButton" id="close_btn">
|
||||||
|
<property name="label">gtk-close</property>
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">True</property>
|
||||||
|
<property name="receives_default">True</property>
|
||||||
|
<property name="use_stock">True</property>
|
||||||
|
<property name="always_show_image">True</property>
|
||||||
|
<signal name="clicked" handler="on_close_clicked" swapped="no"/>
|
||||||
|
</object>
|
||||||
|
<packing>
|
||||||
|
<property name="expand">True</property>
|
||||||
|
<property name="fill">True</property>
|
||||||
|
<property name="position">0</property>
|
||||||
|
</packing>
|
||||||
|
</child>
|
||||||
|
<child>
|
||||||
|
<object class="GtkButton" id="report_btn">
|
||||||
|
<property name="label" translatable="yes">Report Bug</property>
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">True</property>
|
||||||
|
<property name="receives_default">True</property>
|
||||||
|
<signal name="clicked" handler="on_report_clicked" swapped="no"/>
|
||||||
|
</object>
|
||||||
|
<packing>
|
||||||
|
<property name="expand">True</property>
|
||||||
|
<property name="fill">True</property>
|
||||||
|
<property name="position">1</property>
|
||||||
|
</packing>
|
||||||
|
</child>
|
||||||
|
</object>
|
||||||
|
<packing>
|
||||||
|
<property name="expand">False</property>
|
||||||
|
<property name="fill">False</property>
|
||||||
|
<property name="position">0</property>
|
||||||
|
</packing>
|
||||||
|
</child>
|
||||||
|
<child>
|
||||||
|
<object class="GtkGrid" id="grid">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">False</property>
|
||||||
|
<property name="row_spacing">20</property>
|
||||||
|
<property name="column_spacing">20</property>
|
||||||
|
<child>
|
||||||
|
<object class="GtkImage" id="image">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">False</property>
|
||||||
|
<property name="valign">center</property>
|
||||||
|
<property name="stock">gtk-dialog-error</property>
|
||||||
|
<property name="icon_size">6</property>
|
||||||
|
</object>
|
||||||
|
<packing>
|
||||||
|
<property name="left_attach">0</property>
|
||||||
|
<property name="top_attach">0</property>
|
||||||
|
</packing>
|
||||||
|
</child>
|
||||||
|
<child>
|
||||||
|
<object class="GtkLabel" id="msglabel">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">False</property>
|
||||||
|
<property name="halign">start</property>
|
||||||
|
<property name="valign">center</property>
|
||||||
|
<property name="hexpand">True</property>
|
||||||
|
<property name="label" translatable="yes">A programming error has been detected.
|
||||||
|
It probably is not fatal, but should be reported
|
||||||
|
to the developers nonetheless.</property>
|
||||||
|
<property name="max_width_chars">60</property>
|
||||||
|
<property name="lines">3</property>
|
||||||
|
<attributes>
|
||||||
|
<attribute name="font-desc" value="<Geben Sie den Wert ein> 12"/>
|
||||||
|
</attributes>
|
||||||
|
</object>
|
||||||
|
<packing>
|
||||||
|
<property name="left_attach">1</property>
|
||||||
|
<property name="top_attach">0</property>
|
||||||
|
</packing>
|
||||||
|
</child>
|
||||||
|
<child>
|
||||||
|
<object class="GtkScrolledWindow" id="scrolledwindow">
|
||||||
|
<property name="height_request">150</property>
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">True</property>
|
||||||
|
<property name="vexpand">True</property>
|
||||||
|
<property name="shadow_type">in</property>
|
||||||
|
<child>
|
||||||
|
<object class="GtkTextView" id="exception_view">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">True</property>
|
||||||
|
<property name="hexpand">True</property>
|
||||||
|
<property name="vexpand">True</property>
|
||||||
|
<property name="editable">False</property>
|
||||||
|
<property name="left_margin">4</property>
|
||||||
|
<property name="right_margin">4</property>
|
||||||
|
<property name="accepts_tab">False</property>
|
||||||
|
</object>
|
||||||
|
</child>
|
||||||
|
</object>
|
||||||
|
<packing>
|
||||||
|
<property name="left_attach">0</property>
|
||||||
|
<property name="top_attach">1</property>
|
||||||
|
<property name="width">2</property>
|
||||||
|
</packing>
|
||||||
|
</child>
|
||||||
|
</object>
|
||||||
|
<packing>
|
||||||
|
<property name="expand">True</property>
|
||||||
|
<property name="fill">True</property>
|
||||||
|
<property name="position">1</property>
|
||||||
|
</packing>
|
||||||
|
</child>
|
||||||
|
</object>
|
||||||
|
</child>
|
||||||
|
</object>
|
||||||
|
</interface>
|
|
@ -94,6 +94,9 @@ class GajimApplication(Gtk.Application):
|
||||||
|
|
||||||
Gtk.Application.do_activate(self)
|
Gtk.Application.do_activate(self)
|
||||||
|
|
||||||
|
import gtkexcepthook
|
||||||
|
gtkexcepthook.init()
|
||||||
|
|
||||||
# Create and initialize Application Paths & Databases
|
# Create and initialize Application Paths & Databases
|
||||||
import common.configpaths
|
import common.configpaths
|
||||||
common.configpaths.gajimpaths.init(
|
common.configpaths.gajimpaths.init(
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
# -*- coding:utf-8 -*-
|
# -*- coding:utf-8 -*-
|
||||||
## src/gtkexcepthook.py
|
## src/gtkexcepthook.py
|
||||||
##
|
##
|
||||||
|
## Copyright (C) 2016 Philipp Hörist <philipp AT hoerist.com>
|
||||||
## Copyright (C) 2005-2006 Nikos Kouremenos <kourem AT gmail.com>
|
## Copyright (C) 2005-2006 Nikos Kouremenos <kourem AT gmail.com>
|
||||||
## Copyright (C) 2005-2014 Yann Leboulanger <asterix AT lagaule.org>
|
## Copyright (C) 2005-2014 Yann Leboulanger <asterix AT lagaule.org>
|
||||||
## Copyright (C) 2008 Stephan Erb <steve-e AT h3c.de>
|
## Copyright (C) 2008 Stephan Erb <steve-e AT h3c.de>
|
||||||
|
@ -24,83 +25,61 @@ import sys
|
||||||
import os
|
import os
|
||||||
import traceback
|
import traceback
|
||||||
import threading
|
import threading
|
||||||
|
import webbrowser
|
||||||
|
import gi
|
||||||
|
|
||||||
|
gi.require_version('Gtk', '3.0')
|
||||||
from gi.repository import Gtk
|
from gi.repository import Gtk
|
||||||
from gi.repository import Gdk
|
|
||||||
from gi.repository import Pango
|
|
||||||
from common import i18n # installs _() function
|
|
||||||
from dialogs import HigDialog
|
|
||||||
|
|
||||||
from io import StringIO
|
from io import StringIO
|
||||||
from common import helpers
|
from common import configpaths
|
||||||
|
|
||||||
|
glade_file = os.path.join(configpaths.get('GUI'), 'exception_dialog.ui')
|
||||||
|
|
||||||
_exception_in_progress = threading.Lock()
|
_exception_in_progress = threading.Lock()
|
||||||
|
|
||||||
def _info(type_, value, tb):
|
|
||||||
|
def _hook(type_, value, tb):
|
||||||
if not _exception_in_progress.acquire(False):
|
if not _exception_in_progress.acquire(False):
|
||||||
# Exceptions have piled up, so we use the default exception
|
# Exceptions have piled up, so we use the default exception
|
||||||
# handler for such exceptions
|
# handler for such exceptions
|
||||||
_excepthook_save(type_, value, tb)
|
sys.__excepthook__(type_, value, tb)
|
||||||
return
|
return
|
||||||
|
|
||||||
dialog = HigDialog(None, Gtk.MessageType.WARNING, Gtk.ButtonsType.NONE,
|
ExceptionDialog(type_, value, tb)
|
||||||
_('A programming error has been detected'),
|
|
||||||
_('It probably is not fatal, but should be reported '
|
|
||||||
'to the developers nonetheless.'))
|
|
||||||
|
|
||||||
dialog.set_modal(False)
|
|
||||||
#FIXME: add icon to this button
|
|
||||||
RESPONSE_REPORT_BUG = 42
|
|
||||||
dialog.add_buttons(Gtk.STOCK_CLOSE, Gtk.ButtonsType.CLOSE,
|
|
||||||
_('_Report Bug'), RESPONSE_REPORT_BUG)
|
|
||||||
report_button = dialog.action_area.get_children()[0] # right to left
|
|
||||||
report_button.grab_focus()
|
|
||||||
|
|
||||||
# Details
|
|
||||||
textview = Gtk.TextView()
|
|
||||||
textview.set_editable(False)
|
|
||||||
textview.override_font(Pango.FontDescription('Monospace'))
|
|
||||||
sw = Gtk.ScrolledWindow()
|
|
||||||
sw.set_policy(Gtk.PolicyType.AUTOMATIC, Gtk.PolicyType.AUTOMATIC)
|
|
||||||
sw.add(textview)
|
|
||||||
frame = Gtk.Frame()
|
|
||||||
frame.set_shadow_type(Gtk.ShadowType.IN)
|
|
||||||
frame.add(sw)
|
|
||||||
frame.set_border_width(6)
|
|
||||||
textbuffer = textview.get_buffer()
|
|
||||||
trace = StringIO()
|
|
||||||
traceback.print_exception(type_, value, tb, None, trace)
|
|
||||||
textbuffer.set_text(trace.getvalue())
|
|
||||||
textview.set_size_request(
|
|
||||||
Gdk.Screen.width() / 3,
|
|
||||||
Gdk.Screen.height() / 4)
|
|
||||||
expander = Gtk.Expander(label=_('Details'))
|
|
||||||
expander.add(frame)
|
|
||||||
dialog.vbox.pack_start(expander, True, True, 0)
|
|
||||||
|
|
||||||
dialog.set_resizable(True)
|
|
||||||
# on expand the details the dialog remains centered on screen
|
|
||||||
dialog.set_position(Gtk.WindowPosition.CENTER_ALWAYS)
|
|
||||||
|
|
||||||
def on_dialog_response(dialog, response):
|
|
||||||
if response == RESPONSE_REPORT_BUG:
|
|
||||||
url = 'http://trac.gajim.org/wiki/HowToCreateATicket'
|
|
||||||
helpers.launch_browser_mailer('url', url)
|
|
||||||
else:
|
|
||||||
dialog.destroy()
|
|
||||||
dialog.connect('response', on_dialog_response)
|
|
||||||
dialog.show_all()
|
|
||||||
|
|
||||||
_exception_in_progress.release()
|
_exception_in_progress.release()
|
||||||
|
|
||||||
# gdb/kdm etc if we use startx this is not True
|
|
||||||
if os.name == 'nt' or not sys.stderr.isatty():
|
class ExceptionDialog():
|
||||||
#FIXME: maybe always show dialog?
|
def __init__(self, type_, value, tb):
|
||||||
_excepthook_save = sys.excepthook
|
builder = Gtk.Builder()
|
||||||
sys.excepthook = _info
|
builder.add_from_file(glade_file)
|
||||||
|
self.dialog = builder.get_object("ExceptionDialog")
|
||||||
|
builder.connect_signals(self)
|
||||||
|
builder.get_object("report_btn").grab_focus()
|
||||||
|
self.exception_view = builder.get_object("exception_view")
|
||||||
|
buffer_ = self.exception_view.get_buffer()
|
||||||
|
trace = StringIO()
|
||||||
|
traceback.print_exception(type_, value, tb, None, trace)
|
||||||
|
buffer_.set_text(trace.getvalue())
|
||||||
|
self.exception_view.set_editable(False)
|
||||||
|
self.dialog.run()
|
||||||
|
|
||||||
|
def on_report_clicked(self, *args):
|
||||||
|
url = 'https://dev.gajim.org/gajim/gajim/issues'
|
||||||
|
webbrowser.open(url, new=2)
|
||||||
|
|
||||||
|
def on_close_clicked(self, *args):
|
||||||
|
self.dialog.destroy()
|
||||||
|
|
||||||
|
|
||||||
|
def init():
|
||||||
|
# gdb/kdm etc if we use startx this is not True
|
||||||
|
if os.name == 'nt' or not sys.stderr.isatty():
|
||||||
|
# FIXME: maybe always show dialog?
|
||||||
|
sys.excepthook = _hook
|
||||||
|
|
||||||
# this is just to assist testing (python gtkexcepthook.py)
|
# this is just to assist testing (python gtkexcepthook.py)
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
_excepthook_save = sys.excepthook
|
init()
|
||||||
sys.excepthook = _info
|
print(sys.version)
|
||||||
raise Exception()
|
raise Exception()
|
||||||
|
|
Loading…
Reference in New Issue