a  zeP$@sddlZddlZddlZddlZddlmZmZddlmZddlm Z ddlm Z gdZ ej dkrpd Z d Zneed d Z ejd Zerejejd anejad dZddZddZddZddZd'ddZddZddZddZgZ dd Z!d!d"Z"d#d$Z#d%d&Z$dS)(N)get_start_methodset_start_method)process) reduction)util)_mainfreeze_supportset_executableget_executableget_preparation_dataget_command_lineimport_main_pathwin32Ffrozenzpythonservice.exez python.execCs|adSN _python_exe)ZexerI/opt/bitninja-python-dojo/embedded/lib/python3.9/multiprocessing/spawn.pyr )sr cCstSrrrrrrr -sr cCs$t|dkr|ddkrdSdSdS)Nr--multiprocessing-forkTF)len)argvrrr is_forking4srcCshttjrdi}tjddD]0}|d\}}|dkr@d||<qt|||<qtfi|tdS)Nr=None)rsysrsplitint spawn_mainexit)kwdsargnamevaluerrrr >s  r cKshttddr(tjdgdd|DSd}|ddd |D;}t}tg|d |dgSdS) NrFrcSsg|] }d|qS)%s=%rr.0itemrrr Tz$get_command_line..zWr+z#get_command_line..z-c)getattrr executableitemsjoinr_args_from_interpreter_flagsr)r"progZoptsrrrr Ns r c Cstjdkr`ddl}ddl}|dur:||j|jBd|}nd}tj||d}| |t j }|}n"ddl m } || j_|}t |}t||} t| dS)NrrF)source_processr)resource_tracker)rplatformmsvcrt_winapiZ OpenProcessZ SYNCHRONIZEZPROCESS_DUP_HANDLErZ duplicateopen_osfhandleosO_RDONLYr4_resource_trackerZ_fdduprr!) Z pipe_handleZ parent_pidZ tracker_fdr6r7r3Z new_handlefdparent_sentinelr4exitcoderrrr \s(     r c Cs|tj|dddR}dt_z,tj|}t|tj|}Wt`n t`0Wdn1sh0Y| |S)NrbT)closefd) r9fdopenrcurrent_process _inheritingrpickleloadprepare _bootstrap)r>r?Z from_parentZpreparation_dataselfrrrrxs  2rcCsttddrtddS)NrEFa 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-rrD RuntimeErrorrrrr_check_not_importing_mainsrLcCstttjtjd}tjdur2tj|d<t j }z| d}Wnt y\Yn 0tj||<|j||t jtjttdt jd}t|jdd}|dur||d<nft jdkststst|d d}|durtj |stjdurtj tj|}tj ||d <|S) N) log_to_stderrauthkey log_levelr;)r$sys_pathsys_argvorig_dirdir start_method__main__r$init_main_from_namer__file__init_main_from_path)rLdictr_log_to_stderrrrDrN_loggergetEffectiveLevelrpathcopyindex ValueError ORIGINAL_DIRupdaterr9getcwdrmodulesr-__spec__r5WINEXE WINSERVICEisabsr0normpath)r$drPi main_moduleZ main_mod_name main_pathrrrr sD        r cCsd|vr|dt_d|vr,|dt_d|vrD|drDtd|vr^t|dd|vrp|dt_ d|vr|dt_ d|vrt |dd|vr|dt_ d |vrt|d d d d |vrt|d nd |vrt|d dS)Nr$rNrMrOrPrQrSrRrTT)forcerVrX)rrDr$rNrrM get_loggersetLevelrr]rr9chdirrar_fixup_main_from_name_fixup_main_from_path)datarrrrHs,   rHcCs~tjd}|dks|dr dSt|jdd|kr6dSt|td}t j |ddd}|j ||tjd<tjd<dS)NrUz .__main__r$ __mp_main__T)run_nameZ alter_sys) rrdendswithr-reold_main_modulesappendtypes ModuleTyperunpyZ run_module__dict__rb)Zmod_name current_mainrl main_contentrrrrrs    rrcCstjd}tjtj|d}|dkr.dSt|dd|krBdSt|t d}t j |dd}|j ||tjd<tjd<dS)NrUrZipythonrWru)rv)rrdr9r]splitextbasenamer-rxryrzr{r|Zrun_pathr}rb)rmr~Z main_namerlrrrrrs s    rscCs t|dSr)rs)rmrrrr%sr)NN)%r9rr|rzr;rrrcontextrr__all__r5rfrgr-r.lowerrwr]r0 exec_prefixrr r rr r r rrLr rxrHrrrsrrrrr s<        2&