AlkantarClanX12

Your IP : 18.224.52.54


Current Path : /opt/alt/python35/lib64/python3.5/__pycache__/
Upload File :
Current File : //opt/alt/python35/lib64/python3.5/__pycache__/tracemalloc.cpython-35.opt-2.pyc



���]=�@s`ddlmZmZddlmZddlZddlZddlZddl	Z	ddl
Tddl
mZmZdd�Z
Gdd	�d	�ZGd
d�d�Zdd
�ZeGdd�d��ZeGdd�de��Zdd�ZGdd�d�ZGdd�de�Zdd�ZGdd�d�ZGdd�d�Zdd�ZdS) �)�Sequence�Iterable)�total_orderingN)�*)�_get_object_traceback�_get_tracescCs�x�d
D]�}t|�dkrM|dkrM|r?d||fSd||fSt|�dksk|dkr�|rd||fSd||fS|d
}qWdS)N�B�KiB�MiB�GiB�TiB�dz%+.1f %sz%.1f %s�
iz%+.0f %sz%.0f %s)rr	r
rri()�abs)�size�signZunit�r�0/opt/alt/python35/lib64/python3.5/tracemalloc.py�_format_size
s
rc@s^eZdZdZdd�Zdd�Zdd	�Zd
d�Zdd
�Zdd�Z	dS)�	Statistic�	tracebackr�countcCs||_||_||_dS)N)rrr)�selfrrrrrr�__init__%s		zStatistic.__init__cCst|j|j|jf�S)N)�hashrrr)rrrr�__hash__*szStatistic.__hash__cCs4|j|jko3|j|jko3|j|jkS)N)rrr)r�otherrrr�__eq__-szStatistic.__eq__cCsYd|jt|jd�|jf}|jrU|j|j}|dt|d�7}|S)Nz%s: size=%s, count=%iFz, average=%s)rrrr)r�text�averagerrr�__str__2s
	zStatistic.__str__cCsd|j|j|jfS)Nz)<Statistic traceback=%r size=%i count=%i>)rrr)rrrr�__repr__<szStatistic.__repr__cCs|j|j|jfS)N)rrr)rrrr�	_sort_key@szStatistic._sort_keyN)rrr)
�__name__�
__module__�__qualname__�	__slots__rrrr r!r"rrrrrs
rc@s^eZdZdZdd�Zdd	�Zd
d�Zdd
�Zdd�Zdd�Z	dS)�
StatisticDiffrr�	size_diffr�
count_diffcCs1||_||_||_||_||_dS)N)rrr(rr))rrrr(rr)rrrrKs
				zStatisticDiff.__init__cCs(t|j|j|j|j|jf�S)N)rrrr(rr))rrrrrRszStatisticDiff.__hash__cCsX|j|jkoW|j|jkoW|j|jkoW|j|jkoW|j|jkS)N)rrr(rr))rrrrrrVs
zStatisticDiff.__eq__cCsnd|jt|jd�t|jd�|j|jf}|jrj|j|j}|dt|d�7}|S)Nz %s: size=%s (%s), count=%i (%+i)FTz, average=%s)rrrr(rr))rrrrrrr ]s
	zStatisticDiff.__str__cCs&d|j|j|j|j|jfS)Nz9<StatisticDiff traceback=%r size=%i (%+i) count=%i (%+i)>)rrr(rr))rrrrr!iszStatisticDiff.__repr__cCs.t|j�|jt|j�|j|jfS)N)rr(rr)rr)rrrrr"nszStatisticDiff._sort_keyN)rrr(rr))
r#r$r%r&rrrr r!r"rrrrr'Dsr'cCs�g}x�|j�D]�\}}|j|d�}|dk	rrt||j|j|j|j|j|j�}n$t||j|j|j|j�}|j|�qWxG|j�D]9\}}t|d|jd|j�}|j|�q�W|S)Nr)�items�popr'rr�append)�	old_group�	new_group�
statisticsr�statZpreviousrrr�_compare_grouped_statsts r1c@s�eZdZdZdd�Zedd��Zedd��Zdd	�Zd
d�Z	dd
�Z
dd�Zdd�ZdS)�Frame�_framecCs
||_dS)N)r3)r�framerrrr�szFrame.__init__cCs|jdS)Nr)r3)rrrr�filename�szFrame.filenamecCs|jdS)N�)r3)rrrr�lineno�szFrame.linenocCs|j|jkS)N)r3)rrrrrr�szFrame.__eq__cCs|j|jkS)N)r3)rrrrr�__lt__�szFrame.__lt__cCs
t|j�S)N)rr3)rrrrr�szFrame.__hash__cCsd|j|jfS)Nz%s:%s)r5r7)rrrrr �sz
Frame.__str__cCsd|j|jfS)Nz<Frame filename=%r lineno=%r>)r5r7)rrrrr!�szFrame.__repr__N)r3)
r#r$r%r&r�propertyr5r7rr8rr r!rrrrr2�sr2c@s�eZdZdZdd�Zdd�Zdd�Zdd	�Zd
d�Zdd
�Z	dd�Z
dd�Zdd�Zddd�Z
dS)�	Traceback�_framescCstj|�||_dS)N)rrr;)r�framesrrrr�s
zTraceback.__init__cCs
t|j�S)N)�lenr;)rrrr�__len__�szTraceback.__len__cCsBt|t�r-tdd�|j|D��St|j|�SdS)Ncss|]}t|�VqdS)N)r2)�.0�tracerrr�	<genexpr>�sz(Traceback.__getitem__.<locals>.<genexpr>)�
isinstance�slice�tupler;r2)r�indexrrr�__getitem__�szTraceback.__getitem__cCs|j|jkS)N)r3r;)rr4rrr�__contains__�szTraceback.__contains__cCs
t|j�S)N)rr;)rrrrr�szTraceback.__hash__cCs|j|jkS)N)r;)rrrrrr�szTraceback.__eq__cCs|j|jkS)N)r;)rrrrrr8�szTraceback.__lt__cCst|d�S)Nr)�str)rrrrr �szTraceback.__str__cCsdt|�fS)Nz<Traceback %r>)rD)rrrrr!�szTraceback.__repr__NcCs�g}|dk	r"|dkr"|Sxj|d|�D]X}|jd|j|jf�tj|j|j�j�}|r3|jd|�q3W|S)Nrz  File "%s", line %sz    %s)r,r5r7�	linecache�getline�strip)r�limit�linesr4�linerrr�format�s	zTraceback.format)r;)r#r$r%r&rr>rFrGrrr8r r!rOrrrrr:�sr:cCs*t|�}|dk	r"t|�SdSdS)N)rr:)�objr<rrr�get_object_traceback�s
rQc@sveZdZdZdd�Zedd��Zedd��Zdd	�Zd
d�Z	dd
�Z
dd�ZdS)�Trace�_tracecCs
||_dS)N)rS)rr@rrrr�szTrace.__init__cCs|jdS)Nr)rS)rrrrr�sz
Trace.sizecCst|jd�S)Nr6)r:rS)rrrrr�szTrace.tracebackcCs|j|jkS)N)rS)rrrrrrszTrace.__eq__cCs
t|j�S)N)rrS)rrrrrszTrace.__hash__cCsd|jt|jd�fS)Nz%s: %sF)rrr)rrrrr 	sz
Trace.__str__cCsdt|jd�|jfS)Nz<Trace size=%s, traceback=%r>F)rrr)rrrrr!szTrace.__repr__N)rS)r#r$r%r&rr9rrrrr r!rrrrrR�srRc@sXeZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
S)�_TracescCstj|�||_dS)N)rr�_traces)r�tracesrrrrs
z_Traces.__init__cCs
t|j�S)N)r=rU)rrrrr>sz_Traces.__len__cCsBt|t�r-tdd�|j|D��St|j|�SdS)Ncss|]}t|�VqdS)N)rR)r?r@rrrrAsz&_Traces.__getitem__.<locals>.<genexpr>)rBrCrDrUrR)rrErrrrFsz_Traces.__getitem__cCs|j|jkS)N)rSrU)rr@rrrrG sz_Traces.__contains__cCs|j|jkS)N)rU)rrrrrr#sz_Traces.__eq__cCsdt|�S)Nz<Traces len=%s>)r=)rrrrr!&sz_Traces.__repr__N)	r#r$r%rr>rFrGrr!rrrrrTsrTcCs5tjj|�}|jd�r1|dd�}|S)Nz.pycr6���)�os�path�normcase�endswith)r5rrr�_normalize_filename*sr\c@sXeZdZdddd�Zedd��Zdd�Zd	d
�Zdd�ZdS)
�FilterNFcCs.||_t|�|_||_||_dS)N)�	inclusiver\�_filename_patternr7�
all_frames)rr^�filename_patternr7r`rrrr2s		zFilter.__init__cCs|jS)N)r_)rrrrra9szFilter.filename_patterncCsIt|�}tj||j�s%dS|jdkr8dS||jkSdS)NFT)r\�fnmatchr_r7)rr5r7rrrZ
__match_frame=szFilter.__match_framecCs|j||�|jAS)N)�_Filter__match_framer^)rr5r7rrr�_match_frameFszFilter._match_framecs^�jr:t�fdd�|D��r/�jS�jSn |d\}}�j||�SdS)Nc3s'|]\}}�j||�VqdS)N)rc)r?r5r7)rrrrAKsz*Filter._match_traceback.<locals>.<genexpr>r)r`�anyr^rd)rrr5r7r)rr�_match_tracebackIs	
zFilter._match_traceback)	r#r$r%rr9rarcrdrfrrrrr]1s
	r]c@s|eZdZdd�Zdd�Zedd��Zdd�Zd	d
�Zdd�Z	d
dd�Z
d
dd�ZdS)�SnapshotcCst|�|_||_dS)N)rTrV�traceback_limit)rrVrhrrrrZszSnapshot.__init__cCs3t|d��}tj||tj�WdQRXdS)N�wb)�open�pickle�dump�HIGHEST_PROTOCOL)rr5�fprrrrl`sz
Snapshot.dumpc	Cs*t|d��}tj|�SWdQRXdS)N�rb)rjrk�load)r5rnrrrrpgsz
Snapshot.loadcs`|d�|r3t�fdd�|D��s3dS|r\t�fdd�|D��r\dSdS)Nr6c3s|]}|j��VqdS)N)rf)r?�trace_filter)rrrrArsz)Snapshot._filter_trace.<locals>.<genexpr>Fc3s|]}|j��VqdS)N)rf)r?rq)rrrrAvsT)re)r�include_filters�exclude_filtersr@r)rr�
_filter_traceos


zSnapshot._filter_tracecs�t|t�s(tdt|�j��|r�g�g�x4|D],}|jr`�j|�qA�j|�qAW���fdd��jjD�}n�jjj	�}t
|�j�S)Nz)filters must be a list of filters, not %scs+g|]!}�j��|�r|�qSr)rt)r?r@)rsrrrrr�
<listcomp>�s		z*Snapshot.filter_traces.<locals>.<listcomp>)rBr�	TypeError�typer#r^r,rVrU�copyrgrh)r�filtersrqZ
new_tracesr)rsrrrr�
filter_traces{s
	(zSnapshot.filter_tracescCsG|dkrtd|f��|rA|d	krAtd|��i}i}|sTx�|jjD]�}|\}}y||}Wnstk
r�|dkr�|}	n6|dkr�|dd�}	n|dddff}	t|	�}|||<YnXy,||}
|
j|7_|
jd7_Wq`tk
rLt||d�||<Yq`Xq`Wn�x�|jjD]�}|\}}x�|D]�}y||}WnStk
r�|dkr�|f}	n|ddff}	t|	�}|||<YnXy,||}
|
j|7_|
jd7_Wqztk
r:t||d�||<YqzXqzWqaW|S)
Nrr5r7zunknown key_type: %rz/cumulative mode cannot by used with key type %rr6r)rr5r7)r7r5)�
ValueErrorrVrU�KeyErrorr:rrr)r�key_type�
cumulativeZstatsZ
tracebacksr@rZtrace_tracebackrr<r0r4rrr�	_group_by�sX

	

"



#zSnapshot._group_byFcCsA|j||�}t|j��}|jdddtj�|S)N�reverseT�key)r�list�values�sortrr")rr}r~Zgroupedr/rrrr/�szSnapshot.statisticscCsP|j||�}|j||�}t||�}|jdddtj�|S)Nr�Tr�)rr1r�r'r")rZold_snapshotr}r~r.r-r/rrr�
compare_to�s
zSnapshot.compare_toN)r#r$r%rrl�staticmethodrprtrzrr/r�rrrrrgUs3
rgcCs4t�std��t�}t�}t||�S)NzLthe tracemalloc module must be tracing memory allocations to take a snapshot)Z
is_tracing�RuntimeErrorrZget_traceback_limitrg)rVrhrrr�
take_snapshot�s
			r�)�collectionsrr�	functoolsrrbrIZos.pathrXrkZ_tracemallocrrrrr'r1r2r:rQrRrTr\r]rgr�rrrr�<module>s*
&0#5!$�