Your IP : 18.191.233.198


Current Path : /opt/alt/python34/lib64/python3.4/__pycache__/
Upload File :
Current File : //opt/alt/python34/lib64/python3.4/__pycache__/cgitb.cpython-34.pyo

�
j f	/�@s%dZddlZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
dd�ZgZdd�Z
dd�Zd	d
�Zdd�Zd
d�Zddd�Zddd�ZGdd�d�Ze�jZdddddd�ZdS)a�More comprehensive traceback formatting for Python scripts.

To enable this module, do:

    import cgitb; cgitb.enable()

at the top of your script.  The optional arguments to enable() are:

    display     - if true, tracebacks are displayed in the web browser
    logdir      - if set, tracebacks are written to files in this directory
    context     - number of lines of source code to show for each stack frame
    format      - 'text' or 'html' controls the output format

By default, tracebacks are displayed but not saved, the context is 5 lines
and the output format is 'html' (for backwards compatibility with the
original use of this module)

Alternatively, if you have caught an exception and want cgitb to display it
for you, call cgitb.handler().  The optional argument to handler() is a
3-item tuple (etype, evalue, etb) just like the value of sys.exc_info().
The default handler displays output as HTML.

�NcCsdS)zAReturn a string that resets the CGI and browser to a known state.a'<!--: spam
Content-Type: text/html

<body bgcolor="#f0f0f8"><font color="#f0f0f8" size="-5"> -->
<body bgcolor="#f0f0f8"><font color="#f0f0f8" size="-5"> --> -->
</font> </font> </font> </script> </object> </blockquote> </pre>
</table> </table> </table> </table> </table> </font> </font> </font>�rrr�*/opt/alt/python34/lib64/python3.4/cgitb.py�reset#srcCs|rd|dSdSdS)Nz<small>z</small>�r)�textrrr�small.srcCs|rd|dSdSdS)Nz<strong>z	</strong>rr)rrrr�strong4srcCs|rd|dSdSdS)Nz<font color="#909090">z</font>rr)rrrr�grey:sr	cCs�||krd||fS||jkr:d|j|fSd|jkr�|jd}t|�ti�kr�||kr�d||fSq�t||�r�dt||�fSndtfS)z9Find the value for a given name in the given environment.�local�global�__builtins__�builtinN)�	f_globals�type�hasattr�getattr�	__UNDEF__)�name�frame�locals�builtinsrrr�lookup@s
rcCs2gdddtf\}}}}}xtj|�D]�\}}	}
}}|tjkr\Pn|tjkr�|	tjkr�|dkr�|tk	r�t||	t�}|j||	||f�q�q$t	|	||�\}
}|j|	|
|f�n/|	dkr||d7}|}nd\}}|	}q4W|S)zEScan one logical line of Python and look up values of variables used.Nr�.)Nr)
r�tokenize�generate_tokens�NEWLINE�NAME�keyword�kwlistr�appendr)�readerrr�varsZ	lasttoken�parent�prefix�valueZttype�token�start�end�line�whererrr�scanvarsPs"$% 	
r*�c"
s�|\}}}t|t�r*|j}ndtjj�ddtj}tjtj��}dt	j
jdtt	j
j
t|���dd|d|�d	}d
tdd�d
}g}	tj||�}
x�|
D]�\}�}}
}}�r.tjj���d�t	j
j
��f}n
d�}tj|�\}}}}d}|
dkr�dt|
�tj||||ddd��}ni�|g��fdd�}t|||�}dd||fg}|dk	r�||}x�|D]�}tddtt|��t|��d}|�krpd|t	j
j|�f}|jd|�n3d|t	j
j|�f}|jdt|��|d7}qWnig}}x�|D]�\}}} ||kr�q�nd||<| tk	r�|d-kr"d!|t|�}n8|d"kr=t|�}n|t|jd#�d.�}|jd$|t	j
j| �f�q�|j|d%�q�W|jdttd&j|����|	jd'd(j|��q�Wd)tt	j
j
t|���t	j
j
t|��fg}!xet|�D]W}|dd�d*krEq#nt	j
jt ||��} |!jd+||| f�q#W|dj|	�dj|!�d,t	j
j
djt!j"|||���S)/z9Return a nice HTML document describing a given traceback.zPython rz: z<body bgcolor="#f0f0f8">z<big><big>%s</big></big>z#ffffffz#6622aaz<br>z�
<p>A problem occurred in a Python script.  Here is the sequence of
function calls leading up to the error, in the order they occurred.</p>z<tt>z&nbsp;r+z&nbsp;</tt>z<a href="file://%s">%s</a>�?rzin �formatvaluecSsdtjj|�S)N�=)�pydoc�html�repr)r$rrr�<lambda>�szhtml.<locals>.<lambda>c
s<d�|d<ztj�|d�SWd|dd7<XdS)N�r)�	linecache�getline)�lnum)�file�	highlightrrr �szhtml.<locals>.readerz+<tr><td bgcolor="#d8bbff">%s%s %s</td></tr>z<big>&nbsp;</big>Nz<tt>=&gt;%s%s</tt>z&<tr><td bgcolor="#ffccee">%s</td></tr>z<tt>&nbsp;&nbsp;%s%s</tt>z<tr><td>%s</td></tr>r3rr
z<em>%s</em> r
rz%s&nbsp;= %sz <em>undefined</em>z, zF
<table width="100%%" cellspacing=0 cellpadding=0 border=0>
%s</table>�
z	<p>%s: %s�_z
<br>%s%s&nbsp;=
%sz�


<!-- The above is a description of an error in a Python program, formatted
     for a Web browser because the 'cgitb' module was enabled.  In case you
     are not reading this in a Web browser, here is the original traceback:

%s
-->
)zglobalzbuiltin���)#�
isinstancer�__name__�sys�version�split�
executable�time�ctimer/r0Zheadingr�escape�strr�inspect�getinnerframes�os�path�abspath�getargvalues�formatargvaluesr*�lenZ	preformatrr	rr1�join�dirr�	traceback�format_exception)"�einfo�context�etype�evalue�etb�pyver�date�head�indent�frames�recordsrr6�func�lines�index�link�args�varargs�varkwr�callr r!�rows�ir(�num�done�dumprr)r$�	exceptionr)r7r8rr0es|"@



.

&&	r0c 
sl|\}}}t|t�r*|j}ndtjj�ddtj}tjtj��}dt	|�||fd}g}t
j||�}	x*|	D]"\}
�}}}
}�r�tj
j��p�d�t
j|
�\}}}}d}|dkr/d|t
j||||d	d
d��}ni�|g��fdd
�}t||
|�}d�|fg}|dk	r�||}x<|
D]1}d|}|j||j��|d7}q�Wnig}}x�|D]�\}}}||kr�q�nd||<|tk	rz|dkr.d|}n&|dkrT||jd�d}n|jd|tjj|�f�q�|j|d�q�W|jdj|��|jddj|��q�Wdt	|�t	|�fg}xIt|�D];}tjjt||��}|jdd ||f�q�W|dj|�dj|�ddjtj|||��S)!z:Return a plain text document describing a given traceback.zPython rz: z	%s
%s
%s
z�
A problem occurred in a Python script.  Here is the sequence of
function calls leading up to the error, in the order they occurred.
r,rzin r-cSsdtjj|�S)Nr.)r/rr1)r$rrrr2�sztext.<locals>.<lambda>c
s<d�|d<ztj�|d�SWd|dd7<XdS)Nr3r)r4r5)r6)r7r8rrr �sztext.<locals>.readerz %s %sNz%5d r3rzglobal r
rz%s = %sz
 undefinedr9z
%s
z%s: %sz

%s%s = %s� �zc

The above is a description of an error in a Python program.  Here is
the original traceback:

%s
r;z    )r<rr=r>r?r@rArBrCrErFrGrHrIrJrKrLr*r�rstriprr/rr1rNrOrrPrQ) rRrSrTrUrVrWrXrYr[r\rr6r]r^r_rarbrcrrdr r!rerfr(rgrhrirr)r$rjr)r7r8rr�s^"





&rc@sLeZdZdZddddddd�Zdd	�Zdd
d�ZdS)�Hookz?A hook to replace sys.excepthook that shows tracebacks in HTML.r3Nr+r0cCs:||_||_||_|p'tj|_||_dS)N)�display�logdirrSr>�stdoutr7�format)�selfrorprSr7rrrrr�__init__s
			z
Hook.__init__cCs|j|||f�dS)N)�handle)rsrTrUrVrrr�__call__sz
Hook.__call__c
Cs�|ptj�}|jdkr7|jjt��n|jdkrLtpOt}d}y|||j�}Wn&dj	t
j|��}d}YnX|jr�|r�|j
dd�j
dd�}|jjd	|d
�q|jj|d�n|jjd�|jdk	r�d
dg|jdk}tjd|d|j�\}}y7tj|d�}|j|�|j�d|}	Wnd|}	YnX|jdkr�|jjd|	�q�|jj|	d�ny|jj�WnYnXdS)Nr0FrT�&z&amp;�<z&lt;z<pre>z</pre>
r9z*<p>A problem occurred in a Python script.
z.txtz.html�suffixrO�wz*%s contains the description of this error.z*Tried to save traceback to %s, but failed.z
<p>%s</p>
)r>�exc_inforrr7�writerr0rrSrNrPrQro�replacerp�tempfileZmkstemprH�fdopen�close�flush)
rs�infoZ	formatterZplain�docry�fdrIr7�msgrrrrusB	!

zHook.handle)r=�
__module__�__qualname__�__doc__rtrvrurrrrrns
rnr3c	Cs(td|d|d|d|�t_dS)aInstall an exception handler that formats tracebacks as HTML.

    The optional argument 'display' can be set to 0 to suppress sending the
    traceback to the browser, and 'logdir' can be set to a directory to cause
    tracebacks to be written to files there.rorprSrrN)rnr>�
excepthook)rorprSrrrrr�enable9sr�)r�rFrr4rHr/r>r~rBrrPrrrrr	rr*r0rrnruZhandlerr�rrrr�<module>s,
ZA8

?>