Add error logging
authorduplo <duplo@38d2e660-2303-0410-9eaa-f027e97ec537>
Tue, 8 Sep 2009 16:28:53 +0000 (16:28 +0000)
committerduplo <duplo@38d2e660-2303-0410-9eaa-f027e97ec537>
Tue, 8 Sep 2009 16:28:53 +0000 (16:28 +0000)
git-svn-id: https://src.develer.com/svnoss/bertos/trunk@2908 38d2e660-2303-0410-9eaa-f027e97ec537

wizard/bertos.py
wizard/exception_handler.py [new file with mode: 0644]

index 57dbe8af3ba1503bc8cad068efc7c84fc8b8686b..54f2885b59ec544666b7891fbdd8d54809909750 100755 (executable)
@@ -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 (file)
index 0000000..ae3b82f
--- /dev/null
@@ -0,0 +1,64 @@
+#!/usr/bin/env python\r
+# encoding: utf-8\r
+#\r
+# This file is part of BeRTOS.\r
+#\r
+# Bertos is free software; you can redistribute it and/or modify\r
+# it under the terms of the GNU General Public License as published by\r
+# the Free Software Foundation; either version 2 of the License, or\r
+# (at your option) any later version.\r
+#\r
+# This program is distributed in the hope that it will be useful,\r
+# but WITHOUT ANY WARRANTY; without even the implied warranty of\r
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
+# GNU General Public License for more details.\r
+#\r
+# You should have received a copy of the GNU General Public License\r
+# along with this program; if not, write to the Free Software\r
+# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA\r
+#\r
+# As a special exception, you may use this file as part of a free software\r
+# library without restriction.  Specifically, if other files instantiate\r
+# templates or use macros or inline functions from this file, or you compile\r
+# this file and link it with other files to produce an executable, this\r
+# file does not by itself cause the resulting executable to be covered by\r
+# the GNU General Public License.  This exception does not however\r
+# invalidate any other reasons why the executable file might be covered by\r
+# the GNU General Public License.\r
+#\r
+# Copyright 2008 Develer S.r.l. (http://www.develer.com/)\r
+#\r
+# $Id: const.py 2907 2009-09-08 14:02:04Z duplo $\r
+#\r
+# Author: Lorenzo Berni <duplo@develer.com>\r
+#\r
+\r
+import sys\r
+import os\r
+import traceback\r
+\r
+from PyQt4.QtCore import *\r
+from PyQt4.QtGui import *\r
+\r
+def _excepthook(exc_type, exc_value, exc_traceback):\r
+    project_dir = QApplication.instance().project.info("PROJECT_PATH")\r
+    file_name = os.path.join(project_dir, "wizard_error.log")\r
+    if os.path.exists(file_name):\r
+        content = open(file_name, "r").read()\r
+    else:\r
+        content = ""\r
+    f = open(file_name, "w")\r
+    message = "\n".join(traceback.format_exception(exc_type, exc_value, exc_traceback))\r
+    f.write(message)\r
+    f.write(">"*80 + "\n")\r
+    f.write(content)\r
+    f.close()\r
+    QMessageBox.critical(\r
+        None,\r
+        "Exception occurred",\r
+        "An exception is occurred. Please attach the '%s' file to the support request." %os.path.abspath(file_name),\r
+    )\r
+    QApplication.instance().quit()\r
+\r
+sys.excepthook = _excepthook\r
+\r