Your IP : 18.191.171.121


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

�
i f#=�@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|�dkrP|dkrP|r?d||fSd||fSnt|�dksn|dkr�|r�d||fSd||fSn|d
}qWdS)N�B�KiB�MiB�GiB�TiB�dz%+.1f %sz%.1f %s�
iz%+.0f %sz%.0f %s)rr	r
rri()�abs)�sizeZsignZunit�r�0/opt/alt/python34/lib64/python3.4/tracemalloc.py�_format_size
s
rc@sdeZdZdZdZdd�Zdd�Zd	d
�Zdd�Zd
d�Z	dd�Z
dS)�	StatisticzS
    Statistic difference on memory allocations between two Snapshot instance.
    �	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__cCs\d|jt|jd�|jf}|jrX|j|j}|dt|d�7}n|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)z	tracebackzsizezcount)�__name__�
__module__�__qualname__�__doc__�	__slots__rrrrr r!rrrrrs
rc@sdeZdZdZdZdd�Zd	d
�Zdd�Zd
d�Zdd�Z	dd�Z
dS)�
StatisticDiffzd
    Statistic difference on memory allocations between an old and a new
    Snapshot instance.
    rr�	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__cCsqd|jt|jd�t|jd�|j|jf}|jrm|j|j}|dt|d�7}n|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)z	tracebackzsizez	size_diffzcountz
count_diff)r"r#r$r%r&rrrrr 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�eZdZdZdZdd�Zedd��Zedd��Zd	d
�Z	dd�Z
d
d�Zdd�Zdd�Z
dS)�Framez
    Frame of a traceback.
    �_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)z_frame)r"r#r$r%r&r�propertyr5r7rr8rrr rrrrr2�sr2c@s�eZdZdZdZdd�Zdd�Zdd�Zd	d
�Zdd�Z	d
d�Z
dd�Zdd�Zdd�Z
ddd�ZdS)�	Tracebackz`
    Sequence of Frame instances sorted from the most recent frame
    to the oldest frame.
    �_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"|Sxm|d|�D][}|jd|j|jf�tj|j|j�j�}|r3|jd|�q3q3W|S)Nrz  File "%s", line %sz    %s)r,r5r7�	linecache�getline�strip)r�limit�linesr4�linerrr�format�s	zTraceback.format)z_frames)r"r#r$r%r&rr>rFrGrrr8rr rOrrrrr:�sr:cCs*t|�}|dk	r"t|�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)rr:)�objr<rrr�get_object_traceback�s
rQc@s|eZdZdZdZdd�Zedd��Zedd��Zd	d
�Z	dd�Z
d
d�Zdd�ZdS)�Tracez"
    Trace of a memory block.
    �_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)z_trace)
r"r#r$r%r&rr9rrrrrr 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rTcCs8tjj|�}|jd�r4|dd�}n|S)N�.pyc�.pyor6)rWrX���)�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_patternr7rbrrrr2s		zFilter.__init__cCs|jS)N)ra)rrrrrc9szFilter.filename_patterncCsIt|�}tj||j�s%dS|jdkr8dS||jkSdS)NFT)r^�fnmatchrar7)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)re)r?r5r7)rrrrAKsz*Filter._match_traceback.<locals>.<genexpr>r)rb�anyr`rf)rrr5r7r)rr�_match_tracebackIs	
zFilter._match_traceback)	r"r#r$rr9rcrerfrhrrrrr_1s
	r_c@s�eZdZdZdd�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)rTrV�traceback_limit)rrVrjrrrrZszSnapshot.__init__cCs2t|d��}tj||tj�WdQXdS)z1
        Write the snapshot into a file.
        �wbN)�open�pickle�dumpZHIGHEST_PROTOCOL)rr5�fprrrrn`sz
Snapshot.dumpc	Cs)t|d��}tj|�SWdQXdS)z.
        Load a snapshot from a file.
        �rbN)rlrm�load)r5rorrrrqgsz
Snapshot.loadcsf|d�|r6t�fdd�|D��s6dSn|rbt�fdd�|D��rbdSndS)Nr6c3s|]}|j��VqdS)N)rh)r?�trace_filter)rrrrArsz)Snapshot._filter_trace.<locals>.<genexpr>Fc3s|]}|j��VqdS)N)rh)r?rr)rrrrAvsT)rg)r�include_filters�exclude_filtersr@r)rr�
_filter_traceos


zSnapshot._filter_tracecs�t|t�s+tdt|�j��n|r�g�g�x4|D],}|jrc�j|�qD�j|�qDW���fdd��jjD�}n�jjj	�}t
|�j�S)z�
        Create a new Snapshot instance with a filtered traces sequence, filters
        is a list of Filter 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 %scs+g|]!}�j��|�r|�qSr)ru)r?r@)rtrsrrr�
<listcomp>�s		z*Snapshot.filter_traces.<locals>.<listcomp>)rBr�	TypeError�typer"r`r,rVrU�copyrirj)r�filtersrrZ
new_tracesr)rtrsrr�
filter_traces{s
	(zSnapshot.filter_tracescCsM|dkr"td|f��n|rG|d	krGtd|��ni}i}|sZx�|jjD]�}|\}}y||}Wnstk
r�|dkr�|}	n6|dkr�|dd�}	n|dddff}	t|	�}|||<YnXy,||}
|
j|7_|
jd7_Wqftk
rRt||d�||<YqfXqfWn�x�|jjD]�}|\}}x�|D]�}y||}WnStk
r�|dkr�|f}	n|ddff}	t|	�}|||<YnXy,||}
|
j|7_|
jd7_Wq�tk
r@t||d�||<Yq�Xq�WqgW|S)
Nrr5r7zunknown key_type: %rz/cumulative mode cannot by used with key type %rr6r)z	traceback�filename�lineno)r}r|)�
ValueErrorrVrU�KeyErrorr:rrr)r�key_type�
cumulativeZstatsZ
tracebacksr@rZtrace_tracebackrr<r0r4rrr�	_group_by�sX

	

"



#zSnapshot._group_byFcCsA|j||�}t|j��}|jdddtj�|S)zd
        Group statistics by key_type. Return a sorted list of Statistic
        instances.
        �reverseT�key)r��list�values�sortrr!)rr�r�Zgroupedr/rrrr/�szSnapshot.statisticscCsP|j||�}|j||�}t||�}|jdddtj�|S)z�
        Compute the differences with an old snapshot old_snapshot. Get
        statistics as a sorted list of StatisticDiff instances, grouped by
        group_by.
        r�Tr�)r�r1r�r'r!)rZold_snapshotr�r�r.r-r/rrr�
compare_to�s
zSnapshot.compare_toN)
r"r#r$r%rrn�staticmethodrqrur{r�r/r�rrrrriUs3
ricCs7t�std��nt�}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)Z
is_tracing�RuntimeErrorrZget_traceback_limitri)rVrjrrr�
take_snapshot�s
			r�)�collectionsrr�	functoolsrrdrIZos.pathrZrmZ_tracemallocrrrrr'r1r2r:rQrRrTr^r_rir�rrrr�<module>s*
&0#5!$�

?>