2008-08-15 19:31:51 +02:00
|
|
|
# -*- coding:utf-8 -*-
|
2018-01-17 21:02:31 +01:00
|
|
|
## gajim/gtkexcepthook.py
|
2005-09-09 22:26:06 +02:00
|
|
|
##
|
2018-01-17 21:02:31 +01:00
|
|
|
## Copyright (C) 2016-2018 Philipp Hörist <philipp AT hoerist.com>
|
2008-08-15 05:20:23 +02:00
|
|
|
## Copyright (C) 2005-2006 Nikos Kouremenos <kourem AT gmail.com>
|
2014-01-02 09:33:54 +01:00
|
|
|
## Copyright (C) 2005-2014 Yann Leboulanger <asterix AT lagaule.org>
|
2008-08-15 19:31:51 +02:00
|
|
|
## Copyright (C) 2008 Stephan Erb <steve-e AT h3c.de>
|
2005-09-09 22:26:06 +02:00
|
|
|
##
|
2007-10-22 13:13:13 +02:00
|
|
|
## This file is part of Gajim.
|
|
|
|
##
|
|
|
|
## Gajim is free software; you can redistribute it and/or modify
|
2005-09-09 22:26:06 +02:00
|
|
|
## it under the terms of the GNU General Public License as published
|
2007-10-22 13:13:13 +02:00
|
|
|
## by the Free Software Foundation; version 3 only.
|
2005-09-09 22:26:06 +02:00
|
|
|
##
|
2007-10-22 13:13:13 +02:00
|
|
|
## Gajim is distributed in the hope that it will be useful,
|
2005-09-09 22:26:06 +02:00
|
|
|
## but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2008-08-15 05:20:23 +02:00
|
|
|
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2005-09-09 22:26:06 +02:00
|
|
|
## GNU General Public License for more details.
|
|
|
|
##
|
2007-10-22 13:13:13 +02:00
|
|
|
## You should have received a copy of the GNU General Public License
|
2008-08-15 05:20:23 +02:00
|
|
|
## along with Gajim. If not, see <http://www.gnu.org/licenses/>.
|
2007-10-22 13:13:13 +02:00
|
|
|
##
|
2005-09-09 22:26:06 +02:00
|
|
|
|
2005-09-09 19:09:04 +02:00
|
|
|
import sys
|
2006-05-26 15:26:53 +02:00
|
|
|
import os
|
2005-09-09 19:09:04 +02:00
|
|
|
import traceback
|
2005-09-13 13:11:39 +02:00
|
|
|
import threading
|
2017-01-02 23:45:11 +01:00
|
|
|
import webbrowser
|
2018-01-17 21:02:31 +01:00
|
|
|
import platform
|
|
|
|
from io import StringIO
|
|
|
|
from urllib.parse import urlencode
|
2005-09-09 19:09:04 +02:00
|
|
|
|
2018-01-17 21:02:31 +01:00
|
|
|
import nbxmpp
|
2018-02-05 21:00:28 +01:00
|
|
|
import gajim
|
2018-01-17 21:02:31 +01:00
|
|
|
import gi
|
2017-01-02 23:45:11 +01:00
|
|
|
gi.require_version('Gtk', '3.0')
|
2018-01-17 21:02:31 +01:00
|
|
|
from gi.repository import Gtk, GObject
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
glade_file = os.path.join('data', 'gui', 'exception_dialog.ui')
|
|
|
|
else:
|
|
|
|
from gajim.common import configpaths
|
|
|
|
glade_file = os.path.join(configpaths.get('GUI'), 'exception_dialog.ui')
|
2017-01-02 23:45:11 +01:00
|
|
|
|
2005-09-09 19:09:04 +02:00
|
|
|
|
2005-09-13 13:11:39 +02:00
|
|
|
_exception_in_progress = threading.Lock()
|
2005-09-09 19:09:04 +02:00
|
|
|
|
2018-01-17 21:02:31 +01:00
|
|
|
ISSUE_TEXT = '''## Versions
|
|
|
|
- OS: {}
|
|
|
|
- GTK+ Version: {}
|
|
|
|
- PyGObject Version: {}
|
|
|
|
- python-nbxmpp Version: {}
|
2018-02-05 21:00:28 +01:00
|
|
|
- Gajim Version: {}
|
2018-01-17 21:02:31 +01:00
|
|
|
|
|
|
|
## Traceback
|
|
|
|
```
|
|
|
|
{}
|
|
|
|
```
|
|
|
|
## Steps to reproduce the problem
|
|
|
|
...'''
|
2017-01-02 23:45:11 +01:00
|
|
|
|
|
|
|
def _hook(type_, value, tb):
|
2010-02-08 15:08:40 +01:00
|
|
|
if not _exception_in_progress.acquire(False):
|
|
|
|
# Exceptions have piled up, so we use the default exception
|
|
|
|
# handler for such exceptions
|
2017-01-02 23:45:11 +01:00
|
|
|
sys.__excepthook__(type_, value, tb)
|
2010-02-08 15:08:40 +01:00
|
|
|
return
|
2005-09-09 19:09:04 +02:00
|
|
|
|
2017-01-02 23:45:11 +01:00
|
|
|
ExceptionDialog(type_, value, tb)
|
|
|
|
_exception_in_progress.release()
|
2008-12-03 22:56:12 +01:00
|
|
|
|
2005-09-09 19:09:04 +02:00
|
|
|
|
2017-01-02 23:45:11 +01:00
|
|
|
class ExceptionDialog():
|
|
|
|
def __init__(self, type_, value, tb):
|
|
|
|
builder = Gtk.Builder()
|
|
|
|
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)
|
2018-01-17 21:02:31 +01:00
|
|
|
self.text = self.get_issue_text(trace.getvalue())
|
|
|
|
buffer_.set_text(self.text)
|
2017-01-02 23:45:11 +01:00
|
|
|
self.exception_view.set_editable(False)
|
2018-01-17 21:02:31 +01:00
|
|
|
self.dialog.show()
|
2005-09-09 19:09:04 +02:00
|
|
|
|
2017-01-02 23:45:11 +01:00
|
|
|
def on_report_clicked(self, *args):
|
2018-01-17 21:02:31 +01:00
|
|
|
issue_url = 'https://dev.gajim.org/gajim/gajim/issues/new'
|
|
|
|
params = {'issue[description]': self.text}
|
|
|
|
url = '{}?{}'.format(issue_url, urlencode(params))
|
2017-01-02 23:45:11 +01:00
|
|
|
webbrowser.open(url, new=2)
|
2005-09-09 19:09:04 +02:00
|
|
|
|
2017-01-02 23:45:11 +01:00
|
|
|
def on_close_clicked(self, *args):
|
|
|
|
self.dialog.destroy()
|
2005-09-11 15:41:21 +02:00
|
|
|
|
2018-01-17 21:02:31 +01:00
|
|
|
def get_issue_text(self, traceback_text):
|
|
|
|
gtk_ver = '%i.%i.%i' % (
|
|
|
|
Gtk.get_major_version(),
|
|
|
|
Gtk.get_minor_version(),
|
|
|
|
Gtk.get_micro_version())
|
|
|
|
gobject_ver = '.'.join(map(str, GObject.pygobject_version))
|
|
|
|
|
|
|
|
return ISSUE_TEXT.format(get_os_info(),
|
|
|
|
gtk_ver,
|
|
|
|
gobject_ver,
|
|
|
|
nbxmpp.__version__,
|
2018-02-05 21:00:28 +01:00
|
|
|
gajim.__version__,
|
2018-01-17 21:02:31 +01:00
|
|
|
traceback_text)
|
|
|
|
|
2008-12-03 22:56:12 +01:00
|
|
|
|
2017-01-02 23:45:11 +01:00
|
|
|
def init():
|
|
|
|
if os.name == 'nt' or not sys.stderr.isatty():
|
|
|
|
sys.excepthook = _hook
|
2005-09-09 19:09:04 +02:00
|
|
|
|
2018-01-17 21:02:31 +01:00
|
|
|
|
|
|
|
def get_os_info():
|
|
|
|
if os.name == 'nt' or sys.platform == 'darwin':
|
|
|
|
return platform.system() + " " + platform.release()
|
|
|
|
elif os.name == 'posix':
|
|
|
|
try:
|
|
|
|
import distro
|
|
|
|
return distro.name(pretty=True)
|
|
|
|
except ImportError:
|
|
|
|
return platform.system()
|
|
|
|
return ''
|
|
|
|
|
|
|
|
# this is just to assist testing (python3 gtkexcepthook.py)
|
2005-09-09 19:09:04 +02:00
|
|
|
if __name__ == '__main__':
|
2017-01-02 23:45:11 +01:00
|
|
|
init()
|
|
|
|
print(sys.version)
|
2018-01-17 21:02:31 +01:00
|
|
|
ExceptionDialog(None, None, None)
|
|
|
|
Gtk.main()
|