annotate orpg/tools/orpg_log.py @ 79:dd4be4817377 ornery-dev

Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
author sirebral
date Sun, 23 Aug 2009 14:57:06 -0500
parents c54768cffbd4
children 65c212e9a5b4
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 #
79
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
28
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
29 from __future__ import with_statement
79
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
30 import sys, os, os.path, wx, time, traceback
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
31
79
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
32 from orpg.orpgCore import component
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
33 from orpg.external.terminalwriter import TerminalWriter
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
34 from orpg.tools.decorators import pending_deprecation
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
35 from orpg.dirpath import dir_struct
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
36
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
37 #########################
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
38 ## Error Types
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
39 #########################
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
40 ORPG_CRITICAL = 1
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
41 ORPG_GENERAL = 2
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
42 ORPG_INFO = 4
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
43 ORPG_NOTE = 8
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
44 ORPG_DEBUG = 16
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
45
79
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
46 def Crash(type, value, crash):
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
47 crash_report = open(dir_struct["home"] + 'crash-report.txt', "w")
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
48 traceback.print_exception(type, value, crash, file=crash_report)
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
49 crash_report.close()
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
50 msg = ''
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
51 crash_report = open(dir_struct["home"] + 'crash-report.txt', "r")
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
52 for line in crash_report: msg += line
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
53 logger.exception(msg)
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
54 crash_report.close()
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
55 logger.exception("Crash Report Created!!")
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
56 logger.info("Printed out a datafile called crash-report.txt\nPress <enter> to exit!", True); raw_input('')
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
57 exit()
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
58
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
59 class DebugConsole(wx.Frame):
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
60 def __init__(self, parent):
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
61 super(DebugConsole, self).__init__(parent, -1, "Debug Window")
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
62 icon = None
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
63 icon = wx.Icon(dir_struct["icon"]+'note.ico', wx.BITMAP_TYPE_ICO)
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
64 self.SetIcon( icon )
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
65 self.console = wx.TextCtrl(self, -1, style=wx.TE_MULTILINE | wx.TE_READONLY)
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
66 sizer = wx.BoxSizer(wx.VERTICAL)
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
67 sizer.Add(self.console, 1, wx.EXPAND)
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
68 self.SetSizer(sizer)
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
69 self.SetAutoLayout(True)
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
70 self.SetSize((300, 175))
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
71 self.Bind(wx.EVT_CLOSE, self.Min)
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
72 self.Min(None)
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
73 component.add('debugger', self.console)
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
74
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
75 def Min(self, evt):
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
76 self.Hide()
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
77
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
78 class orpgLog(object):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
79 _log_level = 7
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
80 _log_name = None
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
81 _log_to_console = False
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
82 _io = TerminalWriter(sys.stderr)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
83 _lvl_args = None
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
84
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
85 def __new__(cls, *args, **kwargs):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
86 it = cls.__dict__.get("__it__")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
87 if it is not None:
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
88 return it
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
89 cls.__it__ = it = object.__new__(cls)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
90 return it
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
91
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
92 def __init__(self, home_dir, filename='orpgRunLog '):
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
93 self._lvl_args = {16: {'colorizer': {'green': True},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
94 'log_string': 'DEBUG'},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
95 8: {'colorizer': {'bold': True, 'green':True},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
96 'log_string':'NOTE'},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
97 4: {'colorizer': {'blue': True},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
98 'log_string': 'INFO'},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
99 2: {'colorizer': {'red': True},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
100 'log_string': 'ERROR'},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
101 1: {'colorizer': {'bold': True, 'red': True},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
102 'log_string': 'EXCEPTION'}}
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
103 if not self.log_name:
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
104 self.log_name = home_dir + filename + time.strftime('%m-%d-%Y.txt',
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
105 time.localtime(time.time()))
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
106
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
107 def debug(self, msg, to_console=False):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
108 self.log(msg, ORPG_DEBUG, to_console)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
109
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
110 def note(self, msg, to_console=False):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
111 self.log(msg, ORPG_NOTE, to_console)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
112
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
113 def info(self, msg, to_console=False):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
114 self.log(msg, ORPG_INFO, to_console)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
115
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
116 def general(self, msg, to_console=False):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
117 self.log(msg, ORPG_GENERAL, to_console)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
118
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
119 def exception(self, msg, to_console=True):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
120 self.log(msg, ORPG_CRITICAL, to_console)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
121
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
122 def log(self, msg, log_type, to_console=False):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
123 if self.log_to_console or to_console or log_type == ORPG_CRITICAL:
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
124 self._io.line(str(msg), **self._lvl_args[log_type]['colorizer'])
79
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
125 try: component.get('debugger').AppendText(".. " + str(msg) +'\n')
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
126 except: pass
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
127
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
128 if log_type & self.log_level or to_console:
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
129 atr = {'msg': msg, 'level': self._lvl_args[log_type]['log_string']}
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
130 atr['time'] = time.strftime('[%x %X]', time.localtime(time.time()))
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
131 logMsg = '%(time)s (%(level)s) - %(msg)s\n' % (atr)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
132
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
133 with open(self.log_name, 'a') as f:
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
134 f.write(logMsg)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
135
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
136 @pending_deprecation("use logger.log_level = #")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
137 def setLogLevel(self, log_level):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
138 self.log_level = log_level
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
139
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
140 @pending_deprecation("use logger.log_level")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
141 def getLogLevel(self):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
142 return self.log_level
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
143
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
144 @pending_deprecation("use logger.log_name = bla")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
145 def setLogName(self, log_name):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
146 self.log_name = log_name
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
147
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
148 @pending_deprecation("use logger.log_name")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
149 def getLogName(self):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
150 return self.log_name
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
151
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
152 @pending_deprecation("use logger.log_to_console = True/False")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
153 def setLogToConsol(self, true_or_false):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
154 self.log_to_consol = true_or_false
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
155
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
156 @pending_deprecation("use logger.log_to_console")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
157 def getLogToConsol(self):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
158 return self.log_to_consol
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
159
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
160 """
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
161 Property Methods
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
162 """
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
163 def _get_log_level(self):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
164 return self._log_level
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
165 def _set_log_level(self, log_level):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
166 if not isinstance(log_level, int) or log_level < 1 or log_level > 31:
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
167 raise TypeError("The loggers level must be an int between 1 and 31")
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
168
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
169 self._log_level = log_level
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
170
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
171 def _get_log_name(self):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
172 return self._log_name
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
173 def _set_log_name(self, name):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
174 if not os.access(os.path.abspath(os.path.dirname(name)), os.W_OK):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
175 raise IOError("Could not write to the specified location")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
176
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
177 self._log_name = name
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
178
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
179 def _get_log_to_console(self):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
180 return self._log_to_console
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
181 def _set_log_to_console(self, true_or_false):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
182 if not isinstance(true_or_false, bool):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
183 raise TypeError("log_to_console must be a boolean value")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
184
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
185 self._log_to_console = true_or_false
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
186
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
187 log_level = property(_get_log_level, _set_log_level)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
188 log_name = property(_get_log_name, _set_log_name)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
189 log_to_console = property(_get_log_to_console, _set_log_to_console)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
190
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
191 logger = orpgLog(dir_struct.get("user") + "runlogs/")
79
dd4be4817377 Chat Window no longer prints excessive debug statements to console. Renamed the Update Manager menu item to Traipse Suite. Added debug console to Traipse Suite. Log now prints an error report and waits for user input so Windows users can see the error being reported.
sirebral
parents: 66
diff changeset
192 crash = sys.excepthook = Crash