Server IP : 85.214.239.14 / Your IP : 216.73.216.84 Web Server : Apache/2.4.65 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Mon Sep 30 15:36:27 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 8.2.29 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /proc/2/cwd/proc/2/root/proc/3/root/usr/lib/python3.5/__pycache__/ |
Upload File : |
F��a=�@s`ddlmZmZddlmZddlZddlZddlZddl Z ddl Tddl mZmZdd�Z Gdd �d �ZGd d�d�Zdd �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 rri()�abs)�sizeZsignZunit�r�!/usr/lib/python3.5/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__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__�__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__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%r&rrrrr r!rrrrr'Dsr'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�Zdd�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�szFrame.linenocCs|j|jkS)N)r3)rrrrrr�szFrame.__eq__cCs|j|jkS)N)r3)rrrrr�__lt__�szFrame.__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&r�propertyr5r7rr8rrr rrrrr2�sr2c@s�eZdZdZdZdd�Zdd�Zdd�Zd d �Zdd�Z d d�Z dd�Zdd�Zdd�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"|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%r&rr>rFrGrrr8rr rOrrrrr:�sr: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�ZdS)�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)rrrrrrszTrace.__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%r&rr9rrrrrr rrrrrR�srRc@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 rrrrrTsrTcCs5tjj|�}|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=szFilter.__match_framecCs|j||�|jAS)N)�_Filter__match_framer^)rr5r7rrr�_match_frameFszFilter._match_framecs^�jr:t�fdd�|D��r/�jS�jSn |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�eZdZdZdd�Zdd�Zedd��Zdd �Zd d�Z dd �Z ddd�Zddd�ZdS)�SnapshotzB Snapshot of traces of memory blocks allocated by Python. cCst|�|_||_dS)N)rTrV�traceback_limit)rrVrhrrrrZszSnapshot.__init__cCs3t|d��}tj||tj�WdQRXdS)z1 Write the snapshot into a file. �wbN)�open�pickle�dumpZHIGHEST_PROTOCOL)rr5�fprrrrl`sz Snapshot.dumpc Cs*t|d��}tj|�SWdQRXdS)z. Load a snapshot from a file. �rbN)rjrk�load)r5rmrrrrogsz 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?rp)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)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)rs)r?r@)rrrqrrr� <listcomp>�s z*Snapshot.filter_traces.<locals>.<listcomp>)rBr� TypeError�typer"r^r,rVrU�copyrgrh)r�filtersrpZ new_tracesr)rrrqrr� filter_traces{s (zSnapshot.filter_tracescCsG|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)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. rTr�)r~r1r�r'r!)rZold_snapshotr|r}r.r-r/rrr� compare_to�s zSnapshot.compare_toN) r"r#r$r%rrl�staticmethodrorsryr~r/r�rrrrrgUs3 rgcCs4t�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)Z is_tracing�RuntimeErrorrZget_traceback_limitrg)rVrhrrr� take_snapshot�s r�)�collectionsrr� functoolsrrbrI�os.pathrXrkZ_tracemallocrrrrr'r1r2r:rQrRrTr\r]rgr�rrrr�<module>s* &0#5!$�