HEX
Server: Apache/2.4.58 (Ubuntu)
System: Linux ns3133907 6.8.0-86-generic #87-Ubuntu SMP PREEMPT_DYNAMIC Mon Sep 22 18:03:36 UTC 2025 x86_64
User: cssnetorguk (1024)
PHP: 8.2.28
Disabled: NONE
Upload Files
File: //snap/core20/2669/lib/python3.8/__pycache__/cgitb.cpython-38.pyc
U

��@h@/�@s�dZddlZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
dd�ZgZdd�Z
dd�Zd	d
�Zdd�Zd
d�Zddd�Zddd�ZGdd�d�Ze�jZddd�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�/usr/lib/python3.8/cgitb.py�reset#srcCs|rd|dSdSdS)Nz<small>z</small>�r��textrrr�small.srcCs|rd|dSdSdS)Nz<strong>z	</strong>rrrrrr�strong4sr	cCs|rd|dSdSdS)Nz<font color="#909090">z</font>rrrrrr�grey:sr
cCs�||krd||fS||jkr,d|j|fSd|jkr~|jd}t|�ti�krf||kr~d||fSnt||�r~dt||�fSdtfS)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



rcCs�gdddtf\}}}}}t�|�D]�\}}	}
}}|tjkr>q�|tjkr�|	tjkr�|dkr�|tk	r�t||	t�}|�||	||f�q�t	|	||�\}
}|�|	|
|f�n"|	dkr�||d7}|}nd\}}|	}q"|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}dtj��ddtj}t�t���}dt	j
�dtt	j
�
t|���dd|d|�d	}d
td�d}g}	t�||�}
|
D�]F\}�}}
}}�r�tj����d
�t	j
�
��f}nd�}t�|�\}}}}d}|
dk�r8dtt	j
�
|
��}|
dk�r8|tj||||dd�d�7}i�|gf��fdd�	}t|||�}dd||fg}|dk	�r
||}|D]�}tddtt|��t|��d}|�k�r�d|t	j
�|�f}|�d|�n&d|t	j
�|�f}|�dt|��|d 7}�q�ig}}|D]�\}}} ||k�r0�qd ||<| tk	�r�|d!k�r^d"|t|�}n*|d#k�rrt|�}n|t|�d$�d%�}|�d&|t	j
�| �f�n|�|d'��q|�dttd(�|����|	�d)d*�|��q�d+tt	j
�
t|���t	j
�
t|��fg}!t|�D]B}|dd �d,k�r4�qt	j
�t ||��} |!�d-||| f��q|d�|	�d�|!�d.t	j
�
d�t!�"|||���S)/z9Return a nice HTML document describing a given traceback.�Python r�: 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;&nbsp;&nbsp;&nbsp;&nbsp;z&nbsp;</tt>z<a href="file://%s">%s</a>�?r�in �<module>cSsdtj�|�S�N�=)�pydoc�html�repr�r%rrr�<lambda>��zhtml.<locals>.<lambda>�Zformatvaluec
s8d�|d<zt��|d�W�S|dd7<XdS�N�r��	linecache�getline��lnum��fileZ	highlightrrr!�szhtml.<locals>.readerz+<tr><td bgcolor="#d8bbff">%s%s %s</td></tr>z<big>&nbsp;</big>Nz&nbsp;r,z<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>r<)rrz<em>%s</em> rr���z%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
-->
)#�
isinstancer�__name__�sys�version�split�
executable�time�ctimer4r5Zheadingr	�escape�strr�inspect�getinnerframes�os�path�abspath�getargvalues�formatargvaluesr+�lenZ	preformatr r
rr6�join�dirr�	traceback�format_exception)"�einfo�context�etype�evalue�etb�pyver�date�head�indent�frames�recordsrrA�func�lines�index�link�args�varargs�varkwr�callr!r"�rows�ir)�num�done�dumprr*r%�	exceptionrrBrr5es�

�
��

��
$






��	��r5c 	s�|\}}}t|t�r|j}dtj��ddtj}t�t���}dt	|�||fd}g}t
�||�}	|	D�]�\}
�}}}
}�r�tj
���p�d�t
�|
�\}}}}d}|dkr�d|}|d	kr�|t
j||||d
d�d�7}i�|gf��fd
d�	}t||
|�}d�|fg}|dk	�rP||}|
D](}d|}|�||���|d7}�q&ig}}|D]�\}}}||k�rv�q^d||<|tk	�r�|dk�r�d|}n|dk�r�||�d�d}|�d|tj�|�f�n|�|d��q^|�d�|��|�dd�|��qndt	|�t	|�fg}t|�D],}tj�t||��}|�dd||f��q*|d�|�d�|�dd�t�|||��S) z:Return a plain text document describing a given traceback.r-rr.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/rr0r1cSsdtj�|�Sr2)r4rr6r7rrrr8�r9ztext.<locals>.<lambda>r:c
s8d�|d<zt��|d�W�S|dd7<XdSr;r=r@rBrrr!�sztext.<locals>.readerz %s %sNz%5d r<rzglobal rrrDz%s = %sz
 undefinedrEz
%s
z%s: %sz

%s%s = %sz    zc

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

%s
)rGrrHrIrJrKrLrMrNrPrQrRrSrTrUrVrWr+r �rstriprr4rr6rYrZrr[r\) r]r^r_r`rarbrcrdrfrgrrArhrirjrlrmrnrror!r"rprqr)rrrsrtrr*r%rurrBrr�sb

�






�rc@s,eZdZdZddd�Zdd	�Zd
d
d�ZdS)�Hookz?A hook to replace sys.excepthook that shows tracebacks in HTML.r<Nr,r5cCs(||_||_||_|ptj|_||_dS�N)�display�logdirr^rI�stdoutrC�format)�selfryrzr^rCr|rrr�__init__s
z
Hook.__init__cCs|�|||f�dSrx)�handle)r}r_r`rarrr�__call__
sz
Hook.__call__c
	Csz|p
t��}|jdkr$|j�t��|jdkr2tp4t}d}z|||j�}Wn d�	t
j|��}d}YnX|jr�|r�t
j�|�}|j�d|d�q�|j�|d�n|j�d�|jdk	�rZd	d
g|jdk}tj||jd�\}}z.t�|d��}|�|�W5QRXd
|}	Wnd|}	YnX|jdk�rJ|j�d|	�n|j�|	d�z|j��WnYnXdS)Nr5FrTz<pre>z</pre>
rEz*<p>A problem occurred in a Python script.
z.txtz.html)�suffixrZ�wz*%s contains the description of this error.z*Tried to save traceback to %s, but failed.z
<p>%s</p>
)rI�exc_infor|rC�writerr5rr^rYr[r\ryr4rOrz�tempfileZmkstemprS�fdopen�flush)
r}�infoZ	formatterZplain�docr��fdrTrC�msgrrrrs@

zHook.handle)r<Nr,Nr5)N)rH�
__module__�__qualname__�__doc__r~r�rrrrrrws�
rwr<cCst||||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.�ryrzr^r|N)rwrI�
excepthookr�rrr�enable:s�r�)r,)r,)r<Nr,r5)r�rQrr>rSr4rIr�rMrr[rrrr	r
rr+r5rrwrZhandlerr�rrrr�<module>s,

[
B7