a DOg}@sTdZddlZddlZddlZddlZddlZddlZddlZddlm Z ddlm Z ddlm Z ddlm Z ddlm Z dd lmZdd lmZdd lmZdd lmZd dZGdddejejZGdddeejZGdddeejZGdddeZGdddeejZGdddeeejZGdddeeejZ Gddde j!Z"dS))BaseProactorEventLoopN) base_events) constants)futures) exceptions) protocols)sslproto) transports)trsock)loggercCst||jd<z||jd<Wn.tjyP|jrLtj d|ddYn0d|jvrz| |jd<Wntjyd|jd<Yn0dS)NsocketZsocknamezgetsockname() failed on %rTexc_infopeername) r TransportSocket_extraZ getsocknamer error_loop get_debugr warningZ getpeername) transportsockr ) r4__name__r appendr(filenor$r%r#lenr)formatjoin)r-inforrr__repr__Hs         z#_ProactorBasePipeTransport.__repr__cCs||jd<dS)Npipe)rr-rrrrrZsz%_ProactorBasePipeTransport._set_extracCs ||_dSNr+)r-r/rrrr!]sz'_ProactorBasePipeTransport.set_protocolcCs|jSrBrCr-rrr get_protocol`sz'_ProactorBasePipeTransport.get_protocolcCs|jSrB)r(rDrrr is_closingcsz%_ProactorBasePipeTransport.is_closingcCs\|jr dSd|_|jd7_|js>|jdur>|j|jd|jdurX|jd|_dS)NTr) r(r'r#r%rr*_call_connection_lostr$cancelrDrrrclosefs  z _ProactorBasePipeTransport.closecCs*|jdur&|d|t|d|dS)Nzunclosed transport )source)r ResourceWarningrI)r-Z_warnrrr__del__qs z"_ProactorBasePipeTransport.__del__Fatal error on pipe transportc Cs`zNt|tr*|jrBtjd||ddn|j||||jdW||n ||0dS)Nz%r: %sTr)message exceptionrr/) isinstanceOSErrorrrr debugcall_exception_handlerr+ _force_close)r-excrNrrr _fatal_errorvs   z'_ProactorBasePipeTransport._fatal_errorcCs|jdur6|js6|dur*|jdn |j||jr@dSd|_|jd7_|jrj|jd|_|jr|jd|_d|_ d|_ |j |j |dS)NTrr) _empty_waiterdone set_resultZ set_exceptionr(r'r%rHr$r&r#rr*rG)r-rUrrrrTs"   z'_ProactorBasePipeTransport._force_closec Cszd|j|Wt|jdr8|jdkr8|jtj|jd|_|j }|dur| d|_ nVt|jdr|jdkr|jtj|jd|_|j }|dur| d|_ 0dS)Nshutdown) r+Zconnection_losthasattrr r:rZr Z SHUT_RDWRrIr"Z_detach)r-rUr2rrrrGs$  z0_ProactorBasePipeTransport._call_connection_lostcCs"|j}|jdur|t|j7}|SrB)r&r#r;)r-sizerrrget_write_buffer_sizes z0_ProactorBasePipeTransport.get_write_buffer_size)NNN)rM)r8 __module__ __qualname__rr?rr!rErFrIwarningswarnrLrVrTrGr^ __classcell__rrr3rr.s  rcsPeZdZdfdd ZddZddZdd Zd d Zd d ZdddZ Z S)_ProactorReadPipeTransportNcs:d|_d|_t|||||||j|jd|_dS)NTF) _pending_data_pausedrrrr* _loop_readingr,r3rrrs z#_ProactorReadPipeTransport.__init__cCs|j o|j SrB)rfr(rDrrr is_readingsz%_ProactorReadPipeTransport.is_readingcCs0|js |jrdSd|_|jr,td|dS)NTz%r pauses reading)r(rfrrr rRrDrrr pause_readings   z(_ProactorReadPipeTransport.pause_readingcCsn|js |jsdSd|_|jdur0|j|jd|j}d|_|durT|j|j||jrjt d|dS)NFz%r resumes reading) r(rfr$rr*rgre_data_receivedrr rRr-datarrrresume_readings   z)_ProactorReadPipeTransport.resume_readingc Cs~|jrtd|z|j}WnHttfy<Yn2tyl}z| |dWYd}~dSd}~00|sz| dS)Nz%r received EOFz1Fatal error: protocol.eof_received() call failed.) rrr rRr+Z eof_received SystemExitKeyboardInterrupt BaseExceptionrVrI)r-Z keep_openrUrrr _eof_receiveds  z(_ProactorReadPipeTransport._eof_receivedc Cs|jr||_dS|s |dSt|jtjrzt|j|Wqtt fyXYqt y}z| |dWYd}~dSd}~00n |j |dS)Nz3Fatal error: protocol.buffer_updated() call failed.) rfrerqrPr+rZBufferedProtocolZ_feed_data_to_buffered_protornrorprVZ data_received)r-rlrUrrrrjs"z)_ProactorReadPipeTransport._data_receivedc Csd}zz|dur2d|_|r*|}n||jrVd}WW|durR||dS|dkrxWW|durt||dS|js|jj |j d|_Wnt y}z8|js| |dn|j rtjdddWYd}~nd}~0ty}z||WYd}~nnd}~0tyB}z| |dWYd}~n>d}~0tjy`|js\Yn0|jsx|j|jW|dur||n|dur||0dS)Niz"Fatal read error on pipe transportz*Read error on pipe transport while closingTr)r$rXresultrHr(rjrfr _proactorrecvr ConnectionAbortedErrorrVrr rRConnectionResetErrorrTrQrCancelledErroradd_done_callbackrg)r-futrlrUrrrrgsP       z(_ProactorReadPipeTransport._loop_reading)NNN)N) r8r_r`rrhrirmrqrjrgrcrrr3rrds rdcsZeZdZdZfddZddZdddZd d Zd d Zd dZ ddZ ddZ Z S)_ProactorBaseWritePipeTransportTcstj|i|d|_dSrB)rrrWr-argskwr3rrrGsz(_ProactorBaseWritePipeTransport.__init__cCst|tttfs$tdt|j|jr2td|j durDtd|sLdS|j rz|j t j krht d|j d7_ dS|jdur|jt|dn.|jst||_|n|j||dS)Nz/data argument must be a bytes-like object, not zwrite_eof() already calledz(unable to write; sendfile is in progresszsocket.send() raised exception.r)rl)rPbytes bytearray memoryview TypeErrortyper8r) RuntimeErrorrWr'r!LOG_THRESHOLD_FOR_CONNLOST_WRITESr rr% _loop_writingr#_maybe_pause_protocolextendrkrrrwriteKs0       z%_ProactorBaseWritePipeTransport.writeNc CsZz|dur |jdur |jr WdSd|_d|_|r8||durL|j}d|_|s|jrf|j|jd|jrz|j t j | nN|jj|j ||_|jst||_|j|j|n|j|j|jdur|jdur|jdWn`ty$}z||WYd}~n:d}~0tyT}z||dWYd}~n d}~00dS)Nrz#Fatal write error on pipe transport)r%r(r&rsr#rr*rGr)r rZr SHUT_WR_maybe_resume_protocolrtsendrXr;ryrrrWrYrwrTrQrV)r-frlrUrrrrqs8    z-_ProactorBaseWritePipeTransport._loop_writingcCsdSNTrrDrrr can_write_eofsz-_ProactorBaseWritePipeTransport.can_write_eofcCs |dSrB)rIrDrrr write_eofsz)_ProactorBaseWritePipeTransport.write_eofcCs|ddSrBrTrDrrrabortsz%_ProactorBaseWritePipeTransport.abortcCs:|jdurtd|j|_|jdur4|jd|jS)NzEmpty waiter is already set)rWrrZ create_futurer%rYrDrrr_make_empty_waiters     z2_ProactorBaseWritePipeTransport._make_empty_waitercCs d|_dSrB)rWrDrrr_reset_empty_waitersz3_ProactorBaseWritePipeTransport._reset_empty_waiter)NN) r8r_r`Z_start_tls_compatiblerrrrrrrrrcrrr3rr{As & )r{cs$eZdZfddZddZZS)_ProactorWritePipeTransportcs8tj|i||jj|jd|_|j|jdS)N) rrrrtrur r$ry _pipe_closedr|r3rrrsz$_ProactorWritePipeTransport.__init__cCs@|r dS|jrdSd|_|jdur4|tn|dSrB)Z cancelledr(r$r%rTBrokenPipeErrorrI)r-rzrrrrs z(_ProactorWritePipeTransport._pipe_closed)r8r_r`rrrcrrr3rrs rcsXeZdZdZdfdd ZddZddZd d Zdd d Zdd dZ dddZ Z S)_ProactorDatagramTransportiNcs>||_d|_tj|||||dt|_|j|j dS)N)r0r1) _addressrWrr collectionsdequer#rr*rg)r-r.rr/addressr0r1r3rrrs  z#_ProactorDatagramTransport.__init__cCst||dSrBrrArrrrsz%_ProactorDatagramTransport._set_extracCstdd|jDS)Ncss|]\}}t|VqdSrB)r;).0rl_rrr rrzC_ProactorDatagramTransport.get_write_buffer_size..)sumr#rDrrrr^sz0_ProactorDatagramTransport.get_write_buffer_sizecCs|ddSrBrrDrrrrsz _ProactorDatagramTransport.abortcCst|tttfstdt||s&dS|jdurN|d|jfvrNtd|j|jr|jr|jt j krpt d|jd7_dS|j t||f|jdur||dS)Nz,data argument must be bytes-like object (%r)z!Invalid address: must be None or z!socket.sendto() raised exception.r)rPrrrrrr ValueErrorr'rrr rr#r9r%rr)r-rladdrrrrsendtos&     z!_ProactorDatagramTransport.sendtoc Csz|jrWdSd|_|r ||jr2|jrN|jrN|jrH|j|jdWdS|j \}}|jdur||jj |j ||_n|jj j |j ||d|_Wn^ty}z|j|WYd}~nNd}~0ty}z||dWYd}~n d}~00|j|j|dS)N)rz'Fatal write error on datagram transport)r'r%rsr#rr(rr*rGpopleftrtrr rrQr+error_received ExceptionrVryrr)r-rzrlrrUrrrrs2     "z(_ProactorDatagramTransport._loop_writingc Cs|d}zZz|jr*WW|r&|j||dSd|_|dur|}|jrdd}WW|r`|j||dS|jdur|||j}}n|\}}|jrWW|r|j||dS|jdur|jj |j |j |_n|jj |j |j |_WnPt y}z|j|WYd}~nBd}~0tjy.|js*Yn0|jdurJ|j|jW|rx|j||n|rv|j||0dSrB)r'r+Zdatagram_receivedr$rsr(rrrtrur max_sizeZrecvfromrQrrrxryrg)r-rzrlrresrUrrrrgsT$       z(_ProactorDatagramTransport._loop_reading)NNN)N)N)N) r8r_r`rrrr^rrrrgrcrrr3rrs   !rc@seZdZddZddZdS)_ProactorDuplexPipeTransportcCsdS)NFrrDrrrrKsz*_ProactorDuplexPipeTransport.can_write_eofcCstdSrB)NotImplementedErrorrDrrrrNsz&_ProactorDuplexPipeTransport.write_eofN)r8r_r`rrrrrrrFsrcs>eZdZejjZd fdd ZddZddZ dd Z Z S) _ProactorSocketTransportNcs$t||||||t|dSrB)rrrZ _set_nodelayr,r3rrrYsz!_ProactorSocketTransport.__init__cCst||dSrBrrArrrr^sz#_ProactorSocketTransport._set_extracCsdSrrrDrrrrasz&_ProactorSocketTransport.can_write_eofcCs2|js |jrdSd|_|jdur.|jtjdSr)r(r)r%r rZr rrDrrrrds   z"_ProactorSocketTransport.write_eof)NNN) r8r_r`rZ _SendfileModeZ TRY_NATIVEZ_sendfile_compatiblerrrrrcrrr3rrRsrcseZdZfddZd3ddZd4dddddddd Zd5d d Zd6d d Zd7ddZd8ddZ fddZ ddZ ddZ ddZ ddZddZddZd d!Zd"d#Zd$d%Zd9d&d'Zd(d)Zd:d+d,Zd-d.Zd/d0Zd1d2ZZS);rcshttd|jj||_||_d|_i|_ | || t t urdt|jdS)NzUsing proactor: %s)rrr rRr4r8rt _selector_self_reading_future_accept_futuresZset_loop_make_self_pipe threadingcurrent_thread main_threadsignal set_wakeup_fd_csockr:)r-Zproactorr3rrrns  zBaseProactorEventLoop.__init__NcCst||||||SrB)r)r-rr/r0r1r2rrr_make_socket_transport{s z,BaseProactorEventLoop._make_socket_transportF) server_sideserver_hostnamer1r2ssl_handshake_timeoutc Cs0tj||||||| d} t||| ||d| jS)N)rr1r2)r Z SSLProtocolrZ_app_transport) r-Zrawsockr/ sslcontextr0rrr1r2rZ ssl_protocolrrr_make_ssl_transportsz)BaseProactorEventLoop._make_ssl_transportcCst||||||SrB)r)r-rr/rr0r1rrr_make_datagram_transports z.BaseProactorEventLoop._make_datagram_transportcCst|||||SrB)rr-rr/r0r1rrr_make_duplex_pipe_transportsz1BaseProactorEventLoop._make_duplex_pipe_transportcCst|||||SrB)rdrrrr_make_read_pipe_transportsz/BaseProactorEventLoop._make_read_pipe_transportcCst|||||SrB)rrrrr_make_write_pipe_transportsz0BaseProactorEventLoop._make_write_pipe_transportcsj|rtd|rdSttur6td|| |j d|_ d|_ t dS)Nz!Cannot close a running event loopr[)Z is_runningr is_closedrrrrr_stop_accept_futures_close_self_pipertrIrrrDr3rrrIs  zBaseProactorEventLoop.closecs|j||IdHSrB)rtru)r-rnrrr sock_recvszBaseProactorEventLoop.sock_recvcs|j||IdHSrB)rtZ recv_into)r-rZbufrrrsock_recv_intosz$BaseProactorEventLoop.sock_recv_intocs|j||IdHSrB)rtr)r-rrlrrr sock_sendallsz"BaseProactorEventLoop.sock_sendallcs|j||IdHSrB)rtZconnect)r-rrrrr sock_connectsz"BaseProactorEventLoop.sock_connectcs|j|IdHSrB)rtacceptrArrr sock_acceptsz!BaseProactorEventLoop.sock_acceptc s>z |}Wn4ttjfy@}ztdWYd}~n d}~00zt|j}Wnt yntdYn0|rx|n|}|sdSt |d}|rt |||n|} t ||}d} zpt | ||}|dkr| W| dkr| |S|j ||||IdH||7}| |7} qW| dkr:| |n| dkr8| |0dS)Nznot a regular filerl)r:AttributeErrorioUnsupportedOperationrZSendfileNotAvailableErrorosfstatst_sizerQminseekrtsendfile) r-rfileoffsetcountr:errZfsizeZ blocksizeZend_posZ total_sentrrr_sock_sendfile_natives:          z+BaseProactorEventLoop._sock_sendfile_nativecsn|}||IdHz4|j|j|||ddIdHW||rP|Sn||rh|0dS)NF)Zfallback)rhrirZ sock_sendfiler rrm)r-Ztransprrrrmrrr_sendfile_natives" z&BaseProactorEventLoop._sendfile_nativecCsL|jdur|jd|_|jd|_|jd|_|jd8_dS)Nr)rrH_ssockrIr _internal_fdsrDrrrrs    z&BaseProactorEventLoop._close_self_pipecCs:t\|_|_|jd|jd|jd7_dS)NFr)r Z socketpairrrZ setblockingrrDrrrrs  z%BaseProactorEventLoop._make_self_pipec Csz4|dur||j|ur"WdS|j|jd}Wn`tjyJYdSttfy`YnHt y}z| d||dWYd}~nd}~00||_| |j dS)Niz.Error on reading from the event loop self pipe)rNrOr.) rsrrtrurrrxrnrorprSry_loop_self_reading)r-rrUrrrrs$ z(BaseProactorEventLoop._loop_self_readingcCsL|j}|durdSz|dWn&tyF|jrBtjdddYn0dS)Nz3Fail to write a null byte into the self-pipe socketTr)rrrQ_debugr rR)r-Zcsockrrr_write_to_selfs z$BaseProactorEventLoop._write_to_selfdcs(dfdd dS)Nc s,z|durn|\}}jr,td||}durXj||dd|idnj||d|idr|WdSj}Wnt y}zP dkrȈ d|t dnjrtjd dd WYd}~n>d}~0tjyYn0|j <|dS) Nz#%r got a new connection from %r: %rTr)rr1r2rrr[zAccept failed on a socket)rNrOr zAccept failed on socket %rr)rsrr rRrrrrtrrQr:rSr rrIrrxrry)rZconnrr/rUr.protocol_factoryr-r2rrrrrr.0sJ   z2BaseProactorEventLoop._start_serving..loop)N)r*)r-rrrr2Zbacklogrrrr_start_serving,s%z$BaseProactorEventLoop._start_servingcCsdSrBr)r-Z event_listrrr_process_eventsWsz%BaseProactorEventLoop._process_eventscCs&|jD] }|q |jdSrB)rvaluesrHclear)r-futurerrrr[s z*BaseProactorEventLoop._stop_accept_futurescCs6|j|d}|r||j||dSrB)rpopr:rHrt _stop_servingrI)r-rrrrrr`s  z#BaseProactorEventLoop._stop_serving)NNN)N)NNN)NN)NN)NN)N)NNrN)r8r_r`rrrrrrrrIrrrrrrrrrrrrrrrrcrrr3rrlsN            +r)#__all__rrr rarrrrrrrrr r r logr rZ_FlowControlMixinZ BaseTransportrZ ReadTransportrdZWriteTransportr{rZDatagramTransportrZ TransportrrZ BaseEventLooprrrrrsT           n