Your IP : 18.191.207.141
3
\�"�@s.ddlZddlZddlZddlZddlmZmZddlmZddlm Z ddlm
Z
ddd d
ddd
gZejdkrzdZ
dZn&ejdko�eedd�Z
ejj�jd�Zer�ejjejd�anejadd �Zdd
�Zdd�Zdd�Zdd�Zd&dd�Zdd�Zdd�Zdd�ZgZ dd �Z!d!d"�Z"d#d$�Z#d%d
�Z$dS)'�N�)�get_start_method�set_start_method)�process)� reduction)�util�_main�freeze_support�set_executable�get_executable�get_preparation_data�get_command_line�import_main_path�win32F�frozenzpythonservice.exez
python.execCs|adS)N)�_python_exe)Zexe�r�-/usr/lib64/python3.6/multiprocessing/spawn.pyr
)scCstS)N)rrrrrr-scCs$t|�dkr|ddkrdSdSdS)N�rz--multiprocessing-forkTF)�len)�argvrrr�
is_forking4srcCshttj�rdi}xBtjdd�D]0}|jd�\}}|dkrBd||<qt|�||<qWtf|�tj�dS)Nr�=�None)r�sysr�split�int�
spawn_main�exit)�kwds�arg�name�valuerrrr >s
cKshttdd�r(tjdgdd�|j�D�Sd}|djdd �|j�D��;}tj�}tg|d
|dgSdS)NrFz--multiprocessing-forkcSsg|]}d|�qS)z%s=%rr)�.0�itemrrr�
<listcomp>Tsz$get_command_line.<locals>.<listcomp>z<from multiprocessing.spawn import spawn_main; spawn_main(%s)z, css|]}d|VqdS)z%s=%rNr)r#r$rrr� <genexpr>Wsz#get_command_line.<locals>.<genexpr>z-c)�getattrr�
executable�items�joinrZ_args_from_interpreter_flagsr)r�progZoptsrrrr
NscCs\tjdkr.ddl}tj||�}|j|tj�}nddlm }||j
_|}t|�}tj
|�dS)Nrrr)�semaphore_tracker)r�platform�msvcrtrZsteal_handleZopen_osfhandle�os�O_RDONLY�r,Z_semaphore_trackerZ_fdrr)Zpipe_handleZ
parent_pidZ
tracker_fdr.Z
new_handle�fdr,Zexitcoderrrr\s
rcCs^tj|ddd��@}dtj�_z$tjj|�}t|�tjj|�}Wdtj�`XWdQRX|j �S)N�rbT)�closefd)
r/�fdopenr�current_process�_inheritingr�pickle�load�prepare�
_bootstrap)r2Zfrom_parentZpreparation_data�selfrrrrms
cCsttj�dd�rtd��dS)Nr7Fa
An attempt has been made to start a new process before the
current process has finished its bootstrapping phase.
This probably means that you are not using fork to start your
child processes and you have forgotten to use the proper idiom
in the main module:
if __name__ == '__main__':
freeze_support()
...
The "freeze_support()" line can be omitted if the program
is not going to be frozen to produce an executable.)r'rr6�RuntimeErrorrrrr�_check_not_importing_mainys
r>cCs t�ttjtj�jd�}tjdk r2tjj�|d<t j
j�}y|jd�}Wnt
k
r^YnXtj||<|j||t jtjtj�t�d�t jd}t|jdd�}|dk r�||d<nht jdks�to�t�rt|d d�}|dk �rtj
j|�o�tjdk �rtj
jtj|�}tj
j|�|d
<|S)N)�
log_to_stderr�authkey� log_levelr1)r!�sys_path�sys_argv�orig_dir�dir�start_method�__main__r!�init_main_from_namer�__file__�init_main_from_path)r>�dictrZ_log_to_stderrrr6r@Z_loggerZgetEffectiveLevelr�path�copy�index�
ValueError�ORIGINAL_DIR�updaterr/�getcwdr�modulesr'�__spec__r-�WINEXE�
WINSERVICE�isabsr*�normpath)r!�drB�i�main_moduleZ
main_mod_name� main_pathrrrr�s>
cCs�d|kr|dtj�_d|kr,|dtj�_d|krD|drDtj�d|kr^tj�j|d�d|krp|dt_ d|kr�|dt_
d|kr�tj|d�d|kr�|dt_
d |kr�t|d d
d�d|kr�t|d�nd
|kr�t|d
�dS)Nr!r@r?rArBrCrErDrFT)ZforcerHrJ)rr6r!r@rr?Z
get_loggerZsetLevelrrLrr/�chdirrPr�_fixup_main_from_name�_fixup_main_from_path)�datarrrr:�s,
r:cCs~tjd}|dks|jd�r dSt|jdd�|kr6dStj|�tjd�}t j
|ddd�}|jj|�|tjd<tjd<dS)NrGz .__main__r!�__mp_main__T)�run_nameZ alter_sys)
rrS�endswithr'rT�old_main_modules�append�types�
ModuleType�runpyZ
run_module�__dict__rQ)Zmod_name�current_mainr[�main_contentrrrr^�s
r^cCs�tjd}tjjtjj|��d}|dkr.dSt|dd�|krBdStj|�t j
d�}tj|dd�}|j
j|�|tjd<tjd<dS)NrGrZipythonrIra)rb)rrSr/rL�splitext�basenamer'rdrerfrgrhZrun_pathrirQ)r\rjZ main_namer[rkrrrr_�s
r_cCst|�dS)N)r_)r\rrrrs)NN)%r/rrhrfr1rrr�contextrr�__all__r-rUrVr'r(�lowerrcrLr*�exec_prefixrr
rrr r
rrr>rrdr:r^r_rrrrr�<module>s>
2&
?>