Your IP : 18.224.64.51


Current Path : /proc/self/root/opt/alt/python37/lib64/python3.7/__pycache__/
Upload File :
Current File : //proc/self/root/opt/alt/python37/lib64/python3.7/__pycache__/tracemalloc.cpython-37.opt-1.pyc

B

� f�B�@sddlmZmZddlmZddlZddlZddlZddl	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�de�ZGdd�de�ZGd d!�d!�Zd"d#�ZdS)$�)�Sequence�Iterable)�total_orderingN)�*)�_get_object_traceback�_get_tracescCszxtdD]l}t|�dkr:|dkr:|r.d||fSd||fSt|�dksN|dkrj|r^d||fSd	||fS|d
}qWdS)N)�BZKiBZMiBZGiB�TiB�drz%+.1f %sz%.1f %si(r	z%+.0f %sz%.0f %si)�abs)�sizeZsignZunit�r
�0/opt/alt/python37/lib64/python3.7/tracemalloc.py�_format_size
s
rc@sDeZdZdZdZdd�Zdd�Zdd�Zd	d
�Zdd�Z	d
d�Z
dS)�	StatisticzS
    Statistic difference on memory allocations between two Snapshot instance.
    )�	tracebackr�countcCs||_||_||_dS)N)rrr)�selfrrrr
r
r�__init__%szStatistic.__init__cCst|j|j|jf�S)N)�hashrrr)rr
r
r�__hash__*szStatistic.__hash__cCs$|j|jko"|j|jko"|j|jkS)N)rrr)r�otherr
r
r�__eq__-szStatistic.__eq__cCsBd|jt|jd�|jf}|jr>|j|j}|dt|d�7}|S)Nz%s: size=%s, count=%iFz, average=%s)rrrr)r�text�averager
r
r�__str__2s

zStatistic.__str__cCsd|j|j|jfS)Nz)<Statistic traceback=%r size=%i count=%i>)rrr)rr
r
r�__repr__<szStatistic.__repr__cCs|j|j|jfS)N)rrr)rr
r
r�	_sort_key@szStatistic._sort_keyN)�__name__�
__module__�__qualname__�__doc__�	__slots__rrrrrrr
r
r
rrs
rc@sDeZdZdZdZdd�Zdd�Zdd�Zd	d
�Zdd�Z	d
d�Z
dS)�
StatisticDiffzd
    Statistic difference on memory allocations between an old and a new
    Snapshot instance.
    )rr�	size_diffr�
count_diffcCs"||_||_||_||_||_dS)N)rrr$rr%)rrrr$rr%r
r
rrKs
zStatisticDiff.__init__cCst|j|j|j|j|jf�S)N)rrrr$rr%)rr
r
rrRszStatisticDiff.__hash__cCs<|j|jko:|j|jko:|j|jko:|j|jko:|j|jkS)N)rrr$rr%)rrr
r
rrVs
zStatisticDiff.__eq__cCsPd|jt|jd�t|jd�|j|jf}|jrL|j|j}|dt|d�7}|S)Nz %s: size=%s (%s), count=%i (%+i)FTz, average=%s)rrrr$rr%)rrrr
r
rr]s


zStatisticDiff.__str__cCsd|j|j|j|j|jfS)Nz9<StatisticDiff traceback=%r size=%i (%+i) count=%i (%+i)>)rrr$rr%)rr
r
rriszStatisticDiff.__repr__cCs t|j�|jt|j�|j|jfS)N)rr$rr%rr)rr
r
rrnszStatisticDiff._sort_keyN)rrr r!r"rrrrrrr
r
r
rr#Dsr#cCs�g}xp|��D]d\}}|�|d�}|dk	rPt||j|j|j|j|j|j�}nt||j|j|j|j�}|�|�qWx6|��D]*\}}t|d|jd|j�}|�|�q�W|S)Nr)�items�popr#rr�append)�	old_group�	new_group�
statisticsr�statZpreviousr
r
r�_compare_grouped_statstsr-c@s\eZdZdZdZdd�Zedd��Zedd��Zd	d
�Z	dd�Z
d
d�Zdd�Zdd�Z
dS)�Framez
    Frame of a traceback.
    )�_framecCs
||_dS)N)r/)r�framer
r
rr�szFrame.__init__cCs
|jdS)Nr)r/)rr
r
r�filename�szFrame.filenamecCs
|jdS)N�)r/)rr
r
r�lineno�szFrame.linenocCs|j|jkS)N)r/)rrr
r
rr�szFrame.__eq__cCs|j|jkS)N)r/)rrr
r
r�__lt__�szFrame.__lt__cCs
t|j�S)N)rr/)rr
r
rr�szFrame.__hash__cCsd|j|jfS)Nz%s:%s)r1r3)rr
r
rr�sz
Frame.__str__cCsd|j|jfS)Nz<Frame filename=%r lineno=%r>)r1r3)rr
r
rr�szFrame.__repr__N)rrr r!r"r�propertyr1r3rr4rrrr
r
r
rr.�sr.c@sfeZdZdZdZdd�Zdd�Zdd�Zd	d
�Zdd�Z	d
d�Z
dd�Zdd�Zdd�Z
ddd�ZdS)�	Tracebackz`
    Sequence of Frame instances sorted from the oldest frame
    to the most recent frame.
    )�_framescCst�|�tt|��|_dS)N)rr�tuple�reversedr7)r�framesr
r
rr�s
zTraceback.__init__cCs
t|j�S)N)�lenr7)rr
r
r�__len__�szTraceback.__len__cCs4t|t�r"tdd�|j|D��St|j|�SdS)Ncss|]}t|�VqdS)N)r.)�.0�tracer
r
r�	<genexpr>�sz(Traceback.__getitem__.<locals>.<genexpr>)�
isinstance�slicer8r7r.)r�indexr
r
r�__getitem__�s
zTraceback.__getitem__cCs|j|jkS)N)r/r7)rr0r
r
r�__contains__�szTraceback.__contains__cCs
t|j�S)N)rr7)rr
r
rr�szTraceback.__hash__cCs|j|jkS)N)r7)rrr
r
rr�szTraceback.__eq__cCs|j|jkS)N)r7)rrr
r
rr4�szTraceback.__lt__cCst|d�S)Nr)�str)rr
r
rr�szTraceback.__str__cCsdt|�fS)Nz<Traceback %r>)r8)rr
r
rr�szTraceback.__repr__NFcCs�g}|dk	r2|dkr$||d�}q6|d|�}n|}|rBt|�}xH|D]@}|�d|j|jf�t�|j|j���}|rH|�d|�qHW|S)Nrz  File "%s", line %sz    %s)r9r(r1r3�	linecache�getline�strip)r�limitZmost_recent_first�linesZframe_slicer0�liner
r
r�format�s
zTraceback.format)NF)rrr r!r"rr<rCrDrrr4rrrLr
r
r
rr6�sr6cCs t|�}|dk	rt|�SdSdS)z�
    Get the traceback where the Python object *obj* was allocated.
    Return a Traceback instance.

    Return None if the tracemalloc module is not tracing memory allocations or
    did not trace the allocation of the object.
    N)rr6)�objr:r
r
r�get_object_traceback�srNc@s`eZdZdZdZdd�Zedd��Zedd��Zed	d
��Z	dd�Z
d
d�Zdd�Zdd�Z
dS)�Tracez"
    Trace of a memory block.
    )�_tracecCs
||_dS)N)rP)rr>r
r
rrszTrace.__init__cCs
|jdS)Nr)rP)rr
r
r�domainszTrace.domaincCs
|jdS)Nr2)rP)rr
r
rr	sz
Trace.sizecCst|jd�S)N�)r6rP)rr
r
rr
szTrace.tracebackcCs|j|jkS)N)rP)rrr
r
rrszTrace.__eq__cCs
t|j�S)N)rrP)rr
r
rrszTrace.__hash__cCsd|jt|jd�fS)Nz%s: %sF)rrr)rr
r
rrsz
Trace.__str__cCsd|jt|jd�|jfS)Nz'<Trace domain=%s size=%s, traceback=%r>F)rQrrr)rr
r
rrszTrace.__repr__N)rrr r!r"rr5rQrrrrrrr
r
r
rrO�srOc@s<eZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
S)�_TracescCst�|�||_dS)N)rr�_traces)r�tracesr
r
rr s
z_Traces.__init__cCs
t|j�S)N)r;rT)rr
r
rr<%sz_Traces.__len__cCs4t|t�r"tdd�|j|D��St|j|�SdS)Ncss|]}t|�VqdS)N)rO)r=r>r
r
rr?*sz&_Traces.__getitem__.<locals>.<genexpr>)r@rAr8rTrO)rrBr
r
rrC(s
z_Traces.__getitem__cCs|j|jkS)N)rPrT)rr>r
r
rrD.sz_Traces.__contains__cCs|j|jkS)N)rT)rrr
r
rr1sz_Traces.__eq__cCsdt|�S)Nz<Traces len=%s>)r;)rr
r
rr4sz_Traces.__repr__N)	rrr rr<rCrDrrr
r
r
rrSsrScCs&tj�|�}|�d�r"|dd�}|S)Nz.pyc���)�os�path�normcase�endswith)r1r
r
r�_normalize_filename8s
r[c@seZdZdd�Zdd�ZdS)�
BaseFiltercCs
||_dS)N)�	inclusive)rr]r
r
rr@szBaseFilter.__init__cCst�dS)N)�NotImplementedError)rr>r
r
r�_matchCszBaseFilter._matchN)rrr rr_r
r
r
rr\?sr\csJeZdZd�fdd�	Zedd��Zdd�Zd	d
�Zdd�Zd
d�Z	�Z
S)�FilterNFcs2t��|�||_t|�|_||_||_||_dS)N)�superrr]r[�_filename_patternr3�
all_framesrQ)rr]�filename_patternr3rcrQ)�	__class__r
rrHs
zFilter.__init__cCs|jS)N)rb)rr
r
rrdQszFilter.filename_patterncCs6t|�}t�||j�sdS|jdkr(dS||jkSdS)NFT)r[�fnmatchrbr3)rr1r3r
r
r�_match_frame_implUs
zFilter._match_frame_implcCs|�||�|jAS)N)rgr])rr1r3r
r
r�_match_frame^szFilter._match_framecsH�jr,t�fdd�|D��r"�jS�jSn|d\}}��||�SdS)Nc3s|]\}}��||�VqdS)N)rg)r=r1r3)rr
rr?csz*Filter._match_traceback.<locals>.<genexpr>r)rc�anyr]rh)rrr1r3r
)rr�_match_tracebackas

zFilter._match_tracebackcCsD|\}}}|�|�}|jdk	r@|jr2|o0||jkS|p>||jkS|S)N)rjrQr])rr>rQrrZresr
r
rr_ls


z
Filter._match)NFN)rrr rr5rdrgrhrjr_�
__classcell__r
r
)rerr`Gs	r`cs0eZdZ�fdd�Zedd��Zdd�Z�ZS)�DomainFiltercst��|�||_dS)N)rar�_domain)rr]rQ)rer
rrxszDomainFilter.__init__cCs|jS)N)rm)rr
r
rrQ|szDomainFilter.domaincCs|\}}}||jk|jAS)N)rQr])rr>rQrrr
r
rr_�s
zDomainFilter._match)rrr rr5rQr_rkr
r
)rerrlwsrlc@sXeZdZdZdd�Zdd�Zedd��Zdd	�Zd
d�Z	dd
�Z
ddd�Zddd�ZdS)�SnapshotzB
    Snapshot of traces of memory blocks allocated by Python.
    cCst|�|_||_dS)N)rSrU�traceback_limit)rrUror
r
rr�s
zSnapshot.__init__c	Cs*t|d��}t�||tj�WdQRXdS)z1
        Write the snapshot into a file.
        �wbN)�open�pickle�dumpZHIGHEST_PROTOCOL)rr1�fpr
r
rrs�sz
Snapshot.dumpc	Cs t|d��}t�|�SQRXdS)z.
        Load a snapshot from a file.
        �rbN)rqrr�load)r1rtr
r
rrv�sz
Snapshot.loadcs@|rt�fdd�|D��sdS|r<t�fdd�|D��r<dSdS)Nc3s|]}|���VqdS)N)r_)r=�trace_filter)r>r
rr?�sz)Snapshot._filter_trace.<locals>.<genexpr>Fc3s|]}|���VqdS)N)r_)r=rw)r>r
rr?�sT)ri)r�include_filters�exclude_filtersr>r
)r>r�
_filter_trace�s

zSnapshot._filter_tracecs�t|t�stdt|�j��|rng�g�x(|D] }|jrD��|�q.��|�q.W���fdd��jjD�}n�jj�	�}t
|�j�S)z�
        Create a new Snapshot instance with a filtered traces sequence, filters
        is a list of Filter or DomainFilter instances.  If filters is an empty
        list, return a new Snapshot instance with a copy of the traces.
        z)filters must be a list of filters, not %scsg|]}����|�r|�qSr
)rz)r=r>)ryrxrr
r�
<listcomp>�sz*Snapshot.filter_traces.<locals>.<listcomp>)r@r�	TypeError�typerr]r(rUrT�copyrnro)r�filtersrwZ
new_tracesr
)ryrxrr�
filter_traces�s

zSnapshot.filter_tracesc

Cs�|dkrtd|f��|r.|dkr.td|��i}i}|�sx�|jjD]�}|\}}}y||}	WnZtk
r�|dkr~|}
n(|dkr�|dd�}
n|dddff}
t|
�}	|	||<YnXy(||	}|j|7_|jd7_WqFtk
�r
t|	|d�||	<YqFXqFWn�x�|jjD]�}|\}}}x�|D]�}y||}	WnFtk
�r�|dk�rd|f}
n|ddff}
t|
�}	|	||<YnXy(||	}|j|7_|jd7_Wn&tk
�r�t|	|d�||	<YnX�q0W�qW|S)	N)rr1r3zunknown key_type: %r)r3r1z/cumulative mode cannot by used with key type %rrr3r2r)�
ValueErrorrUrT�KeyErrorr6rrr)
r�key_type�
cumulativeZstatsZ
tracebacksr>rQrZtrace_tracebackrr:r,r0r
r
r�	_group_by�sX



"zSnapshot._group_byFcCs,|�||�}t|���}|jdtjd�|S)zd
        Group statistics by key_type. Return a sorted list of Statistic
        instances.
        T)�reverse�key)r��list�values�sortrr)rr�r�Zgroupedr+r
r
rr+�szSnapshot.statisticscCs6|�||�}|�||�}t||�}|jdtjd�|S)z�
        Compute the differences with an old snapshot old_snapshot. Get
        statistics as a sorted list of StatisticDiff instances, grouped by
        group_by.
        T)r�r�)r�r-r�r#r)rZold_snapshotr�r�r*r)r+r
r
r�
compare_tos

zSnapshot.compare_toN)F)F)
rrr r!rrs�staticmethodrvrzr�r�r+r�r
r
r
rrn�s3

rncCs$t�std��t�}t�}t||�S)zI
    Take a snapshot of traces of memory blocks allocated by Python.
    zLthe tracemalloc module must be tracing memory allocations to take a snapshot)�
is_tracing�RuntimeErrorrZget_traceback_limitrn)rUror
r
r�
take_snapshot
s
r�)Zcollections.abcrr�	functoolsrrfrFZos.pathrWrrZ_tracemallocrrrrr#r-r.r6rNrOrSr[r\r`rlrnr�r
r
r
r�<module>s0&0#?%0	

?>