MINI MINI MANI MO

Path : /usr/lib64/python3.6/multiprocessing/__pycache__/
File Upload :
Current File : //usr/lib64/python3.6/multiprocessing/__pycache__/pool.cpython-36.opt-2.pyc

3


 \e@s8ddgZddlZddlZddlZddlZddlZddlZddlZddlm	Z	ddlm
Z
mZdZdZ
dZejZdd	Zd
dZGdd
d
eZGdddZddZGdddeZdfddfddZddZGdddeZGdddeZeZGdddeZGdddeZGd d!d!eZ Gd"ddeZ!dS)#Pool
ThreadPoolN)util)get_contextTimeoutErrorcCstt|S)N)listmap)argsr,/usr/lib64/python3.6/multiprocessing/pool.pymapstar+srcCsttj|d|dS)Nrr)r		itertoolsstarmap)rrrr
starmapstar.src@seZdZddZddZdS)RemoteTracebackcCs
||_dS)N)tb)selfrrrr
__init__6szRemoteTraceback.__init__cCs|jS)N)r)rrrr
__str__8szRemoteTraceback.__str__N)__name__
__module____qualname__rrrrrr
r5src@seZdZddZddZdS)ExceptionWithTracebackcCs0tjt|||}dj|}||_d||_dS)Nz

"""
%s""")	tracebackformat_exceptiontypejoinexcr)rr rrrr
r<s
zExceptionWithTraceback.__init__cCst|j|jffS)N)rebuild_excr r)rrrr

__reduce__Asz!ExceptionWithTraceback.__reduce__N)rrrrr"rrrr
r;srcCst||_|S)N)r	__cause__)r rrrr
r!Ds
r!cs,eZdZfddZddZddZZS)MaybeEncodingErrorcs.t||_t||_tt|j|j|jdS)N)reprr valuesuperr$r)rr r&)	__class__rr
rPs

zMaybeEncodingError.__init__cCsd|j|jfS)Nz(Error sending result: '%s'. Reason: '%s')r&r )rrrr
rUszMaybeEncodingError.__str__cCsd|jj|fS)Nz<%s: %s>)r(r)rrrr
__repr__YszMaybeEncodingError.__repr__)rrrrrr)
__classcell__rr)r(r
r$Lsr$Fc'Cs|j}|j}t|dr*|jj|jj|dk	r:||d}xH|dksX|oT||kry
|}	Wn$ttfk
rtj	dPYnX|	dkrtj	dP|	\}
}}}
}yd||
|f}WnBt
k
r}z&|r|tk	rt||j
}d|f}WYdd}~XnXy||
||fWnRt
k
rd}z4t||d}tj	d|||
|d|ffWYdd}~XnXd}	}
}}}
}|d7}qBWtj	d	|dS)
N_writerrz)worker got EOFError or OSError -- exitingzworker got sentinel -- exitingTFrz0Possible encoding error while sending result: %szworker exiting after %d tasks)putgethasattrr+close_readerEOFErrorOSErrorrdebug	Exception_helper_reraises_exceptionr
__traceback__r$)inqueueoutqueueinitializerinitargsZmaxtasksZwrap_exceptionr,r-Z	completedtaskjobifuncrkwdsresultewrappedrrr
worker]sD





$rCcCs|dS)Nr)Zexrrr
r5sr5c@s2eZdZdZddZddfddfddZddZd	d
ZddZd
dZ	fifddZ
d<ddZd=ddZd>ddZ
ddZd?ddZd@ddZfiddfddZdAd d!ZdBd"d#Zed$d%Zed&d'Zed(d)Zed*d+Zd,d-Zd.d/Zd0d1Zd2d3Zed4d5Zed6d7Zd8d9Z d:d;Z!dS)CrTcOs|jj||S)N)_ctxProcess)rrr?rrr
rEszPool.ProcessNcCsn|pt|_|jtj|_i|_t|_||_	||_
||_|dkrPtj
pNd}|dkr`td|dk	rzt|rztd||_g|_|jtjtj|fd|_d|j_t|j_|jjtjtj|j|j|j|j|jfd|_d|j_t|j_|jjtjtj|j|j |jfd|_!d|j!_t|j!_|j!jt"j#||j$|j|j%|j|j|j|j|j!|jfdd|_&dS)Nrz&Number of processes must be at least 1zinitializer must be a callable)targetrT)rZexitpriority)'rrD
_setup_queuesqueueQueue
_taskqueue_cacheRUN_state_maxtasksperchild_initializer	_initargsos	cpu_count
ValueErrorcallable	TypeError
_processes_pool_repopulate_pool	threadingZThreadr_handle_workers_worker_handlerdaemonstart
_handle_tasks
_quick_put	_outqueue
_task_handler_handle_results
_quick_get_result_handlerrZFinalize_terminate_pool_inqueue
_terminate)r	processesr9r:Zmaxtasksperchildcontextrrr
rsT




z
Pool.__init__cCsZd}xPttt|jD]:}|j|}|jdk	rtjd||jd}|j|=qW|S)NFzcleaning up worker %dT)reversedrangelenrXexitcoderr3r)rZcleanedr=rCrrr
_join_exited_workerss

zPool._join_exited_workersc	Cs|xvt|jt|jD]^}|jt|j|j|j|j	|j
|jfd}|jj||j
jdd|_
d|_|jtjdqWdS)N)rFrrEZ
PoolWorkerTzadded worker)rlrWrmrXrErCrgrarPrQrO_wrap_exceptionappendnamereplacer]r^rr3)rr=wrrr
rYszPool._repopulate_poolcCs|jr|jdS)N)rorY)rrrr
_maintain_poolszPool._maintain_poolcCs4|jj|_|jj|_|jjj|_|jjj|_	dS)N)
rDZSimpleQueuergrar+sendr`r0recvrd)rrrr
rHszPool._setup_queuescCs|j|||jS)N)apply_asyncr-)rr>rr?rrr
applysz
Pool.applycCs|j||t|jS)N)
_map_asyncrr-)rr>iterable	chunksizerrr
r
szPool.mapcCs|j||t|jS)N)rzrr-)rr>r{r|rrr
rszPool.starmapcCs|j||t|||S)N)rzr)rr>r{r|callbackerror_callbackrrr

starmap_asyncszPool.starmap_asyncccsny0d}x&t|D]\}}||||fifVqWWn8tk
rh}z||dt|fifVWYdd}~XnXdS)Nr)	enumerater4r5)rZ
result_jobr>r{r=xrArrr
_guarded_task_generationszPool._guarded_task_generationrcCs|jtkrtd|dkrFt|j}|jj|j|j|||j	f|St
j|||}t|j}|jj|j|jt||j	fdd|DSdS)NzPool not runningrcss|]}|D]
}|Vq
qdS)Nr).0chunkitemrrr
	<genexpr>@szPool.imap.<locals>.<genexpr>)
rNrMrTIMapIteratorrLrKr,r_job_set_lengthr
_get_tasksr)rr>r{r|r@task_batchesrrr
imap's 




z	Pool.imapcCs|jtkrtd|dkrFt|j}|jj|j|j|||j	f|St
j|||}t|j}|jj|j|jt||j	fdd|DSdS)NzPool not runningrcss|]}|D]
}|Vq
qdS)Nr)rrrrrr
r[sz&Pool.imap_unordered.<locals>.<genexpr>)
rNrMrTIMapUnorderedIteratorrLrKr,rrrrrr)rr>r{r|r@rrrr
imap_unorderedBs 




zPool.imap_unorderedcCsB|jtkrtdt|j||}|jj|jd|||fgdf|S)NzPool not runningr)rNrMrTApplyResultrLrKr,r)rr>rr?r}r~r@rrr
rx]s

zPool.apply_asynccCs|j||t|||S)N)rzr)rr>r{r|r}r~rrr
	map_asynchszPool.map_asyncc
Cs|jtkrtdt|ds$t|}|dkrTtt|t|jd\}}|rT|d7}t|dkrdd}tj	|||}t
|j|t|||d}	|jj
|j|	j||df|	S)NzPool not running__len__rr)r~)rNrMrTr.r	divmodrmrXrr	MapResultrLrKr,rr)
rr>r{Zmapperr|r}r~Zextrarr@rrr
rzps&

zPool._map_asynccCsTtj}x0|jtks$|jr8|jtkr8|jtjdq
W|j	j
dtjddS)Ng?zworker handler exiting)
rZcurrent_threadrNrMrL	TERMINATErutimesleeprKr,rr3)poolthreadrrr
r[szPool._handle_workersc
Csjtj}xt|jdD]\}}d}zx|D]}|jr@tjdPy||Wq*tk
r}	zD|dd\}
}y||
j|d|	fWnt	k
rYnXWYdd}	~	Xq*Xq*W|rtjd|r|dnd}||dwPWdd}}}
XqWtjdy:tjd|j
dtjdx|D]}|dq&WWn tk
rZtjd	YnXtjd
dS)Nz'task handler found thread._state != RUNrFzdoing set_length()rztask handler got sentinelz/task handler sending sentinel to result handlerz(task handler sending sentinel to workersz/task handler got OSError when sending sentinelsztask handler exitingr)rZriterr-rNrr3r4_setKeyErrorr,r2)
	taskqueuer,r8rcacherZtaskseqZ
set_lengthr;rAr<idxprrr
r_sB







zPool._handle_taskscCstj}xy
|}Wn"ttfk
r6tjddSX|jrJtjdP|dkr^tjdP|\}}}y||j||Wntk
rYnXd}}}q
Wx|o|jt	kr:y
|}Wn"ttfk
rtjddSX|dkrtjdq|\}}}y||j||Wntk
r*YnXd}}}qWt
|drtjdy,x&tdD]}|jj
spP|q^WWnttfk
rYnXtjdt||jdS)	Nz.result handler got EOFError/OSError -- exitingz,result handler found thread._state=TERMINATEzresult handler got sentinelz&result handler ignoring extra sentinelr0z"ensuring that outqueue is not full
z7result handler exiting: len(cache)=%s, thread._state=%s)rZrr2r1rr3rNrrrr.rlr0pollrm)r8r-rrr;r<r=objrrr
rcsZ









zPool._handle_resultsccs4t|}x&ttj||}|s"dS||fVq
WdS)N)rtuplerislice)r>itsizerrrr
rszPool._get_taskscCstddS)Nz:pool objects cannot be passed between processes or pickled)NotImplementedError)rrrr
r"szPool.__reduce__cCs&tjd|jtkr"t|_t|j_dS)Nzclosing pool)rr3rNrMCLOSEr\)rrrr
r/s

z
Pool.closecCs$tjdt|_t|j_|jdS)Nzterminating pool)rr3rrNr\rh)rrrr
	terminates
zPool.terminatecCsDtjd|jj|jj|jjx|jD]}|jq0WdS)Nzjoining pool)rr3r\rrbrerX)rrrrr
rs



z	Pool.joincCsDtjd|jjx*|jr>|jjr>|jjtj	dqWdS)Nz7removing tasks from inqueue until task handler finishedr)
rr3Z_rlockacquireis_aliver0rrwrr)r7task_handlerrrrr
_help_stuff_finish(s



zPool._help_stuff_finishc	
Cs(tjdt|_t|_tjd|j||t|t|_|jdtjdtj|k	r`|j	|rt
|ddrtjdx|D]}	|	jdkr|	jqWtjdtj|k	r|j	tjdtj|k	r|j	|ot
|ddr$tjd	x,|D]$}	|	j
rtjd
|	j|	j	qWdS)Nzfinalizing poolz&helping task handler/workers to finishzjoining worker handlerrrzterminating workerszjoining task handlerzjoining result handlerzjoining pool workerszcleaning up worker %d)rr3rrNrrmr,rZrrr.rnrrpid)
clsrr7r8rZworker_handlerrZresult_handlerrrrrr
rf1s6










zPool._terminate_poolcCs|S)Nr)rrrr
	__enter___szPool.__enter__cCs|jdS)N)r)rexc_typeZexc_valZexc_tbrrr
__exit__bsz
Pool.__exit__)N)N)NNN)r)r)NNN)NNN)"rrrrprErrorYrurHryr
rrrrrrxrrzstaticmethodr[r_rcrr"r/rrrclassmethodrfrrrrrr
rsD8








.<			.c@s@eZdZddZddZddZddd	Zdd
dZdd
ZdS)rcCs4tj|_tt|_||_||_||_|||j<dS)N)	rZZEvent_eventnextjob_counterrrL	_callback_error_callback)rrr}r~rrr
rks

zApplyResult.__init__cCs
|jjS)N)rZis_set)rrrr
readysszApplyResult.readycCs|jS)N)_success)rrrr

successfulvszApplyResult.successfulNcCs|jj|dS)N)rwait)rtimeoutrrr
rzszApplyResult.waitcCs,|j||jst|jr"|jS|jdS)N)rrrr_value)rrrrr
r-}s
zApplyResult.getcCsV|\|_|_|jr$|jr$|j|j|jr>|jr>|j|j|jj|j|j=dS)N)rrrrrsetrLr)rr=rrrr
rs
zApplyResult._set)N)N)	rrrrrrrr-rrrrr
ris

	rc@seZdZddZddZdS)rcCsftj||||dd|_dg||_||_|dkrLd|_|jj||j=n||t	|||_dS)N)r~Tr)
rrrr
_chunksize_number_leftrrrbool)rrr|lengthr}r~rrr
rs


zMapResult.__init__cCs|jd8_|\}}|rp|jrp||j||j|d|j<|jdkr|jrZ|j|j|j|j=|jjnH|r|jrd|_||_|jdkr|j	r|j	|j|j|j=|jjdS)NrrF)
rrrrrrLrrrr)rr=Zsuccess_resultsuccessr@rrr
rs"




zMapResult._setN)rrrrrrrrr
rs
rc@s:eZdZddZddZdddZeZdd	Zd
dZdS)
rcCsJtjtj|_tt|_||_tj	|_
d|_d|_i|_
|||j<dS)Nr)rZZ	ConditionZLock_condrrrrLcollectionsdeque_items_index_length	_unsorted)rrrrr
rs

zIMapIterator.__init__cCs|S)Nr)rrrr
__iter__szIMapIterator.__iter__NcCs|j~y|jj}Wnhtk
r~|j|jkr6t|jj|y|jj}Wn(tk
rx|j|jkrpttYnXYnXWdQRX|\}}|r|S|dS)N)	rrpopleft
IndexErrorrr
StopIterationrr)rrrrr&rrr
rs"zIMapIterator.nextc
Cs|j|j|krr|jj||jd7_x8|j|jkrd|jj|j}|jj||jd7_q.W|jjn
||j|<|j|jkr|j|j	=WdQRXdS)Nr)
rrrrqrpopnotifyrrLr)rr=rrrr
rs

zIMapIterator._setc	Cs<|j,||_|j|jkr.|jj|j|j=WdQRXdS)N)rrrrrLr)rrrrr
rs

zIMapIterator._set_length)N)	rrrrrr__next__rrrrrr
rs

rc@seZdZddZdS)rc
CsP|j@|jj||jd7_|jj|j|jkrB|j|j=WdQRXdS)Nr)rrrqrrrrLr)rr=rrrr
rs
zIMapUnorderedIterator._setN)rrrrrrrr
rsrc@s@eZdZdZeddZddffddZddZed	d
ZdS)rFcOsddlm}|||S)Nr)rE)ZdummyrE)rr?rErrr
rEszThreadPool.ProcessNcCstj||||dS)N)rr)rrir9r:rrr
rszThreadPool.__init__cCs,tj|_tj|_|jj|_|jj|_dS)N)rIrJrgrar,r`r-rd)rrrr
rHs


zThreadPool._setup_queuesc
Cs<|j,|jj|jjdg||jjWdQRXdS)N)Z	not_emptyrIclearextendZ
notify_all)r7rrrrr
rs
zThreadPool._help_stuff_finish)	rrrrprrErrHrrrrr
rs
)"__all__rZrIrrrRrrrrrrrMrrcountrrrr4rrr!r$rCr5objectrrZAsyncResultrrrrrrrr
<module>
s@	*\&)@

OHA YOOOO