Refactor to use new protocol module and sipo.
[bertos.git] / wizard / exception_handler.py
1 #!/usr/bin/env python
2 # encoding: utf-8
3 #
4 # This file is part of BeRTOS.
5 #
6 # Bertos is free software; you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License as published by
8 # the Free Software Foundation; either version 2 of the License, or
9 # (at your option) any later version.
10 #
11 # This program is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 # GNU General Public License for more details.
15 #
16 # You should have received a copy of the GNU General Public License
17 # along with this program; if not, write to the Free Software
18 # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
19 #
20 # As a special exception, you may use this file as part of a free software
21 # library without restriction.  Specifically, if other files instantiate
22 # templates or use macros or inline functions from this file, or you compile
23 # this file and link it with other files to produce an executable, this
24 # file does not by itself cause the resulting executable to be covered by
25 # the GNU General Public License.  This exception does not however
26 # invalidate any other reasons why the executable file might be covered by
27 # the GNU General Public License.
28 #
29 # Copyright 2008 Develer S.r.l. (http://www.develer.com/)
30 #
31 #
32 # Author: Lorenzo Berni <duplo@develer.com>
33 #
34
35 import sys
36 import os
37 import traceback
38
39 from PyQt4.QtCore import *
40 from PyQt4.QtGui import *
41
42 def _excepthook(exc_type, exc_value, exc_traceback):
43     project_dir = QApplication.instance().project.info("PROJECT_PATH")
44     if not project_dir:
45         project_dir = os.getcwd()
46     file_name = os.path.join(project_dir, "wizard_error.log")
47     if os.path.exists(file_name):
48         content = open(file_name, "r").read()
49     else:
50         content = ""
51         if not os.path.exists(os.path.dirname(file_name)):
52             os.makedirs(os.path.dirname(file_name))
53     f = open(file_name, "w")
54     message = "\n".join(traceback.format_exception(exc_type, exc_value, exc_traceback))
55     f.write(message)
56     f.write(">"*80 + "\n")
57     f.write(content)
58     f.close()
59     print>>sys.stderr, message
60     QMessageBox.critical(
61         None,
62         "Exception occurred",
63         "An exception is occurred. Please attach the '%s' file to the support request." %os.path.abspath(file_name),
64     )
65     QApplication.instance().quit()
66
67 sys.excepthook = _excepthook
68