From 680617324b88f51858e9de9652679d268cf90be4 Mon Sep 17 00:00:00 2001 From: duplo Date: Tue, 8 Sep 2009 16:28:53 +0000 Subject: [PATCH] Add error logging git-svn-id: https://src.develer.com/svnoss/bertos/trunk@2908 38d2e660-2303-0410-9eaa-f027e97ec537 --- wizard/bertos.py | 2 ++ wizard/exception_handler.py | 64 +++++++++++++++++++++++++++++++++++++ 2 files changed, 66 insertions(+) create mode 100644 wizard/exception_handler.py diff --git a/wizard/bertos.py b/wizard/bertos.py index 57dbe8af..54f2885b 100755 --- a/wizard/bertos.py +++ b/wizard/bertos.py @@ -40,6 +40,8 @@ from distutils.dep_util import newer from PyQt4.QtCore import * from PyQt4.QtGui import * +import exception_handler + import BProject import BStartPage diff --git a/wizard/exception_handler.py b/wizard/exception_handler.py new file mode 100644 index 00000000..ae3b82f5 --- /dev/null +++ b/wizard/exception_handler.py @@ -0,0 +1,64 @@ +#!/usr/bin/env python +# encoding: utf-8 +# +# This file is part of BeRTOS. +# +# Bertos is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +# +# As a special exception, you may use this file as part of a free software +# library without restriction. Specifically, if other files instantiate +# templates or use macros or inline functions from this file, or you compile +# this file and link it with other files to produce an executable, this +# file does not by itself cause the resulting executable to be covered by +# the GNU General Public License. This exception does not however +# invalidate any other reasons why the executable file might be covered by +# the GNU General Public License. +# +# Copyright 2008 Develer S.r.l. (http://www.develer.com/) +# +# $Id: const.py 2907 2009-09-08 14:02:04Z duplo $ +# +# Author: Lorenzo Berni +# + +import sys +import os +import traceback + +from PyQt4.QtCore import * +from PyQt4.QtGui import * + +def _excepthook(exc_type, exc_value, exc_traceback): + project_dir = QApplication.instance().project.info("PROJECT_PATH") + file_name = os.path.join(project_dir, "wizard_error.log") + if os.path.exists(file_name): + content = open(file_name, "r").read() + else: + content = "" + f = open(file_name, "w") + message = "\n".join(traceback.format_exception(exc_type, exc_value, exc_traceback)) + f.write(message) + f.write(">"*80 + "\n") + f.write(content) + f.close() + QMessageBox.critical( + None, + "Exception occurred", + "An exception is occurred. Please attach the '%s' file to the support request." %os.path.abspath(file_name), + ) + QApplication.instance().quit() + +sys.excepthook = _excepthook + -- 2.25.1