a DOgF@sddlmZmZddlmZddlZddlZddlZddl Z ddl Tddl m Z m Z ddZ Gdd d ZGd d d Zd d ZeGdddZeGdddeZddZGdddZGdddeZddZGdddZGdddeZGdddeZGd d!d!Zd"d#ZdS)$)SequenceIterable)total_orderingN)*)_get_object_traceback _get_tracescCsdD]|}t|dkr@|dkr@|r0d||fSd||fSt|dksT|dkrx|rhd||fSd ||fS|d }qdS) N)BZKiBZMiBZGiBTiBdrz%+.1f %sz%.1f %si(r z%+.0f %sz%.0f %si)abs)sizeZsignZunitr 0/opt/alt/python39/lib64/python3.9/tracemalloc.py _format_size src@sDeZdZdZdZddZddZddZd d Zd d Z d dZ dS) StatisticzS Statistic difference on memory allocations between two Snapshot instance.  tracebackr countcCs||_||_||_dSNr)selfrr rr r r__init__%szStatistic.__init__cCst|j|j|jfSr)hashrr rrr r r__hash__*szStatistic.__hash__cCs2t|tstS|j|jko0|j|jko0|j|jkSr) isinstancerNotImplementedrr rrotherr r r__eq__-s    zStatistic.__eq__cCsBd|jt|jd|jf}|jr>|j|j}|dt|d7}|S)Nz%s: size=%s, count=%iF , average=%s)rrr rrtextZaverager r r__str__4s  zStatistic.__str__cCsd|j|j|jfS)Nz)rrr r r__repr__>szStatistic.__repr__cCs|j|j|jfSr)r rrrr r r _sort_keyBszStatistic._sort_keyN __name__ __module__ __qualname____doc__ __slots__rrrr"r#r$r r r rrs rc@sDeZdZdZdZddZddZddZd d Zd d Z d dZ dS) StatisticDiffzd Statistic difference on memory allocations between an old and a new Snapshot instance. rr size_diffr count_diffcCs"||_||_||_||_||_dSrr,)rrr r-rr.r r rrMs zStatisticDiff.__init__cCst|j|j|j|j|jfSr)rrr r-rr.rr r rrTszStatisticDiff.__hash__cCsJt|tstS|j|jkoH|j|jkoH|j|jkoH|j|jkoH|j|jkSr)rr+rrr r-rr.rr r rrXs      zStatisticDiff.__eq__cCsPd|jt|jdt|jd|j|jf}|jrL|j|j}|dt|d7}|S)Nz %s: size=%s (%s), count=%i (%+i)FTr)rrr r-rr.r r r rr"as   zStatisticDiff.__str__cCsd|j|j|j|j|jfS)Nz9r,rr r rr#ms  zStatisticDiff.__repr__cCs t|j|jt|j|j|jfSr)r r-r r.rrrr r rr$rs  zStatisticDiff._sort_keyNr%r r r rr+Fs  r+cCsg}|D]d\}}||d}|durNt||j|j|j|j|j|j}nt||j|j|j|j}||q |D]*\}}t|d|j d|j }||qz|SNr)itemspopr+r rappend) old_group new_group statisticsrstatZpreviousr r r_compare_grouped_statsxs"   r7c@s\eZdZdZdZddZeddZeddZd d Z d d Z d dZ ddZ ddZ dS)Framez Frame of a traceback. _framecCs ||_dSrr9rframer r rrszFrame.__init__cCs |jdSr/r9rr r rfilenameszFrame.filenamecCs |jdSNr9rr r rlinenosz Frame.linenocCst|tstS|j|jkSrrr8rr:rr r rrs z Frame.__eq__cCst|tstS|j|jkSrrArr r r__lt__s z Frame.__lt__cCs t|jSr)rr:rr r rrszFrame.__hash__cCsd|j|jfS)Nz%s:%sr=r@rr r rr"sz Frame.__str__cCsd|j|jfS)NzrCrr r rr#szFrame.__repr__N)r&r'r(r)r*rpropertyr=r@rrBrr"r#r r r rr8s  r8c@steZdZdZdZdddZeddZdd Zd d Z d d Z ddZ ddZ ddZ ddZddZdddZdS) Tracebackz` Sequence of Frame instances sorted from the oldest frame to the most recent frame. )_frames _total_nframeNcCs"t|tt||_||_dSr)rrtuplereversedrFrG)rframes total_nframer r rrs zTraceback.__init__cCs|jSr)rGrr r rrKszTraceback.total_nframecCs t|jSr)lenrFrr r r__len__szTraceback.__len__cCs4t|tr"tdd|j|DSt|j|SdS)Ncss|]}t|VqdSr)r8.0tracer r r z(Traceback.__getitem__..)rslicerHrFr8rindexr r r __getitem__s zTraceback.__getitem__cCs |j|jvSr)r:rFr;r r r __contains__szTraceback.__contains__cCs t|jSr)rrFrr r rrszTraceback.__hash__cCst|tstS|j|jkSrrrErrFrr r rrs zTraceback.__eq__cCst|tstS|j|jkSrrXrr r rrBs zTraceback.__lt__cCs t|dSr/)strrr r rr"szTraceback.__str__cCs8dt|}|jdur"|d7}n|d|jd7}|S)Nz z total_nframe=)rHrGrK)rsr r rr#s   zTraceback.__repr__FcCsg}|dur2|dkr$|| d}q6|d|}n|}|rBt|}|D]@}|d|j|jft|j|j}|rF|d|qF|S)Nrz File "%s", line %sz %s)rIr2r=r@ linecachegetlinestrip)rlimitZmost_recent_firstlinesZ frame_slicer<liner r rformats  zTraceback.format)N)NF)r&r'r(r)r*rrDrKrMrVrWrrrBr"r#rbr r r rrEs  rEcCs t|}|durt|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)rrE)objrJr r rget_object_tracebacksrdc@s`eZdZdZdZddZeddZeddZed d Z d d Z d dZ ddZ ddZ dS)Tracez" Trace of a memory block. _tracecCs ||_dSrrfrrPr r rrszTrace.__init__cCs |jdSr/rfrr r rdomainsz Trace.domaincCs |jdSr>rfrr r rr sz Trace.sizecCst|jddS)N)rErgrr r rr#szTrace.tracebackcCst|tstS|j|jkSr)rrerrgrr r rr's z Trace.__eq__cCs t|jSr)rrgrr r rr,szTrace.__hash__cCsd|jt|jdfS)Nz%s: %sF)rrr rr r rr"/sz Trace.__str__cCsd|jt|jd|jfS)Nz'F)rirr rrr r rr#2szTrace.__repr__N)r&r'r(r)r*rrDrir rrrr"r#r r r rres   rec@s<eZdZddZddZddZddZd d Zd d Zd S)_TracescCst|||_dSr)rr_traces)rtracesr r rr8s z_Traces.__init__cCs t|jSr)rLrlrr r rrM=sz_Traces.__len__cCs4t|tr"tdd|j|DSt|j|SdS)Ncss|]}t|VqdSr)rerNr r rrQBrRz&_Traces.__getitem__..)rrSrHrlrerTr r rrV@s z_Traces.__getitem__cCs |j|jvSr)rgrlrhr r rrWFsz_Traces.__contains__cCst|tstS|j|jkSr)rrkrrlrr r rrIs z_Traces.__eq__cCs dt|S)Nz)rLrr r rr#Nsz_Traces.__repr__N) r&r'r(rrMrVrWrr#r r r rrk7s rkcCs&tj|}|dr"|dd}|S)Nz.pyc)ospathnormcaseendswith)r=r r r_normalize_filenameRs   rsc@seZdZddZddZdS) BaseFiltercCs ||_dSr) inclusive)rrur r rrZszBaseFilter.__init__cCstdSr)NotImplementedErrorrhr r r_match]szBaseFilter._matchN)r&r'r(rrwr r r rrtYsrtcsJeZdZdfdd ZeddZddZd d Zd d Zd dZ Z S)FilterNFcs2t|||_t||_||_||_||_dSr)superrrurs_filename_patternr@ all_framesri)rrufilename_patternr@r{ri __class__r rrbs   zFilter.__init__cCs|jSr)rzrr r rr|kszFilter.filename_patterncCs6t|}t||jsdS|jdur(dS||jkSdS)NFT)rsfnmatchrzr@rr=r@r r r_match_frame_implos  zFilter._match_frame_implcCs||||j ASr)rrurr r r _match_framexszFilter._match_framecsHjr,tfdd|Dr"jSj Sn|d\}}||SdS)Nc3s|]\}}||VqdSr)r)rOr=r@rr rrQ}sz*Filter._match_traceback..r)r{anyrur)rrr=r@r rr_match_traceback{s   zFilter._match_tracebackcCsF|\}}}}||}|jdurB|jr4|o2||jkS|p@||jkS|Sr)rriru)rrPrir rrKresr r rrws   z Filter._match)NFN) r&r'r(rrDr|rrrrw __classcell__r r r}rrxas    rxcs0eZdZfddZeddZddZZS) DomainFiltercst|||_dSr)ryr_domain)rrurir}r rrs zDomainFilter.__init__cCs|jSr)rrr r rriszDomainFilter.domaincCs|\}}}}||jk|j ASr)riru)rrPrir rrKr r rrws zDomainFilter._match)r&r'r(rrDrirwrr r r}rrs  rc@sXeZdZdZddZddZeddZdd Zd d Z d d Z dddZ dddZ dS)SnapshotzB Snapshot of traces of memory blocks allocated by Python. cCst||_||_dSr)rkrmtraceback_limit)rrmrr r rrs zSnapshot.__init__cCs>t|d }t||tjWdn1s00YdS)z1 Write the snapshot into a file. wbN)openpickledumpZHIGHEST_PROTOCOL)rr=fpr r rrs z Snapshot.dumpcCs8t|d}t|WdS1s*0YdS)z. Load a snapshot from a file. rbN)rrload)r=rr r rrs z Snapshot.loadcs@|rtfdd|DsdS|r.Fc3s|]}| VqdSrrrrr rrQsT)r)rinclude_filtersexclude_filtersrPr rr _filter_traces  zSnapshot._filter_tracecst|tstdt|j|rjgg|D] }|jrB|q,|q,fddjjD}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 )rrNrrrr r s z*Snapshot.filter_traces..) rr TypeErrortyper&rur2rmrlcopyrr)rfiltersrZ new_tracesr rr filter_tracess    zSnapshot.filter_tracesc Cs|dvrtd|f|r.|dvr.td|i}i}|s |jjD]}|\}}}} z ||} WnXty|dkr||} n(|dkr|dd} n|dddff} t| } | ||<Yn0z(|| } | j|7_| jd7_WqDtyt| |d|| <YqD0qDn|jjD]}|\}}}} |D]} z || } WnDty||dkrZ| f} n| ddff} t| } | || <Yn0z(|| } | j|7_| jd7_Wn$tyt| |d|| <Yn0q(q|S) N)rr=r@zunknown key_type: %r)r@r=z/cumulative mode cannot by used with key type %rrr@r?r) ValueErrorrmrlKeyErrorrEr rr)rkey_type cumulativeZstatsZ tracebacksrPrir Ztrace_tracebackrKrrJr6r<r r r _group_bysZ         zSnapshot._group_byFcCs,|||}t|}|jdtjd|S)zd Group statistics by key_type. Return a sorted list of Statistic instances. Treversekey)rlistvaluessortrr$)rrrZgroupedr5r r rr5s  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. Tr)rr7rr+r$)rZ old_snapshotrrr4r3r5r r r compare_tos    zSnapshot.compare_toN)F)F) r&r'r(r)rr staticmethodrrrrr5rr r r rrs  3 rcCs$tstdt}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_limitr)rmrr r r take_snapshot's r)collections.abcrr functoolsrrr\Zos.pathrorZ _tracemallocrrrrr+r7r8rErdrerkrsrtrxrrrr r r rs2 (2&M'0