Mercurial > traipse
annotate orpg/tools/orpg_log.py @ 20:39ebe168ceb3 ornery-orc
Traipse 'OpenRPG' {090827-02}
Traipse is a distribution of OpenRPG that is designed to be easy to setup and go. Traipse also makes it easy for developers to work on code without fear of sacrifice. 'Ornery-Orc' continues the trend of 'Grumpy' and adds fixes to the code. 'Ornery-Orc''s main goal is to offer more advanced features and enhance the productivity of the user.
Update Summary:
Update Manager is now in version 0.8. While not every button works, users can now browse the different revisions and their different changesets. The code has been refined some with feature from Core added to it. A Crash report is now created if the users software crashes. Update Manager has been moved to the Traipse Suite menu item, and a Debug Console as been added as well.
Please Check the Controls Panel to see the other files changed.
author | sirebral |
---|---|
date | Thu, 27 Aug 2009 01:11:22 -0500 |
parents | 97265586402b |
children | 51428d30c59e |
rev | line source |
---|---|
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
1 # Copyright (C) 2000-2001 The OpenRPG Project |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
2 # |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
3 # openrpg-dev@lists.sourceforge.net |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
4 # |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
5 # This program is free software; you can redistribute it and/or modify |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
6 # it under the terms of the GNU General Public License as published by |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
7 # the Free Software Foundation; either version 2 of the License, or |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
8 # (at your option) any later version. |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
9 # |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
10 # This program is distributed in the hope that it will be useful, |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
13 # GNU General Public License for more details. |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
14 # |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
15 # You should have received a copy of the GNU General Public License |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
16 # along with this program; if not, write to the Free Software |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
17 # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
18 # -- |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
19 # |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
20 # File: orpg_log.py |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
21 # Author: Dj Gilcrease |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
22 # Maintainer: |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
23 # Version: |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
24 # $Id: orpg_log.py,v 1.9 2007/05/06 16:43:02 digitalxero Exp $ |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
25 # |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
26 # Description: classes for orpg log messages |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
27 # |
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
28 |
18 | 29 from __future__ import with_statement |
30 import sys, os, os.path, wx, time, traceback | |
31 | |
32 from orpg.orpgCore import component | |
33 from orpg.external.terminalwriter import TerminalWriter | |
34 from orpg.tools.decorators import pending_deprecation | |
35 from orpg.dirpath import dir_struct | |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
36 |
18 | 37 ######################### |
38 ## Error Types | |
39 ######################### | |
40 ORPG_CRITICAL = 1 | |
41 ORPG_GENERAL = 2 | |
42 ORPG_INFO = 4 | |
43 ORPG_NOTE = 8 | |
44 ORPG_DEBUG = 16 | |
45 | |
46 def Crash(type, value, crash): | |
47 crash_report = open(dir_struct["home"] + 'crash-report.txt', "w") | |
48 traceback.print_exception(type, value, crash, file=crash_report) | |
49 crash_report.close() | |
50 msg = '' | |
51 crash_report = open(dir_struct["home"] + 'crash-report.txt', "r") | |
52 for line in crash_report: msg += line | |
53 logger.exception(msg) | |
54 crash_report.close() | |
55 logger.exception("Crash Report Created!!") | |
56 logger.info("Printed out crash-report.txt in your System folder", True) | |
57 wx.MessageBox('Crash Report Created!', 'System Failure') | |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
58 |
18 | 59 class DebugConsole(wx.Frame): |
60 def __init__(self, parent): | |
61 super(DebugConsole, self).__init__(parent, -1, "Debug Window") | |
62 icon = None | |
63 icon = wx.Icon(dir_struct["icon"]+'note.ico', wx.BITMAP_TYPE_ICO) | |
64 self.SetIcon( icon ) | |
65 self.console = wx.TextCtrl(self, -1, style=wx.TE_MULTILINE | wx.TE_READONLY) | |
66 sizer = wx.BoxSizer(wx.VERTICAL) | |
67 sizer.Add(self.console, 1, wx.EXPAND) | |
68 self.SetSizer(sizer) | |
69 self.SetAutoLayout(True) | |
70 self.SetSize((300, 175)) | |
71 self.Bind(wx.EVT_CLOSE, self.Min) | |
72 self.Min(None) | |
73 component.add('debugger', self.console) | |
74 | |
75 def Min(self, evt): | |
76 self.Hide() | |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
77 |
18 | 78 class orpgLog(object): |
79 _log_level = 7 | |
80 _log_name = None | |
81 _log_to_console = False | |
82 _io = TerminalWriter(sys.stderr) | |
83 _lvl_args = None | |
84 | |
85 def __new__(cls, *args, **kwargs): | |
86 it = cls.__dict__.get("__it__") | |
87 if it is not None: | |
88 return it | |
89 cls.__it__ = it = object.__new__(cls) | |
90 return it | |
91 | |
92 def __init__(self, home_dir, filename='orpgRunLog '): | |
93 self._lvl_args = {16: {'colorizer': {'green': True}, | |
94 'log_string': 'DEBUG'}, | |
95 8: {'colorizer': {'bold': True, 'green':True}, | |
96 'log_string':'NOTE'}, | |
97 4: {'colorizer': {'blue': True}, | |
98 'log_string': 'INFO'}, | |
99 2: {'colorizer': {'red': True}, | |
100 'log_string': 'ERROR'}, | |
101 1: {'colorizer': {'bold': True, 'red': True}, | |
102 'log_string': 'EXCEPTION'}} | |
103 if not self.log_name: | |
104 self.log_name = home_dir + filename + time.strftime('%m-%d-%Y.txt', | |
105 time.localtime(time.time())) | |
106 | |
107 def debug(self, msg, to_console=False): | |
108 self.log(msg, ORPG_DEBUG, to_console) | |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
109 |
18 | 110 def note(self, msg, to_console=False): |
111 self.log(msg, ORPG_NOTE, to_console) | |
112 | |
113 def info(self, msg, to_console=False): | |
114 self.log(msg, ORPG_INFO, to_console) | |
115 | |
116 def general(self, msg, to_console=False): | |
117 self.log(msg, ORPG_GENERAL, to_console) | |
118 | |
119 def exception(self, msg, to_console=True): | |
120 self.log(msg, ORPG_CRITICAL, to_console) | |
121 | |
122 def log(self, msg, log_type, to_console=False): | |
123 if self.log_to_console or to_console or log_type == ORPG_CRITICAL: | |
124 try: self._io.line(str(msg), **self._lvl_args[log_type]['colorizer']) | |
125 except: pass #Fails without the Debug Console | |
126 try: component.get('debugger').AppendText(".. " + str(msg) +'\n') | |
127 except: pass | |
128 | |
129 if log_type & self.log_level or to_console: | |
130 atr = {'msg': msg, 'level': self._lvl_args[log_type]['log_string']} | |
131 atr['time'] = time.strftime('[%x %X]', time.localtime(time.time())) | |
132 logMsg = '%(time)s (%(level)s) - %(msg)s\n' % (atr) | |
133 | |
134 with open(self.log_name, 'a') as f: | |
135 f.write(logMsg) | |
136 | |
137 @pending_deprecation("use logger.log_level = #") | |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
138 def setLogLevel(self, log_level): |
18 | 139 self.log_level = log_level |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
140 |
18 | 141 @pending_deprecation("use logger.log_level") |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
142 def getLogLevel(self): |
18 | 143 return self.log_level |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
144 |
18 | 145 @pending_deprecation("use logger.log_name = bla") |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
146 def setLogName(self, log_name): |
18 | 147 self.log_name = log_name |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
148 |
18 | 149 @pending_deprecation("use logger.log_name") |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
150 def getLogName(self): |
18 | 151 return self.log_name |
152 | |
153 @pending_deprecation("use logger.log_to_console = True/False") | |
154 def setLogToConsol(self, true_or_false): | |
155 self.log_to_consol = true_or_false | |
156 | |
157 @pending_deprecation("use logger.log_to_console") | |
158 def getLogToConsol(self): | |
159 return self.log_to_consol | |
160 | |
161 """ | |
162 Property Methods | |
163 """ | |
164 def _get_log_level(self): | |
165 return self._log_level | |
166 def _set_log_level(self, log_level): | |
167 if not isinstance(log_level, int) or log_level < 1 or log_level > 31: | |
168 raise TypeError("The loggers level must be an int between 1 and 31") | |
169 | |
170 self._log_level = log_level | |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
171 |
18 | 172 def _get_log_name(self): |
173 return self._log_name | |
174 def _set_log_name(self, name): | |
175 if not os.access(os.path.abspath(os.path.dirname(name)), os.W_OK): | |
176 raise IOError("Could not write to the specified location") | |
177 | |
178 self._log_name = name | |
0
4385a7d0efd1
Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff
changeset
|
179 |
18 | 180 def _get_log_to_console(self): |
181 return self._log_to_console | |
182 def _set_log_to_console(self, true_or_false): | |
183 if not isinstance(true_or_false, bool): | |
184 raise TypeError("log_to_console must be a boolean value") | |
185 | |
186 self._log_to_console = true_or_false | |
187 | |
188 log_level = property(_get_log_level, _set_log_level) | |
189 log_name = property(_get_log_name, _set_log_name) | |
190 log_to_console = property(_get_log_to_console, _set_log_to_console) | |
191 | |
192 logger = orpgLog(dir_struct.get("user") + "runlogs/") | |
193 crash = sys.excepthook = Crash |