annotate orpg/tools/orpg_log.py @ 166:eef2463cd441 alpha

Traipse Alpha 'OpenRPG' {091203-00} 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 (Keeping up with Beta) New Features: Added Bookmarks Added 'boot' command to remote admin Added confirmation window for sent nodes Minor changes to allow for portability to an OpenSUSE linux OS Miniatures Layer pop up box allows users to turn off Mini labels, from FlexiRPG Zoom Mouse plugin added Images added to Plugin UI Switching to Element Tree Map efficiency, from FlexiRPG Added Status Bar to Update Manager New TrueDebug Class in orpg_log (See documentation for usage) Portable Mercurial Tip of the Day added, from Core and community New Reference Syntax added for custom PC sheets New Child Reference for gametree New Gametree Recursion method, mapping, context sensitivity, and effeciency.. New Features node with bonus nodes and Node Referencing help added Added 7th Sea die roller method; ie [7k3] = [7d10.takeHighest(3).open(10)] New 'Mythos' System die roller added Added new vs. die roller method for WoD; ie [3v3] = [3d10.vs(3)]. Includes support for Mythos roller. Fixes: Fix to Text based Server Fix to Remote Admin Commands Fix to Pretty Print, from Core Fix to Splitter Nodes not being created Fix to massive amounts of images loading, from Core Fix to Map from gametree not showing to all clients Fix to gametree about menus Fix to Password Manager check on startup Fix to PC Sheets from tool nodes. They now use the tabber_panel Fixed Whiteboard ID to prevent random line or text deleting. Modified ID's to prevent non updated clients from ruining the fix. default_manifest.xml renamed to default_upmana.xml Fix to Update Manager; cleaner clode for saved repositories Fixes made to Settings Panel and no reactive settings when Ok is pressed.
author sirebral
date Thu, 03 Dec 2009 00:50:44 -0600
parents 2ffc5de126c8
children b633f4c64aae 81d0bfd5e800
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
133
37d26a98883f Traipse Alpha 'OpenRPG' {091010-00}
sirebral
parents: 128
diff changeset
30 import sys, os, os.path, time, traceback, inspect, wx
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 #########################
121
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
40 ORPG_PRINT = 0
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
41 ORPG_CRITICAL = 1
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
42 ORPG_GENERAL = 2
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
43 ORPG_INFO = 4
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
44 ORPG_NOTE = 8
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
45 ORPG_DEBUG = 16
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
46
121
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
47
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
48 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
49 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
50 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
51 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
52 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
53 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
54 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
55 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
56 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
57 logger.exception("Crash Report Created!!")
81
65c212e9a5b4 Controls panel is completed. Users cannot delete branches nicely without a Merc upgrade, so that feature will appear in Pious Paladin. Crash report is being tested on windows.
sirebral
parents: 79
diff changeset
58 logger.info("Printed out crash-report.txt in your System folder", True)
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
59
121
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
60 class Term2Win(object):
141
2ffc5de126c8 Traipse Alpha 'OpenRPG' {091123-01}
sirebral
parents: 133
diff changeset
61 # A stdout redirector. To be implemented later.
121
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
62 def write(self, text):
141
2ffc5de126c8 Traipse Alpha 'OpenRPG' {091123-01}
sirebral
parents: 133
diff changeset
63 logger.stdout(text)
121
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
64 wx.Yield()
141
2ffc5de126c8 Traipse Alpha 'OpenRPG' {091123-01}
sirebral
parents: 133
diff changeset
65 #sys.__stdout__.write(text)
121
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
66
122
36919b8a3ef9 Traipse Alpha 'OpenRPG' {091031-00}
sirebral
parents: 121
diff changeset
67 class TrueDebug(object):
124
8827271fbe1b Traipse Alpha 'OpenRPG' {091001-01}
sirebral
parents: 123
diff changeset
68 """A simple debugger. Add debug() to a function and it prints the function name and any objects included. Add an object or a group of objects in ()'s.
122
36919b8a3ef9 Traipse Alpha 'OpenRPG' {091031-00}
sirebral
parents: 121
diff changeset
69 Adding True to locale prints the file name where the function is. Adding False to log turns the log off.
124
8827271fbe1b Traipse Alpha 'OpenRPG' {091001-01}
sirebral
parents: 123
diff changeset
70 Adding True to parents will print out the parent functions, starting from TrueDebug.
122
36919b8a3ef9 Traipse Alpha 'OpenRPG' {091031-00}
sirebral
parents: 121
diff changeset
71 This feature can be modified to trace deeper and find the bugs faster, ending the puzzle box."""
123
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
72 def __init__(self, objects=None, locale=False, log=True, parents=False):
122
36919b8a3ef9 Traipse Alpha 'OpenRPG' {091031-00}
sirebral
parents: 121
diff changeset
73 if log == False: return
36919b8a3ef9 Traipse Alpha 'OpenRPG' {091031-00}
sirebral
parents: 121
diff changeset
74 current = inspect.currentframe()
123
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
75 if parents: self.get_parents(current)
127
0f720618a8bd Traipse Alpha 'OpenRPG' {091002-01}
sirebral
parents: 124
diff changeset
76 else: self.true_debug(current, objects, locale)
122
36919b8a3ef9 Traipse Alpha 'OpenRPG' {091031-00}
sirebral
parents: 121
diff changeset
77
123
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
78 def true_debug(self, current, objects, locale):
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
79 debug_string = 'Function: ' + str(inspect.getouterframes(current)[1][3])
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
80 #if locale == 'all': print inspect.getouterframes(current)[4]; return
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
81 if objects != None: debug_string += ' Objects: ' + str(objects)
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
82 if locale: debug_string += ' File: ' + str(inspect.getouterframes(current)[1][1])
128
fba298d65cf8 Traipse Alpha 'OpenRPG' {091003-00}
sirebral
parents: 127
diff changeset
83 logger.debug(debug_string, True)
123
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
84 return
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
85
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
86 def get_parents(self, current):
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
87 debug_string = 'Function: ' + str(inspect.getouterframes(current)[1][3]) + ' Parents:'
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
88 family = list(inspect.getouterframes(current))
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
89 for parent in family:
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
90 debug_string += ' ' + str(parent[4])
128
fba298d65cf8 Traipse Alpha 'OpenRPG' {091003-00}
sirebral
parents: 127
diff changeset
91 logger.debug(debug_string, True)
123
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
92 return
122
36919b8a3ef9 Traipse Alpha 'OpenRPG' {091031-00}
sirebral
parents: 121
diff changeset
93
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
94 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
95 def __init__(self, parent):
95
af6bf998f425 Traipse Alpha 'OpenRPG' {090919-00}
sirebral
parents: 86
diff changeset
96 super(DebugConsole, self).__init__(parent, -1, "Debug Console")
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
97 icon = wx.Icon(dir_struct["icon"]+'note.ico', wx.BITMAP_TYPE_ICO)
141
2ffc5de126c8 Traipse Alpha 'OpenRPG' {091123-01}
sirebral
parents: 133
diff changeset
98 self.parent = parent
121
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
99 self.SetIcon(icon)
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
100 self.console = wx.TextCtrl(self, -1, style=wx.TE_MULTILINE | wx.TE_READONLY)
121
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
101 self.bt_clear = wx.Button(self, wx.ID_CLEAR)
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
102 self.report = wx.Button(self, wx.ID_ANY, 'Bug Report')
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
103 sizer = wx.GridBagSizer(hgap=1, vgap=1)
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
104 sizer.Add(self.console, (0,0), span=(1,2), flag=wx.EXPAND)
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
105 sizer.Add(self.bt_clear, (1,0), flag=wx.ALIGN_LEFT)
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
106 sizer.Add(self.report, (1,1), flag=wx.ALIGN_LEFT)
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
107 sizer.AddGrowableCol(0)
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
108 sizer.AddGrowableRow(0)
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
109 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
110 self.SetAutoLayout(True)
121
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
111 self.SetSize((450, 175))
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
112 self.Bind(wx.EVT_CLOSE, self.Min)
121
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
113 self.Bind(wx.EVT_BUTTON, self.clear, self.bt_clear)
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
114 self.Bind(wx.EVT_BUTTON, self.bug_report, self.report)
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
115 self.Min(None)
123
174658f839c0 Traipse Alpha 'OpenRPG' {091001-00}
sirebral
parents: 122
diff changeset
116 #sys.stdout = Term2Win()
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
117 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
118
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
119 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
120 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
121
121
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
122 def clear(self, evt):
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
123 self.console.SetValue('')
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
124
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
125 def bug_report(self, evt):
141
2ffc5de126c8 Traipse Alpha 'OpenRPG' {091123-01}
sirebral
parents: 133
diff changeset
126 self.parent.OnMB_HelpReportaBug()
121
496dbf12a6cb Traipse Alpha 'OpenRPG' {091030-00}
sirebral
parents: 95
diff changeset
127
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
128 class orpgLog(object):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
129 _log_level = 7
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
130 _log_name = None
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
131 _log_to_console = False
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
132 _io = TerminalWriter(sys.stderr)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
133 _lvl_args = None
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
134
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
135 def __new__(cls, *args, **kwargs):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
136 it = cls.__dict__.get("__it__")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
137 if it is not None:
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
138 return it
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
139 cls.__it__ = it = object.__new__(cls)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
140 return it
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
141
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
142 def __init__(self, home_dir, filename='orpgRunLog '):
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
143 self._lvl_args = {16: {'colorizer': {'green': True},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
144 'log_string': 'DEBUG'},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
145 8: {'colorizer': {'bold': True, 'green':True},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
146 'log_string':'NOTE'},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
147 4: {'colorizer': {'blue': True},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
148 'log_string': 'INFO'},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
149 2: {'colorizer': {'red': True},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
150 'log_string': 'ERROR'},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
151 1: {'colorizer': {'bold': True, 'red': True},
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
152 'log_string': 'EXCEPTION'}}
141
2ffc5de126c8 Traipse Alpha 'OpenRPG' {091123-01}
sirebral
parents: 133
diff changeset
153
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
154 if not self.log_name:
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
155 self.log_name = home_dir + filename + time.strftime('%m-%d-%Y.txt',
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
156 time.localtime(time.time()))
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
157
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
158 def debug(self, msg, to_console=False):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
159 self.log(msg, ORPG_DEBUG, to_console)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
160
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
161 def note(self, msg, to_console=False):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
162 self.log(msg, ORPG_NOTE, to_console)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
163
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
164 def info(self, msg, to_console=False):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
165 self.log(msg, ORPG_INFO, to_console)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
166
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
167 def general(self, msg, to_console=False):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
168 self.log(msg, ORPG_GENERAL, to_console)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
169
141
2ffc5de126c8 Traipse Alpha 'OpenRPG' {091123-01}
sirebral
parents: 133
diff changeset
170 def stdout(self, msg, to_console=True):
2ffc5de126c8 Traipse Alpha 'OpenRPG' {091123-01}
sirebral
parents: 133
diff changeset
171 self.log(msg, ORPG_INFO, to_console)
2ffc5de126c8 Traipse Alpha 'OpenRPG' {091123-01}
sirebral
parents: 133
diff changeset
172
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
173 def exception(self, msg, to_console=True):
95
af6bf998f425 Traipse Alpha 'OpenRPG' {090919-00}
sirebral
parents: 86
diff changeset
174 component.get('frame').TraipseSuiteWarn('debug')
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
175 self.log(msg, ORPG_CRITICAL, to_console)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
176
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
177 def log(self, msg, log_type, to_console=False):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
178 if self.log_to_console or to_console or log_type == ORPG_CRITICAL:
82
2fa8bd6785a5 TerminalWriter's colors are nice, but if no debug console is open it causes the software to look for one until a recursion error is created. Crash reports are sent to the debug console and a pop-up tells the user one has happened. Fix to chat window from SnowDog.
sirebral
parents: 81
diff changeset
179 try: self._io.line(str(msg), **self._lvl_args[log_type]['colorizer'])
2fa8bd6785a5 TerminalWriter's colors are nice, but if no debug console is open it causes the software to look for one until a recursion error is created. Crash reports are sent to the debug console and a pop-up tells the user one has happened. Fix to chat window from SnowDog.
sirebral
parents: 81
diff changeset
180 except: pass #Fails without the Debug Console
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
181 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
182 except: pass
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
183
133
37d26a98883f Traipse Alpha 'OpenRPG' {091010-00}
sirebral
parents: 128
diff changeset
184 if log_type and (self.log_level or to_console):
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
185 atr = {'msg': msg, 'level': self._lvl_args[log_type]['log_string']}
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
186 atr['time'] = time.strftime('[%x %X]', time.localtime(time.time()))
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
187 logMsg = '%(time)s (%(level)s) - %(msg)s\n' % (atr)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
188
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
189 with open(self.log_name, 'a') as f:
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
190 f.write(logMsg)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
191
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
192 @pending_deprecation("use logger.log_level = #")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
193 def setLogLevel(self, log_level):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
194 self.log_level = log_level
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
195
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
196 @pending_deprecation("use logger.log_level")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
197 def getLogLevel(self):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
198 return self.log_level
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
199
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
200 @pending_deprecation("use logger.log_name = bla")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
201 def setLogName(self, log_name):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
202 self.log_name = log_name
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
203
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
204 @pending_deprecation("use logger.log_name")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
205 def getLogName(self):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
206 return self.log_name
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
207
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
208 @pending_deprecation("use logger.log_to_console = True/False")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
209 def setLogToConsol(self, true_or_false):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
210 self.log_to_consol = true_or_false
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
211
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
212 @pending_deprecation("use logger.log_to_console")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
213 def getLogToConsol(self):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
214 return self.log_to_consol
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
215
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
216 """
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
217 Property Methods
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
218 """
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
219 def _get_log_level(self):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
220 return self._log_level
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
221 def _set_log_level(self, log_level):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
222 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
223 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
224
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
225 self._log_level = log_level
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
226
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
227 def _get_log_name(self):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
228 return self._log_name
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
229 def _set_log_name(self, name):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
230 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
231 raise IOError("Could not write to the specified location")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
232
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
233 self._log_name = name
0
4385a7d0efd1 Deleted and repushed it with the 'grumpy-goblin' branch. I forgot a y
sirebral
parents:
diff changeset
234
66
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
235 def _get_log_to_console(self):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
236 return self._log_to_console
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
237 def _set_log_to_console(self, true_or_false):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
238 if not isinstance(true_or_false, bool):
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
239 raise TypeError("log_to_console must be a boolean value")
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
240
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
241 self._log_to_console = true_or_false
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
242
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
243 log_level = property(_get_log_level, _set_log_level)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
244 log_name = property(_get_log_name, _set_log_name)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
245 log_to_console = property(_get_log_to_console, _set_log_to_console)
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
246
c54768cffbd4 Traipse Dev 'OpenRPG' {090818-00}
sirebral
parents: 15
diff changeset
247 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
248 crash = sys.excepthook = Crash
122
36919b8a3ef9 Traipse Alpha 'OpenRPG' {091031-00}
sirebral
parents: 121
diff changeset
249 debug = TrueDebug