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)sizesignZunitr#/usr/lib64/python3.9/tracemalloc.py _format_size src@s@eZdZdZddZddZddZdd Zd d Zd d Z dS) Statistic tracebackr countcCs||_||_||_dSNr)selfrr rrrr__init__%szStatistic.__init__cCst|j|j|jfSr)hashrr rrrrr__hash__*szStatistic.__hash__cCs2t|tstS|j|jko0|j|jko0|j|jkSr) isinstancerNotImplementedrr rrotherrrr__eq__-s    zStatistic.__eq__cCsBd|jt|jd|jf}|jr>|j|j}|dt|d7}|S)Nz%s: size=%s, count=%iF , average=%s)rrr rrtextZaveragerrr__str__4s  zStatistic.__str__cCsd|j|j|jfS)Nz)rrrrr__repr__>szStatistic.__repr__cCs|j|j|jfSr)r rrrrrr _sort_keyBszStatistic._sort_keyN __name__ __module__ __qualname__ __slots__rrrr#r$r%rrrrrs rc@s@eZdZdZddZddZddZdd Zd d Zd d Z dS) StatisticDiffrr size_diffr count_diffcCs"||_||_||_||_||_dSrr,)rrr r-rr.rrrrMs zStatisticDiff.__init__cCst|j|j|j|j|jfSr)rrr r-rr.rrrrrTszStatisticDiff.__hash__cCsJt|tstS|j|jkoH|j|jkoH|j|jkoH|j|jkoH|j|jkSr)rr+rrr r-rr.rrrrrXs      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!rrrr#as   zStatisticDiff.__str__cCsd|j|j|j|j|jfS)Nz9r,rrrrr$ms  zStatisticDiff.__repr__cCs t|j|jt|j|j|jfSr)r r-r r.rrrrrrr%rs  zStatisticDiff._sort_keyNr&rrrrr+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 statisticsrstatZpreviousrrr_compare_grouped_statsxs"   r7c@sXeZdZdZddZeddZeddZdd Zd d Z d d Z ddZ ddZ dS)Frame_framecCs ||_dSrr9rframerrrrszFrame.__init__cCs |jdSr/r9rrrrfilenameszFrame.filenamecCs |jdSNr9rrrrlinenosz Frame.linenocCst|tstS|j|jkSrrr8rr:rrrrrs z Frame.__eq__cCst|tstS|j|jkSrrArrrr__lt__s z Frame.__lt__cCs t|jSr)rr:rrrrrszFrame.__hash__cCsd|j|jfS)Nz%s:%sr=r@rrrrr#sz Frame.__str__cCsd|j|jfS)NzrCrrrrr$szFrame.__repr__N) r'r(r)r*rpropertyr=r@rrBrr#r$rrrrr8s  r8c@speZdZdZdddZeddZddZd d Zd d Z d dZ ddZ ddZ ddZ ddZdddZdS) Traceback)_frames _total_nframeNcCs"t|tt||_||_dSr)rrtuplereversedrFrG)rframes total_nframerrrrs zTraceback.__init__cCs|jSr)rGrrrrrKszTraceback.total_nframecCs t|jSr)lenrFrrrr__len__szTraceback.__len__cCs4t|tr"tdd|j|DSt|j|SdS)Ncss|]}t|VqdSr)r8.0tracerrr z(Traceback.__getitem__..)rslicerHrFr8rindexrrr __getitem__s zTraceback.__getitem__cCs |j|jvSr)r:rFr;rrr __contains__szTraceback.__contains__cCs t|jSr)rrFrrrrrszTraceback.__hash__cCst|tstS|j|jkSrrrErrFrrrrrs zTraceback.__eq__cCst|tstS|j|jkSrrXrrrrrBs zTraceback.__lt__cCs t|dSr/)strrrrrr#szTraceback.__str__cCs8dt|}|jdur"|d7}n|d|jd7}|S)Nz z total_nframe=)rHrGrK)rsrrrr$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<linerrrformats  zTraceback.format)N)NF)r'r(r)r*rrDrKrMrVrWrrrBr#r$rbrrrrrEs  rEcCs t|}|durt|SdSdSr)rrE)objrJrrrget_object_tracebacksrdc@s\eZdZdZddZeddZeddZedd Zd d Z d d Z ddZ ddZ dS)Trace_tracecCs ||_dSrrfrrPrrrrszTrace.__init__cCs |jdSr/rfrrrrdomainsz Trace.domaincCs |jdSr>rfrrrrr sz Trace.sizecCst|jddS)N)rErgrrrrr#szTrace.tracebackcCst|tstS|j|jkSr)rrerrgrrrrr's z Trace.__eq__cCs t|jSr)rrgrrrrr,szTrace.__hash__cCsd|jt|jdfS)Nz%s: %sF)rrr rrrrr#/sz Trace.__str__cCsd|jt|jd|jfS)Nz'F)rirr rrrrrr$2szTrace.__repr__N) r'r(r)r*rrDrir rrrr#r$rrrrres   rec@s<eZdZddZddZddZddZd d Zd d Zd S)_TracescCst|||_dSr)rr_traces)rtracesrrrr8s z_Traces.__init__cCs t|jSr)rLrlrrrrrM=sz_Traces.__len__cCs4t|tr"tdd|j|DSt|j|SdS)Ncss|]}t|VqdSr)rerNrrrrQBrRz&_Traces.__getitem__..)rrSrHrlrerTrrrrV@s z_Traces.__getitem__cCs |j|jvSr)rgrlrhrrrrWFsz_Traces.__contains__cCst|tstS|j|jkSr)rrkrrlrrrrrIs z_Traces.__eq__cCs dt|S)Nz)rLrrrrr$Nsz_Traces.__repr__N) r'r(r)rrMrVrWrr$rrrrrk7s rkcCs&tj|}|dr"|dd}|S)Nz.pyc)ospathnormcaseendswith)r=rrr_normalize_filenameRs   rsc@seZdZddZddZdS) BaseFiltercCs ||_dSr) inclusive)rrurrrrZszBaseFilter.__init__cCstdSr)NotImplementedErrorrhrrr_match]szBaseFilter._matchN)r'r(r)rrwrrrrrtYsrtcsJeZdZdfdd ZeddZddZd d Zd d Zd dZ Z S)FilterNFcs2t|||_t||_||_||_||_dSr)superrrurs_filename_patternr@ all_framesri)rrufilename_patternr@r{ri __class__rrrbs   zFilter.__init__cCs|jSr)rzrrrrr|kszFilter.filename_patterncCs6t|}t||jsdS|jdur(dS||jkSdS)NFT)rsfnmatchrzr@rr=r@rrr_match_frame_implos  zFilter._match_frame_implcCs||||j ASr)rrurrrr _match_framexszFilter._match_framecsHjr,tfdd|Dr"jSj Sn|d\}}||SdS)Nc3s|]\}}||VqdSr)r)rOr=r@rrrrQ}sz*Filter._match_traceback..r)r{anyrur)rrr=r@rrr_match_traceback{s   zFilter._match_tracebackcCsF|\}}}}||}|jdurB|jr4|o2||jkS|p@||jkS|Sr)rriru)rrPrir rrKresrrrrws   z Filter._match)NFN) r'r(r)rrDr|rrrrw __classcell__rrr}rrxas    rxcs0eZdZfddZeddZddZZS) DomainFiltercst|||_dSr)ryr_domain)rrurir}rrrs zDomainFilter.__init__cCs|jSr)rrrrrriszDomainFilter.domaincCs|\}}}}||jk|j ASr)riru)rrPrir rrKrrrrws zDomainFilter._match)r'r(r)rrDrirwrrrr}rrs  rc@sTeZdZddZddZeddZddZd d Zd d Z dddZ dddZ dS)SnapshotcCst||_||_dSr)rkrmtraceback_limit)rrmrrrrrs zSnapshot.__init__cCs>t|d }t||tjWdn1s00YdS)Nwb)openpickledumpHIGHEST_PROTOCOL)rr=fprrrrs z Snapshot.dumpcCs8t|d}t|WdS1s*0YdS)Nrb)rrload)r=rrrrrs z Snapshot.loadcs@|rtfdd|DsdS|r.Fc3s|]}| VqdSrrrrrrrQsT)r)rinclude_filtersexclude_filtersrPrrr _filter_traces  zSnapshot._filter_tracecst|tstdt|j|rjgg|D] }|jrB|q,|q,fddjjD}n jj }t |j S)Nz)filters must be a list of filters, not %scsg|]}|r|qSr)rrNrrrrr s z*Snapshot.filter_traces..) rr TypeErrortyper'rur2rmrlcopyrr)rfiltersrZ new_tracesrrr 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<rrr _group_bysZ         zSnapshot._group_byFcCs,|||}t|}|jdtjd|SNT)reversekey)rlistvaluessortrr%)rrrZgroupedr5rrrr5s  zSnapshot.statisticscCs6|||}|||}t||}|jdtjd|Sr)rr7rr+r%)rZ old_snapshotrrr4r3r5rrr compare_tos    zSnapshot.compare_toN)F)F) r'r(r)rr staticmethodrrrrr5rrrrrrs  3 rcCs$tstdt}t}t||S)NzLthe tracemalloc module must be tracing memory allocations to take a snapshot) is_tracing RuntimeErrorrZget_traceback_limitr)rmrrrr take_snapshot's r)collections.abcrr functoolsrrr\Zos.pathrorZ _tracemallocrrrrr+r7r8rErdrerkrsrtrxrrrrrrrs2 (2&M'0