a DOg@sddlZddlZddlZddlZddlmZddl m Z ddl m Z mZzddlmZWneyvddlmZYn0gdZejZejZejZejZzejZdZedWneyd ZYn0ej Z!z ej"Z#WneydZ#Yn0ej$Z$[da%da&d d Z'd d Z(eZ)ddZ"GdddZ*e*Z+GdddZ,GdddZ-Gddde-Z.GdddZ/GdddZ0Gddde1Z2ej3Z4e4dJdd Z5e"a6iZ7iZ8e Z9ea:e;azdd%lm?a@mAZBWnFey.dd&lCmDZEdd'lmFZFeFd(d)ZAd*d(ZBd+d,a@Yn0d-d.ZGGd/d0d0e>ZHGd1d2d2e>ZIGd3d4d4e>ZJd5d6ZKeKZLd7d8ZMeMZNd9d:ZOd;d<ZPgZQd aRd=d>ZSdd?lmTZTeIaUd@dAZVdBdCZWzddDlmXZYWn eyddElZmYZYYn0dFdGZ[e\edHrej]e[dIdS)KN) monotonic)WeakSet)islicecount)deque) get_ident active_count Conditioncurrent_thread enumerate main_thread TIMEOUT_MAXEventLockRLock SemaphoreBoundedSemaphoreThreadBarrierBrokenBarrierErrorTimer ThreadError setprofilesettracelocal stack_size excepthookExceptHookArgsT get_native_idFcCs|adSN) _profile_hookfuncr#!/usr/lib64/python3.9/threading.pyr:srcCs|adSr) _trace_hookr!r#r#r$rDsrcOs$tdurt|i|St|i|Sr)_CRLock_PyRLock)argskwargsr#r#r$rRs rc@sZeZdZddZddZddZdd d ZeZd d Zd dZ ddZ ddZ ddZ dS)_RLockcCst|_d|_d|_dSNr)_allocate_lock_block_owner_countselfr#r#r$__init__isz_RLock.__init__c Cs\|j}zt|j}Wnty&Yn0d|jr8dnd|jj|jj||j t t |fS)Nz)<%s %s.%s object owner=%r count=%d at %s>lockedunlocked) r._activenameKeyErrorr-r3 __class__ __module__ __qualname__r/hexid)r1ownerr#r#r$__repr__ns  z_RLock.__repr__cCs|jd|_d|_dSr+)r-_at_fork_reinitr.r/r0r#r#r$r?}s z_RLock._at_fork_reinitTcCsDt}|j|kr"|jd7_dS|j||}|r@||_d|_|SN)rr.r/r-acquire)r1blockingtimeoutmercr#r#r$rCs z_RLock.acquirecCs<|jtkrtd|jd|_}|s8d|_|jdS)Ncannot release un-acquired lockrB)r.r RuntimeErrorr/r-release)r1rr#r#r$rJs  z_RLock.releasecCs |dSrrJr1tvtbr#r#r$__exit__sz_RLock.__exit__cCs|j|\|_|_dSr)r-rCr/r.)r1stater#r#r$_acquire_restores z_RLock._acquire_restorecCs<|jdkrtd|j}d|_|j}d|_|j||fS)NrrH)r/rIr.r-rJ)r1rr=r#r#r$ _release_saves  z_RLock._release_savecCs |jtkSr)r.rr0r#r#r$ _is_ownedsz_RLock._is_ownedN)Tr@) __name__r9r:r2r>r?rC __enter__rJrPrRrSrTr#r#r#r$r*_s  $ r*c@sxeZdZdddZddZddZdd Zd d Zd d ZddZ ddZ dddZ dddZ dddZ ddZeZdS)r NcCs|durt}||_|j|_|j|_z |j|_WntyBYn0z |j|_WntybYn0z |j|_WntyYn0t|_ dSr) r_lockrCrJrSAttributeErrorrRrT_deque_waitersr1lockr#r#r$r2s$      zCondition.__init__cCs|j|jdSr)rWr?rZclearr0r#r#r$r?s zCondition._at_fork_reinitcCs |jSr)rWrVr0r#r#r$rVszCondition.__enter__cGs |jj|Sr)rWrP)r1r(r#r#r$rPszCondition.__exit__cCsd|jt|jfS)Nz)rWlenrZr0r#r#r$r>szCondition.__repr__cCs|jdSr)rWrJr0r#r#r$rS szCondition._release_savecCs|jdSr)rWrC)r1xr#r#r$rR szCondition._acquire_restorecCs"|jdr|jdSdSdSNFT)rWrCrJr0r#r#r$rTs  zCondition._is_ownedcCs|stdt}||j||}d}z|durN|d}n |dkrd|d|}n |d}|W|||sz|j|WSt yYS0Sz|j|Wnt yYn0n8|||sz|j|Wnt yYn00dS)Nzcannot wait on un-acquired lockFTr) rTrIr,rCrZappendrSrRremove ValueError)r1rEwaiter saved_stategotitr#r#r$waitsD      zCondition.waitcCsXd}|}|}|sT|durB|dur.t|}n|t}|dkrBqT|||}q|Sr+)_timerg)r1 predicaterEendtimewaittimeresultr#r#r$wait_forHs   zCondition.wait_forrBcCsz|std|j}|rv|dkrv|d}z |WntyHYn 0|d8}z||WqtyrYq0qdS)Nz!cannot notify on un-acquired lockrrB)rTrIrZrJrbrc)r1nwaitersrdr#r#r$notify_s     zCondition.notifycCs|t|jdSr)rpr^rZr0r#r#r$ notify_all}szCondition.notify_all)N)N)N)rB)rUr9r:r2r?rVrPr>rSrRrTrgrmrprq notifyAllr#r#r#r$r s  0   r c@s6eZdZd ddZd ddZeZddd Zd d ZdS)rrBcCs&|dkrtdtt|_||_dS)Nrz$semaphore initial value must be >= 0)rcr r_cond_valuer1valuer#r#r$r2s zSemaphore.__init__TNcCs|s|durtdd}d}|jp|jdkrr|s4q|durd|durPt|}n|t}|dkrdq|j|q$|jd8_d}Wdn1s0Y|S)Nz.can't specify timeout for non-blocking acquireFrrBT)rcrsrtrhrg)r1rDrErGrjr#r#r$rCs$    "zSemaphore.acquirecCs`|dkrtd|j6|j|7_t|D]}|jq.Wdn1sR0YdS)NrBn must be one or more)rcrsrtrangerpr1rnir#r#r$rJs  zSemaphore.releasecCs |dSrrKrLr#r#r$rPszSemaphore.__exit__)rB)TN)rB)rUr9r:r2rCrVrJrPr#r#r#r$rs   - rc@s eZdZdddZdddZdS) rrBcCst||||_dSr)rr2_initial_valuerur#r#r$r2s zBoundedSemaphore.__init__cCsx|dkrtd|jN|j||jkr0td|j|7_t|D]}|jqFWdn1sj0YdS)NrBrwz!Semaphore released too many times)rcrsrtr{rxrpryr#r#r$rJs  zBoundedSemaphore.releaseN)rB)rB)rUr9r:r2rJr#r#r#r$rs rc@sBeZdZddZddZddZeZddZd d Zdd d Z d S)rcCstt|_d|_dSNF)r rrs_flagr0r#r#r$r2s zEvent.__init__cCs|jdSr)rsr?r0r#r#r$r?szEvent._at_fork_reinitcCs|jSr)r}r0r#r#r$is_setsz Event.is_setcCs:|j d|_|jWdn1s,0YdSNT)rsr}rqr0r#r#r$setsz Event.setcCs0|jd|_Wdn1s"0YdSr|)rsr}r0r#r#r$r])sz Event.clearNcCsD|j*|j}|s|j|}|WdS1s60YdSr)rsr}rg)r1rEsignaledr#r#r$rg3s  z Event.wait)N) rUr9r:r2r?r~isSetrr]rgr#r#r#r$rs   rc@s|eZdZdddZdddZddZdd Zd d Zd d ZddZ ddZ ddZ e ddZ e ddZe ddZdS)rNcCs.tt|_||_||_||_d|_d|_dSr+)r rrs_action_timeout_parties_stater/)r1partiesactionrEr#r#r$r2]s zBarrier.__init__c Cs|dur|j}|j||j}|jd7_zL|d|jkrL|n |||W|jd8_|WdS|jd8_|0Wdn1s0YdSrA)rrs_enterr/r_release_wait_exit)r1rEindexr#r#r$rgms$   z Barrier.waitcCs(|jdvr|jq|jdkr$tdS)Nr@rBr)rrsrgrr0r#r#r$rs    zBarrier._entercCs>z"|jr|d|_|jWn|Yn0dSrA)rrrsrq_breakr0r#r#r$rszBarrier._releasecs4jfdd|s"tjdkr0tdS)Ncs jdkSr+rr#r0r#r$zBarrier._wait..r)rsrmrrrr1rEr#r0r$rs  z Barrier._waitcCs(|jdkr$|jdvr$d|_|jdS)Nrr)r/rrsrqr0r#r#r$rs  z Barrier._exitcCsh|jN|jdkr6|jdkr$d|_q<|jdkrrz,_maintain_shutdown_locks..)_shutdown_locksdifference_update) to_remover#r#r$_maintain_shutdown_lockss rc@seZdZdZd7ddddZddZd d Zd d Zd dZddZ ddZ e rXddZ ddZ ddZddZddZd8ddZd9d!d"Zed#d$Zejd%d$Zed&d'Ze red(d)Zd*d+Zed,d-Zejd.d-Zd/d0Zd1d2Zd3d4Zd5d6ZdS):rFNr#daemoncCs|dur i}||_t|pt|_||_||_|dur>||_n tj|_d|_ t rXd|_ d|_ t |_d|_d|_tj|_t|_t|dSr`)_targetstrr_name_args_kwargs _daemonicr r_ident_HAVE_THREAD_NATIVE_ID _native_id _tstate_lockr_started _is_stopped _initialized_sysstderr_stderr_make_invoke_excepthook_invoke_excepthook _danglingadd)r1grouptargetr6r(r)rr#r#r$r2"s& zThread.__init__cCs>|j|r.|jdur:|j|jn d|_d|_dSr)rr?rrCr)r1is_aliver#r#r$_reset_internal_locksQs    zThread._reset_internal_lockscCs^d}|jrd}||jr$d}|jr2|d7}|jdurJ|d|j7}d|jj|j|fS)Ninitialstartedstoppedz daemonz %sz <%s(%s, %s)>) rr~rrrrr8rUr)r1statusr#r#r$r>bs  zThread.__repr__c Cs|jstd|jr tdt|t|<Wdn1sB0Yzt|jdWn>tytt|=Wdn1s0YYn0|j dS)Nzthread.__init__() not calledz threads can only be started oncer#) rrIrr~_active_limbo_lock_limbo_start_new_thread _bootstrap Exceptionrgr0r#r#r$startps  & $z Thread.startcCs>z*|jr|j|ji|jW|`|`|`n|`|`|`0dSr)rrrr0r#r#r$runs z Thread.runcCs4z |Wn"|jr(tdur(YdSYn0dSr)_bootstrap_innerrrr0r#r#r$rs  zThread._bootstrapcCs t|_dSr)rrr0r#r#r$ _set_identszThread._set_identcCs t|_dSr)rrr0r#r#r$_set_native_idszThread._set_native_idcCsRt|_|j|jsNt"tt|jWdn1sD0YdSr) _set_sentinelrrCr_shutdown_locks_lockrrrr0r#r#r$_set_tstate_locks  zThread._set_tstate_lockcCs$z||tr||jt |t|j<t |=Wdn1sR0Yt rjt t t rxt t z |Wn||Yn0Wt*z tt=Wn Yn0Wdn1s0YnBt*z tt=Wn Yn0Wdn1s0Y0dSr)rrrrrrrr5rrr%rrr rrrrr0r#r#r$rs6  $    & zThread._bootstrap_innercCsN|j}|durd|_d|_|jsJttWdn1s@0YdSr)rrrrrr[r#r#r$_stopsz Thread._stopcCs0ttt=Wdn1s"0YdSr)rr5rr0r#r#r$_deleteszThread._deletecCsZ|jstd|js td|tur2td|durD|n|jt|dddS)NThread.__init__() not calledz'cannot join thread before it is startedzcannot join current threadr)rE)rrIrr~r _wait_for_tstate_lockmaxrr#r#r$joins   z Thread.joinTr@cCs^|j}|durdSz |||r0||Wn&|rR||Yn0dSr)rrCrJrr3)r1blockrEr\r#r#r$r*s  zThread._wait_for_tstate_lockcCs|jSr)rr0r#r#r$r6Es z Thread.namecCst||_dSr)rrr1r6r#r#r$r6PscCs|jSr)rr0r#r#r$identUs z Thread.identcCs|jSr)rr0r#r#r$ native_idbs zThread.native_idcCs&|js|jsdS|d|j Sr|)rrr~rr0r#r#r$rms  zThread.is_alivecCs|jSr)rr0r#r#r$r{s z Thread.daemoncCs*|jstd|jr td||_dS)Nrz)cannot set daemon status of active thread)rrIrr~rr1daemonicr#r#r$rs  cCs|jSrrr0r#r#r$isDaemonszThread.isDaemoncCs ||_dSrrrr#r#r$ setDaemonszThread.setDaemoncCs|jSrr6r0r#r#r$getNameszThread.getNamecCs ||_dSrrrr#r#r$setNameszThread.setName)NNNr#N)N)Tr@)rUr9r:rr2rr>rrrrrrrrrrrrrr6setterrrrrrrrrr#r#r#r$rsL  /  &       r) _excepthook_ExceptHookArgs)print_exception) namedtuplerz'exc_type exc_value exc_traceback threadcCst|Sr)r)r(r#r#r$rscCs|jtkrdStdur(tjdur(tj}n$|jdurH|jj}|durLdSndS|jdur`|jj}nt}td|d|ddt |j|j |j |d| dS)NzException in thread :Tfileflush)r) exc_type SystemExitrrthreadrr6rprint_print_exception exc_value exc_tracebackr)r(rr6r#r#r$rs&     rcsPttjdurtddur*tdtjttfdd}|S)Nzthreading.excepthook is Nonezsys.excepthook is Nonec szz.t}|dur}tg|}||Wnty}zjd|_~durbjdurbj}n|j}d|dddurjdurj}n}|WYd}~n d}~00Wd}nd}0dS)NTz"Exception in threading.excepthook:r)rrr__suppress_context__rr)rhookr(excrsys_excepthook local_print local_sysold_excepthookold_sys_excepthook sys_exc_infor#r$invoke_excepthooks( "z2_make_invoke_excepthook..invoke_excepthook)rrrIexc_infor)rr#rr$rs rc@s&eZdZdddZddZddZdS) rNcCsFt|||_||_|dur"|ng|_|dur4|ni|_t|_dSr)rr2intervalfunctionr(r)rfinished)r1rrr(r)r#r#r$r2 s  zTimer.__init__cCs|jdSr)rrr0r#r#r$cancelsz Timer.cancelcCs:|j|j|js,|j|ji|j|jdSr)rrgrr~rr(r)rr0r#r#r$rs z Timer.run)NN)rUr9r:r2rrr#r#r#r$rs rc@seZdZddZdS) _MainThreadcCshtj|ddd||j|tr6|t|t |j <Wdn1sZ0YdS)N MainThreadFr6r) rr2rrrrrrrr5rr0r#r#r$r2"s z_MainThread.__init__N)rUr9r:r2r#r#r#r$r src@s.eZdZddZddZddZd dd ZdS) _DummyThreadcCsdtj|tddd|j|tr2|t|t |j <Wdn1sV0YdS)NzDummy-%dTr) rr2rrrrrrrr5rr0r#r#r$r27s z_DummyThread.__init__cCsdSrr#r0r#r#r$rAsz_DummyThread._stopcCsdSrr#r0r#r#r$rDsz_DummyThread.is_aliveNcCsdSrr#rr#r#r$rHsz_DummyThread.join)N)rUr9r:r2rrrr#r#r#r$r5s rcCs*z ttWSty$tYS0dSr)r5rr7rr#r#r#r$r Ns  r cCs8t ttttWdS1s*0YdSr)rr^r5rr#r#r#r$r\srcCsttttSr)listr5valuesrr#r#r#r$ _enumeratehsrcCs@t(ttttWdS1s20YdSr)rrr5rrr#r#r#r$r lsr cOs2tr tdtj|g|Ri|}t|dS)Nz$can't register atexit after shutdown)_SHUTTING_DOWNrI functoolspartial_threading_atexitsra)r"argr)callr#r#r$_register_atexit{s r)rcCstjr dSdattD] }|qtjtkrFtj}|t nt t t }t Wdn1sp0Y|sq|D]}||qqFdSr) _main_threadrrreversedr rrrrJrrrrr]rC) atexit_calltlocklocksr\r#r#r$ _shutdowns"    &rcCstSr)rr#r#r#r$r sr )_local)rcCstai}ztt}Wnty0t}Yn0|atat a tt t }| t |D]>}||ur|dt}||_|||<q`|d|q`ttt |Wdn1s0YdS)NTF)rrr5rr7rrr,rrrrupdaterrrrrr]) new_activecurrentthreadsrrr#r#r$ _after_forks0         rregister_at_fork)after_in_child)r)^os_ossysr_threadr timerrh _weakrefsetr itertoolsr_islicerr/ _collectionsrrY ImportError collections__all__start_new_threadr allocate_lockr,rrrrrarXerrorrrr&r r r%rrrr*r'r rrrrrIr__next__rrrr5rrrrrrrrrrr tracebackrrrrrrrr currentThreadr activeCountrr r rrrrrr rrZ_threading_localrhasattrrr#r#r#r$s            v2S)O    5    8 5