Mercurial > p > roundup > code
annotate roundup/cgi/cgitb.py @ 6150:edbd4bba728a
Add 'is_restore_ok' method
| author | Ralf Schlatterbeck <rsc@runtux.com> |
|---|---|
| date | Fri, 01 May 2020 16:33:05 +0200 |
| parents | 883c9e90b403 |
| children | 70e6b053193b |
| rev | line source |
|---|---|
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
1 # |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
2 # This module was written by Ka-Ping Yee, <ping@lfw.org>. |
|
2426
cafdf8b7cc69
use templating translation service instead of commandline-oriented gettext()
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2005
diff
changeset
|
3 # |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
4 |
|
2005
fc52d57c6c3e
documentation cleanup
Richard Jones <richard@users.sourceforge.net>
parents:
1947
diff
changeset
|
5 """Extended CGI traceback handler by Ka-Ping Yee, <ping@lfw.org>. |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
6 """ |
|
5376
64b05e24dbd8
Python 3 preparation: convert print to a function.
Joseph Myers <jsm@polyomino.org.uk>
parents:
4570
diff
changeset
|
7 from __future__ import print_function |
|
2005
fc52d57c6c3e
documentation cleanup
Richard Jones <richard@users.sourceforge.net>
parents:
1947
diff
changeset
|
8 __docformat__ = 'restructuredtext' |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
9 |
|
5434
1ab2c81a64df
Python 3 preparation: avoid string.join().
Joseph Myers <jsm@polyomino.org.uk>
parents:
5433
diff
changeset
|
10 import sys, os, keyword, linecache, tokenize, inspect, cgi |
|
1079
04b44df7af1d
removed some property name clashes
Richard Jones <richard@users.sourceforge.net>
parents:
1066
diff
changeset
|
11 import pydoc, traceback |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
12 |
|
5837
883c9e90b403
Fix problem with cgi.escape being depricated a different way. This way
John Rouillard <rouilj@ieee.org>
parents:
5800
diff
changeset
|
13 from roundup.anypy.html import html_escape |
|
5800
1a835db41674
Call cgi.escape only on python 2. Replace with html.escapeif it can be
John Rouillard <rouilj@ieee.org>
parents:
5436
diff
changeset
|
14 |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
15 from roundup.cgi import templating, TranslationService |
|
5436
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
16 from roundup.anypy.strings import s2b |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
17 |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
18 def get_translator(i18n=None): |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
19 """Return message translation function (gettext) |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
20 |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
21 Parameters: |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
22 i18n - translation service, such as roundup.i18n module |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
23 or TranslationService object. |
|
2426
cafdf8b7cc69
use templating translation service instead of commandline-oriented gettext()
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2005
diff
changeset
|
24 |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
25 Return ``gettext`` attribute of the ``i18n`` object, if available |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
26 (must be a message translation function with one argument). |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
27 If ``gettext`` cannot be obtained from ``i18n``, take default |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
28 TranslationService. |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
29 |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
30 """ |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
31 try: |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
32 return i18n.gettext |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
33 except: |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
34 return TranslationService.get_translation().gettext |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
35 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
36 def breaker(): |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
37 return ('<body bgcolor="white">' + |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
38 '<font color="white" size="-5"> > </font> ' + |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
39 '</table>' * 5) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
40 |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
41 def niceDict(indent, dict): |
|
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
42 l = [] |
|
4362
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
43 for k in sorted(dict): |
|
4264
b1e614c6759f
Improve error reporting.
Stefan Seefeld <stefan@seefeld.name>
parents:
2564
diff
changeset
|
44 v = dict[k] |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
45 l.append('<tr><td><strong>%s</strong></td><td>%s</td></tr>'%(k, |
|
5800
1a835db41674
Call cgi.escape only on python 2. Replace with html.escapeif it can be
John Rouillard <rouilj@ieee.org>
parents:
5436
diff
changeset
|
46 html_escape(repr(v)))) |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
47 return '\n'.join(l) |
|
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
48 |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
49 def pt_html(context=5, i18n=None): |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
50 _ = get_translator(i18n) |
|
5800
1a835db41674
Call cgi.escape only on python 2. Replace with html.escapeif it can be
John Rouillard <rouilj@ieee.org>
parents:
5436
diff
changeset
|
51 esc = html_escape |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
52 exc_info = [esc(str(value)) for value in sys.exc_info()[:2]] |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
53 l = [_('<h1>Templating Error</h1>\n' |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
54 '<p><b>%(exc_type)s</b>: %(exc_value)s</p>\n' |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
55 '<p class="help">Debugging information follows</p>' |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
56 ) % {'exc_type': exc_info[0], 'exc_value': exc_info[1]}, |
|
1396
cce5b4309005
extra info in template error report
Richard Jones <richard@users.sourceforge.net>
parents:
1204
diff
changeset
|
57 '<ol>',] |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
58 from roundup.cgi.PageTemplates.Expressions import TraversalError |
|
1204
b862bbf2067a
Replaced the content() callback ickiness with Page Template macro usage
Richard Jones <richard@users.sourceforge.net>
parents:
1136
diff
changeset
|
59 t = inspect.trace(context) |
|
b862bbf2067a
Replaced the content() callback ickiness with Page Template macro usage
Richard Jones <richard@users.sourceforge.net>
parents:
1136
diff
changeset
|
60 t.reverse() |
|
b862bbf2067a
Replaced the content() callback ickiness with Page Template macro usage
Richard Jones <richard@users.sourceforge.net>
parents:
1136
diff
changeset
|
61 for frame, file, lnum, func, lines, index in t: |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
62 args, varargs, varkw, locals = inspect.getargvalues(frame) |
|
4362
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
63 if '__traceback_info__' in locals: |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
64 ti = locals['__traceback_info__'] |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
65 if isinstance(ti, TraversalError): |
|
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
66 s = [] |
|
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
67 for name, info in ti.path: |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
68 s.append(_('<li>"%(name)s" (%(info)s)</li>') |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
69 % {'name': name, 'info': esc(repr(info))}) |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
70 s = '\n'.join(s) |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
71 l.append(_('<li>Looking for "%(name)s", ' |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
72 'current path:<ol>%(path)s</ol></li>' |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
73 ) % {'name': ti.name, 'path': s}) |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
74 else: |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
75 l.append(_('<li>In %s</li>') % esc(str(ti))) |
|
4362
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
76 if '__traceback_supplement__' in locals: |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
77 ts = locals['__traceback_supplement__'] |
|
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
78 if len(ts) == 2: |
|
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
79 supp, context = ts |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
80 s = _('A problem occurred in your template "%s".') \ |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
81 % str(context.id) |
|
1204
b862bbf2067a
Replaced the content() callback ickiness with Page Template macro usage
Richard Jones <richard@users.sourceforge.net>
parents:
1136
diff
changeset
|
82 if context._v_errors: |
|
b862bbf2067a
Replaced the content() callback ickiness with Page Template macro usage
Richard Jones <richard@users.sourceforge.net>
parents:
1136
diff
changeset
|
83 s = s + '<br>' + '<br>'.join( |
|
1396
cce5b4309005
extra info in template error report
Richard Jones <richard@users.sourceforge.net>
parents:
1204
diff
changeset
|
84 [esc(x) for x in context._v_errors]) |
|
1204
b862bbf2067a
Replaced the content() callback ickiness with Page Template macro usage
Richard Jones <richard@users.sourceforge.net>
parents:
1136
diff
changeset
|
85 l.append('<li>%s</li>'%s) |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
86 elif len(ts) == 3: |
|
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
87 supp, context, info = ts |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
88 l.append(_(''' |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
89 <li>While evaluating the %(info)r expression on line %(line)d |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
90 <table class="otherinfo" style="font-size: 90%%"> |
|
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
91 <tr><th colspan="2" class="header">Current variables:</th></tr> |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
92 %(globals)s |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
93 %(locals)s |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
94 </table></li> |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
95 ''') % { |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
96 'info': info, |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
97 'line': context.position[0], |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
98 'globals': niceDict(' ', context.global_vars), |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
99 'locals': niceDict(' ', context.local_vars) |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
100 }) |
|
1079
04b44df7af1d
removed some property name clashes
Richard Jones <richard@users.sourceforge.net>
parents:
1066
diff
changeset
|
101 |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
102 l.append(''' |
|
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
103 </ol> |
|
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
104 <table style="font-size: 80%%; color: gray"> |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
105 <tr><th class="header" align="left">%s</th></tr> |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
106 <tr><td><pre>%s</pre></td></tr> |
|
5800
1a835db41674
Call cgi.escape only on python 2. Replace with html.escapeif it can be
John Rouillard <rouilj@ieee.org>
parents:
5436
diff
changeset
|
107 </table>''' % (_('Full traceback:'), html_escape(''.join( |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
108 traceback.format_exception(*sys.exc_info()) |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
109 )))) |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
110 l.append('<p> </p>') |
|
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
111 return '\n'.join(l) |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
112 |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
113 def html(context=5, i18n=None): |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
114 _ = get_translator(i18n) |
|
4362
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
115 etype, evalue = sys.exc_info()[0], sys.exc_info()[1] |
|
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
116 if type(etype) is type: |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
117 etype = etype.__name__ |
|
5433
86b6cea7a975
Python 3 preparation: avoid string.split().
Joseph Myers <jsm@polyomino.org.uk>
parents:
5420
diff
changeset
|
118 pyver = 'Python ' + sys.version.split()[0] + '<br>' + sys.executable |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
119 head = pydoc.html.heading( |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
120 _('<font size=+1><strong>%(exc_type)s</strong>: %(exc_value)s</font>') |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
121 % {'exc_type': etype, 'exc_value': evalue}, |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
122 '#ffffff', '#777777', pyver) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
123 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
124 head = head + (_('<p>A problem occurred while running a Python script. ' |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
125 'Here is the sequence of function calls leading up to ' |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
126 'the error, with the most recent (innermost) call first. ' |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
127 'The exception attributes are:')) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
128 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
129 indent = '<tt><small>%s</small> </tt>' % (' ' * 5) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
130 traceback = [] |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
131 for frame, file, lnum, func, lines, index in inspect.trace(context): |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
132 if file is None: |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
133 link = _("<file is None - probably inside <tt>eval</tt> " |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
134 "or <tt>exec</tt>>") |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
135 else: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
136 file = os.path.abspath(file) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
137 link = '<a href="file:%s">%s</a>' % (file, pydoc.html.escape(file)) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
138 args, varargs, varkw, locals = inspect.getargvalues(frame) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
139 if func == '?': |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
140 call = '' |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
141 else: |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
142 call = _('in <strong>%s</strong>') % func + inspect.formatargvalues( |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
143 args, varargs, varkw, locals, |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
144 formatvalue=lambda value: '=' + pydoc.html.repr(value)) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
145 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
146 level = ''' |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
147 <table width="100%%" bgcolor="#dddddd" cellspacing=0 cellpadding=2 border=0> |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
148 <tr><td>%s %s</td></tr></table>''' % (link, call) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
149 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
150 if index is None or file is None: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
151 traceback.append('<p>' + level) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
152 continue |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
153 |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
154 # do a file inspection |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
155 names = [] |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
156 def tokeneater(type, token, start, end, line, names=names): |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
157 if type == tokenize.NAME and token not in keyword.kwlist: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
158 if token not in names: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
159 names.append(token) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
160 if type == tokenize.NEWLINE: raise IndexError |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
161 def linereader(file=file, lnum=[lnum]): |
|
5436
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
162 line = s2b(linecache.getline(file, lnum[0])) |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
163 lnum[0] = lnum[0] + 1 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
164 return line |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
165 |
|
5436
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
166 # The interface that is tokenize.tokenize in Python 3 is |
|
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
167 # called tokenize.generate_tokens in Python 2. However, |
|
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
168 # Python 2 has tokenize.tokenize with a different interface, |
|
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
169 # and Python 3 has an undocumented generate_tokens function, |
|
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
170 # also with a different interface, so a version check is |
|
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
171 # needed instead of checking for which functions exist. |
|
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
172 if sys.version_info[0] > 2: |
|
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
173 tokenize_fn = tokenize.tokenize |
|
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
174 else: |
|
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
175 tokenize_fn = tokenize.generate_tokens |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
176 try: |
|
5436
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
177 for t in tokenize_fn(linereader): |
|
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
178 tokeneater(*t) |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
179 except IndexError: |
|
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
180 pass |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
181 lvals = [] |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
182 for name in names: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
183 if name in frame.f_code.co_varnames: |
|
4362
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
184 if name in locals: |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
185 value = pydoc.html.repr(locals[name]) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
186 else: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
187 value = _('<em>undefined</em>') |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
188 name = '<strong>%s</strong>' % name |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
189 else: |
|
4362
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
190 if name in frame.f_globals: |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
191 value = pydoc.html.repr(frame.f_globals[name]) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
192 else: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
193 value = _('<em>undefined</em>') |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
194 name = '<em>global</em> <strong>%s</strong>' % name |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
195 lvals.append('%s = %s'%(name, value)) |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
196 if lvals: |
|
5434
1ab2c81a64df
Python 3 preparation: avoid string.join().
Joseph Myers <jsm@polyomino.org.uk>
parents:
5433
diff
changeset
|
197 lvals = ', '.join(lvals) |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
198 lvals = indent + '<small><font color="#909090">%s'\ |
|
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
199 '</font></small><br>'%lvals |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
200 else: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
201 lvals = '' |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
202 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
203 excerpt = [] |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
204 i = lnum - index |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
205 for line in lines: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
206 number = ' ' * (5-len(str(i))) + str(i) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
207 number = '<small><font color="#909090">%s</font></small>' % number |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
208 line = '<tt>%s %s</tt>' % (number, pydoc.html.preformat(line)) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
209 if i == lnum: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
210 line = ''' |
|
1947
0e19e99075e3
fix #white in cgitb
Richard Jones <richard@users.sourceforge.net>
parents:
1396
diff
changeset
|
211 <table width="100%%" bgcolor="white" cellspacing=0 cellpadding=0 border=0> |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
212 <tr><td>%s</td></tr></table>''' % line |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
213 excerpt.append('\n' + line) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
214 if i == lnum: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
215 excerpt.append(lvals) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
216 i = i + 1 |
|
5434
1ab2c81a64df
Python 3 preparation: avoid string.join().
Joseph Myers <jsm@polyomino.org.uk>
parents:
5433
diff
changeset
|
217 traceback.append('<p>' + level + '\n'.join(excerpt)) |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
218 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
219 traceback.reverse() |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
220 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
221 exception = '<p><strong>%s</strong>: %s' % (str(etype), str(evalue)) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
222 attribs = [] |
|
5420
7172c201dec2
Python 3 preparation: avoid obsolete types.*Type names.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5376
diff
changeset
|
223 for name in dir(evalue): |
|
7172c201dec2
Python 3 preparation: avoid obsolete types.*Type names.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5376
diff
changeset
|
224 value = pydoc.html.repr(getattr(evalue, name)) |
|
7172c201dec2
Python 3 preparation: avoid obsolete types.*Type names.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5376
diff
changeset
|
225 attribs.append('<br>%s%s = %s' % (indent, name, value)) |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
226 |
|
5434
1ab2c81a64df
Python 3 preparation: avoid string.join().
Joseph Myers <jsm@polyomino.org.uk>
parents:
5433
diff
changeset
|
227 return head + ' '.join(attribs) + ' '.join(traceback) + '<p> </p>' |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
228 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
229 def handler(): |
|
5376
64b05e24dbd8
Python 3 preparation: convert print to a function.
Joseph Myers <jsm@polyomino.org.uk>
parents:
4570
diff
changeset
|
230 print(breaker()) |
|
64b05e24dbd8
Python 3 preparation: convert print to a function.
Joseph Myers <jsm@polyomino.org.uk>
parents:
4570
diff
changeset
|
231 print(html()) |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
232 |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
233 # vim: set filetype=python ts=4 sw=4 et si : |
