mirror of
https://github.com/arsenetar/dupeguru.git
synced 2024-10-29 21:05:57 +00:00
10d1363334
Making error reporting too easy results in too much context-less tracebacks which demand attention and, in the end, aren't of much use. Requiring the user to report errors on Github will reduce the number of reports, but hopefully make these reports have better context.
85 lines
3.6 KiB
Python
85 lines
3.6 KiB
Python
# Created By: Virgil Dupras
|
|
# Created On: 2009-05-23
|
|
# Copyright 2014 Hardcoded Software (http://www.hardcoded.net)
|
|
#
|
|
# This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
# which should be included with this package. The terms are also available at
|
|
# http://www.hardcoded.net/licenses/bsd_license
|
|
|
|
import traceback
|
|
import sys
|
|
import os
|
|
|
|
from PyQt5.QtCore import Qt, QCoreApplication, QSize
|
|
from PyQt5.QtWidgets import QDialog, QVBoxLayout, QHBoxLayout, QLabel, QPlainTextEdit, QPushButton
|
|
|
|
from hscommon.trans import trget
|
|
from hscommon.desktop import open_url
|
|
from .util import horizontalSpacer
|
|
|
|
tr = trget('qtlib')
|
|
|
|
class ErrorReportDialog(QDialog):
|
|
def __init__(self, parent, github_url, error, **kwargs):
|
|
flags = Qt.CustomizeWindowHint | Qt.WindowTitleHint | Qt.WindowSystemMenuHint
|
|
super().__init__(parent, flags, **kwargs)
|
|
self._setupUi()
|
|
name = QCoreApplication.applicationName()
|
|
version = QCoreApplication.applicationVersion()
|
|
errorText = "Application Name: {}\nVersion: {}\n\n{}".format(name, version, error)
|
|
# Under windows, we end up with an error report without linesep if we don't mangle it
|
|
errorText = errorText.replace('\n', os.linesep)
|
|
self.errorTextEdit.setPlainText(errorText)
|
|
self.github_url = github_url
|
|
|
|
self.sendButton.clicked.connect(self.goToGithub)
|
|
self.dontSendButton.clicked.connect(self.reject)
|
|
|
|
def _setupUi(self):
|
|
self.setWindowTitle(tr("Error Report"))
|
|
self.resize(553, 349)
|
|
self.verticalLayout = QVBoxLayout(self)
|
|
self.label = QLabel(self)
|
|
self.label.setText(tr("Something went wrong. How about reporting the error?"))
|
|
self.label.setWordWrap(True)
|
|
self.verticalLayout.addWidget(self.label)
|
|
self.errorTextEdit = QPlainTextEdit(self)
|
|
self.errorTextEdit.setReadOnly(True)
|
|
self.verticalLayout.addWidget(self.errorTextEdit)
|
|
msg = tr(
|
|
"Error reports should be reported as Github issues. You can copy the error traceback "
|
|
"above and paste it in a new issue (bonus point if you run a search to make sure the "
|
|
"issue doesn't already exist). What usually really helps is if you add a description "
|
|
"of how you got the error. Thanks!"
|
|
"\n\n"
|
|
"Although the application should continue to run after this error, it may be in an "
|
|
"unstable state, so it is recommended that you restart the application."
|
|
)
|
|
self.label2 = QLabel(msg)
|
|
self.label2.setWordWrap(True)
|
|
self.verticalLayout.addWidget(self.label2)
|
|
self.horizontalLayout = QHBoxLayout()
|
|
self.horizontalLayout.addItem(horizontalSpacer())
|
|
self.dontSendButton = QPushButton(self)
|
|
self.dontSendButton.setText(tr("Close"))
|
|
self.dontSendButton.setMinimumSize(QSize(110, 0))
|
|
self.horizontalLayout.addWidget(self.dontSendButton)
|
|
self.sendButton = QPushButton(self)
|
|
self.sendButton.setText(tr("Go to Github"))
|
|
self.sendButton.setMinimumSize(QSize(110, 0))
|
|
self.sendButton.setDefault(True)
|
|
self.horizontalLayout.addWidget(self.sendButton)
|
|
self.verticalLayout.addLayout(self.horizontalLayout)
|
|
|
|
def goToGithub(self):
|
|
open_url(self.github_url)
|
|
|
|
|
|
def install_excepthook(github_url):
|
|
def my_excepthook(exctype, value, tb):
|
|
s = ''.join(traceback.format_exception(exctype, value, tb))
|
|
dialog = ErrorReportDialog(None, github_url, s)
|
|
dialog.exec_()
|
|
|
|
sys.excepthook = my_excepthook
|