Mercurial > p > roundup > code
annotate roundup/cgi/cgitb.py @ 5814:bd6d41f21a5a
More extensive EditCSV testing.
Uses test object to cover all types defined by database.
Also check for an error with a row that's too short.
CSV starts with blank line to verify that it recognises header line.
Changes password, date, int, link and other fields.
Deletes row and verified that it is retired.
Make actions.py properly handle emptying of password field.
| author | John Rouillard <rouilj@ieee.org> |
|---|---|
| date | Fri, 14 Jun 2019 21:26:19 -0400 |
| parents | 1a835db41674 |
| children | 883c9e90b403 |
| 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 |
|
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
|
13 try: |
|
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 from html import escape as html_escape # python 3 |
|
1a835db41674
Call cgi.escape only on python 2. Replace with html.escapeif it can be
John Rouillard <rouilj@ieee.org>
parents:
5436
diff
changeset
|
15 except ImportError: |
|
1a835db41674
Call cgi.escape only on python 2. Replace with html.escapeif it can be
John Rouillard <rouilj@ieee.org>
parents:
5436
diff
changeset
|
16 from cgi import escape as html_escape # python 2 fallback |
|
1a835db41674
Call cgi.escape only on python 2. Replace with html.escapeif it can be
John Rouillard <rouilj@ieee.org>
parents:
5436
diff
changeset
|
17 |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
18 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
|
19 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
|
20 |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
21 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
|
22 """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
|
23 |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
24 Parameters: |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
25 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
|
26 or TranslationService object. |
|
2426
cafdf8b7cc69
use templating translation service instead of commandline-oriented gettext()
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2005
diff
changeset
|
27 |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
28 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
|
29 (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
|
30 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
|
31 TranslationService. |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
32 |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
33 """ |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
34 try: |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
35 return i18n.gettext |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
36 except: |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
37 return TranslationService.get_translation().gettext |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
38 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
39 def breaker(): |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
40 return ('<body bgcolor="white">' + |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
41 '<font color="white" size="-5"> > </font> ' + |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
42 '</table>' * 5) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
43 |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
44 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
|
45 l = [] |
|
4362
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
46 for k in sorted(dict): |
|
4264
b1e614c6759f
Improve error reporting.
Stefan Seefeld <stefan@seefeld.name>
parents:
2564
diff
changeset
|
47 v = dict[k] |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
48 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
|
49 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
|
50 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
|
51 |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
52 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
|
53 _ = 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
|
54 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
|
55 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
|
56 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
|
57 '<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
|
58 '<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
|
59 ) % {'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
|
60 '<ol>',] |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
61 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
|
62 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
|
63 t.reverse() |
|
b862bbf2067a
Replaced the content() callback ickiness with Page Template macro usage
Richard Jones <richard@users.sourceforge.net>
parents:
1136
diff
changeset
|
64 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
|
65 args, varargs, varkw, locals = inspect.getargvalues(frame) |
|
4362
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
66 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
|
67 ti = locals['__traceback_info__'] |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
68 if isinstance(ti, TraversalError): |
|
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
69 s = [] |
|
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
70 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
|
71 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
|
72 % {'name': name, 'info': esc(repr(info))}) |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
73 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
|
74 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
|
75 '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
|
76 ) % {'name': ti.name, 'path': s}) |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
77 else: |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
78 l.append(_('<li>In %s</li>') % esc(str(ti))) |
|
4362
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
79 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
|
80 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
|
81 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
|
82 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
|
83 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
|
84 % 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
|
85 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
|
86 s = s + '<br>' + '<br>'.join( |
|
1396
cce5b4309005
extra info in template error report
Richard Jones <richard@users.sourceforge.net>
parents:
1204
diff
changeset
|
87 [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
|
88 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
|
89 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
|
90 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
|
91 l.append(_(''' |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
92 <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
|
93 <table class="otherinfo" style="font-size: 90%%"> |
|
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
94 <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
|
95 %(globals)s |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
96 %(locals)s |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
97 </table></li> |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
98 ''') % { |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
99 'info': info, |
|
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
100 '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
|
101 '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
|
102 '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
|
103 }) |
|
1079
04b44df7af1d
removed some property name clashes
Richard Jones <richard@users.sourceforge.net>
parents:
1066
diff
changeset
|
104 |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
105 l.append(''' |
|
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
106 </ol> |
|
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
107 <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
|
108 <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
|
109 <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
|
110 </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
|
111 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
|
112 )))) |
|
1136
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
113 l.append('<p> </p>') |
|
7e193bbda38e
added generic item editing
Richard Jones <richard@users.sourceforge.net>
parents:
1092
diff
changeset
|
114 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
|
115 |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
116 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
|
117 _ = get_translator(i18n) |
|
4362
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
118 etype, evalue = sys.exc_info()[0], sys.exc_info()[1] |
|
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
119 if type(etype) is type: |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
120 etype = etype.__name__ |
|
5433
86b6cea7a975
Python 3 preparation: avoid string.split().
Joseph Myers <jsm@polyomino.org.uk>
parents:
5420
diff
changeset
|
121 pyver = 'Python ' + sys.version.split()[0] + '<br>' + sys.executable |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
122 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
|
123 _('<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
|
124 % {'exc_type': etype, 'exc_value': evalue}, |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
125 '#ffffff', '#777777', pyver) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
126 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
127 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
|
128 'Here is the sequence of function calls leading up to ' |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
129 'the error, with the most recent (innermost) call first. ' |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
130 'The exception attributes are:')) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
131 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
132 indent = '<tt><small>%s</small> </tt>' % (' ' * 5) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
133 traceback = [] |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
134 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
|
135 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
|
136 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
|
137 "or <tt>exec</tt>>") |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
138 else: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
139 file = os.path.abspath(file) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
140 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
|
141 args, varargs, varkw, locals = inspect.getargvalues(frame) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
142 if func == '?': |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
143 call = '' |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
144 else: |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
145 call = _('in <strong>%s</strong>') % func + inspect.formatargvalues( |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
146 args, varargs, varkw, locals, |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
147 formatvalue=lambda value: '=' + pydoc.html.repr(value)) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
148 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
149 level = ''' |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
150 <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
|
151 <tr><td>%s %s</td></tr></table>''' % (link, call) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
152 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
153 if index is None or file is None: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
154 traceback.append('<p>' + level) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
155 continue |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
156 |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
157 # do a file inspection |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
158 names = [] |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
159 def tokeneater(type, token, start, end, line, names=names): |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
160 if type == tokenize.NAME and token not in keyword.kwlist: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
161 if token not in names: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
162 names.append(token) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
163 if type == tokenize.NEWLINE: raise IndexError |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
164 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
|
165 line = s2b(linecache.getline(file, lnum[0])) |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
166 lnum[0] = lnum[0] + 1 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
167 return line |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
168 |
|
5436
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
169 # 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
|
170 # 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
|
171 # 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
|
172 # 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
|
173 # 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
|
174 # 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
|
175 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
|
176 tokenize_fn = tokenize.tokenize |
|
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
177 else: |
|
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
178 tokenize_fn = tokenize.generate_tokens |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
179 try: |
|
5436
e70fe1d1215b
Python 3 preparation: update tokenize use in cgitb.py.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5434
diff
changeset
|
180 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
|
181 tokeneater(*t) |
|
1065
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
182 except IndexError: |
|
0f9aa62917bd
much nicer error messages when there's a templating error
Richard Jones <richard@users.sourceforge.net>
parents:
985
diff
changeset
|
183 pass |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
184 lvals = [] |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
185 for name in names: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
186 if name in frame.f_code.co_varnames: |
|
4362
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
187 if name in locals: |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
188 value = pydoc.html.repr(locals[name]) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
189 else: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
190 value = _('<em>undefined</em>') |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
191 name = '<strong>%s</strong>' % name |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
192 else: |
|
4362
74476eaac38a
more modernisation
Richard Jones <richard@users.sourceforge.net>
parents:
4264
diff
changeset
|
193 if name in frame.f_globals: |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
194 value = pydoc.html.repr(frame.f_globals[name]) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
195 else: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
196 value = _('<em>undefined</em>') |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
197 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
|
198 lvals.append('%s = %s'%(name, value)) |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
199 if lvals: |
|
5434
1ab2c81a64df
Python 3 preparation: avoid string.join().
Joseph Myers <jsm@polyomino.org.uk>
parents:
5433
diff
changeset
|
200 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
|
201 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
|
202 '</font></small><br>'%lvals |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
203 else: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
204 lvals = '' |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
205 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
206 excerpt = [] |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
207 i = lnum - index |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
208 for line in lines: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
209 number = ' ' * (5-len(str(i))) + str(i) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
210 number = '<small><font color="#909090">%s</font></small>' % number |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
211 line = '<tt>%s %s</tt>' % (number, pydoc.html.preformat(line)) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
212 if i == lnum: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
213 line = ''' |
|
1947
0e19e99075e3
fix #white in cgitb
Richard Jones <richard@users.sourceforge.net>
parents:
1396
diff
changeset
|
214 <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
|
215 <tr><td>%s</td></tr></table>''' % line |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
216 excerpt.append('\n' + line) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
217 if i == lnum: |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
218 excerpt.append(lvals) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
219 i = i + 1 |
|
5434
1ab2c81a64df
Python 3 preparation: avoid string.join().
Joseph Myers <jsm@polyomino.org.uk>
parents:
5433
diff
changeset
|
220 traceback.append('<p>' + level + '\n'.join(excerpt)) |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
221 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
222 traceback.reverse() |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
223 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
224 exception = '<p><strong>%s</strong>: %s' % (str(etype), str(evalue)) |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
225 attribs = [] |
|
5420
7172c201dec2
Python 3 preparation: avoid obsolete types.*Type names.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5376
diff
changeset
|
226 for name in dir(evalue): |
|
7172c201dec2
Python 3 preparation: avoid obsolete types.*Type names.
Joseph Myers <jsm@polyomino.org.uk>
parents:
5376
diff
changeset
|
227 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
|
228 attribs.append('<br>%s%s = %s' % (indent, name, value)) |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
229 |
|
5434
1ab2c81a64df
Python 3 preparation: avoid string.join().
Joseph Myers <jsm@polyomino.org.uk>
parents:
5433
diff
changeset
|
230 return head + ' '.join(attribs) + ' '.join(traceback) + '<p> </p>' |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
231 |
|
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
232 def handler(): |
|
5376
64b05e24dbd8
Python 3 preparation: convert print to a function.
Joseph Myers <jsm@polyomino.org.uk>
parents:
4570
diff
changeset
|
233 print(breaker()) |
|
64b05e24dbd8
Python 3 preparation: convert print to a function.
Joseph Myers <jsm@polyomino.org.uk>
parents:
4570
diff
changeset
|
234 print(html()) |
|
985
55ab0c5b49f9
New CGI interface support
Richard Jones <richard@users.sourceforge.net>
parents:
diff
changeset
|
235 |
|
2564
7500a9bb8bf9
message translator is passed by the client in function arguments;
Alexander Smishlajev <a1s@users.sourceforge.net>
parents:
2426
diff
changeset
|
236 # vim: set filetype=python ts=4 sw=4 et si : |
