a XC?h}@sXdZdZddlZddlZddlZddlZddlZddlZddlZddl m Z ddl m Z ddl m Z ddl m Z dd l mZdd l mZdd l mZdd l mZdd lmZddZGdddejejZGdddeejZGdddeejZGdddeZGdddeejZGdddeeejZ GdddeeejZ!Gddde j"Z#dS) zEvent loop using a proactor and related classes. A proactor is a "notify-on-completion" multiplexer. Currently a proactor is only implemented on Windows with IOCP. )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____doc__rr?rr!rErFrIwarningswarnrLrVrTrGr^ __classcell__rrr3rr.s  rcsTeZdZdZdfdd ZddZddZd d Zd d Zd dZ dddZ Z S)_ProactorReadPipeTransportzTransport for read pipes.Ncs:d|_d|_t|||||||j|jd|_dS)NTF) _pending_data_pausedrrrr* _loop_readingr,r3rrrs z#_ProactorReadPipeTransport.__init__cCs|j o|j SrB)rgr(rDrrr is_readingsz%_ProactorReadPipeTransport.is_readingcCs0|js |jrdSd|_|jr,td|dS)NTz%r pauses reading)r(rgrrr 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(rgr$rr*rhrf_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.) rgrfrrrPr+rZBufferedProtocolZ_feed_data_to_buffered_protororprqrVZ data_received)r-rmrUrrrrks"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(rkrgr _proactorrecvr ConnectionAbortedErrorrVrr rRConnectionResetErrorrTrQrCancelledErroradd_done_callbackrh)r-futrmrUrrrrhsP       z(_ProactorReadPipeTransport._loop_reading)NNN)N) r8r_r`rarrirjrnrrrkrhrdrrr3rres recs^eZdZdZdZfddZddZddd Zd d Zd d Z ddZ ddZ ddZ Z S)_ProactorBaseWritePipeTransportzTransport for write pipes.Tcstj|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)rm)rPbytes bytearray memoryview TypeErrortyper8r) RuntimeErrorrWr'r!LOG_THRESHOLD_FOR_CONNLOST_WRITESr rr% _loop_writingr#_maybe_pause_protocolextendrlrrrwriteKs0       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&rtr#rr*rGr)r rZr SHUT_WR_maybe_resume_protocolrusendrXr;rzrrrWrYrxrTrQrV)r-frmrUrrrrqs8    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`raZ_start_tls_compatiblerrrrrrrrrdrrr3rr|As & )r|cs$eZdZfddZddZZS)_ProactorWritePipeTransportcs8tj|i||jj|jd|_|j|jdS)N) rrrrurvr r$rz _pipe_closedr}r3rrrsz$_ProactorWritePipeTransport.__init__cCs@|r dS|jrdSd|_|jdur4|tn|dSrB)Z cancelledr(r$r%rTBrokenPipeErrorrI)r-r{rrrrs z(_ProactorWritePipeTransport._pipe_closed)r8r_r`rrrdrrr3rrs rcsXeZdZdZdfdd ZddZddZd d Zdd d Zdd dZ dddZ Z S)_ProactorDatagramTransportiNcs>||_d|_tj|||||dt|_|j|j dS)N)r0r1) _addressrWrr collectionsdequer#rr*rh)r-r.rr/addressr0r1r3rrrs  z#_ProactorDatagramTransport.__init__cCst||dSrBrrArrrrsz%_ProactorDatagramTransport._set_extracCstdd|jDS)Ncss|]\}}t|VqdSrB)r;).0rm_rrr rszC_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-rmaddrrrrsendtos&     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%rtr#rr(rr*rGpopleftrurr rrQr+error_received ExceptionrVrzrr)r-r{rmrrUrrrrs2     "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$rtr(rrrurvr max_sizeZrecvfromrQrrryrzrh)r-r{rmrresrUrrrrhsT$       z(_ProactorDatagramTransport._loop_reading)NNN)N)N)N) r8r_r`rrrr^rrrrhrdrrr3rrs   !rc@s eZdZdZddZddZdS)_ProactorDuplexPipeTransportzTransport for duplex pipes.cCsdS)NFrrDrrrrKsz*_ProactorDuplexPipeTransport.can_write_eofcCstdSrB)NotImplementedErrorrDrrrrNsz&_ProactorDuplexPipeTransport.write_eofN)r8r_r`rarrrrrrrFsrcsBeZdZdZejjZd fdd ZddZ ddZ d d Z Z S) _ProactorSocketTransportz Transport for connected sockets.Ncs$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`rarZ _SendfileModeZ TRY_NATIVEZ_sendfile_compatiblerrrrrdrrr3rrRsrcseZdZfddZd3ddZd4dddddddd 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 rRr4r8ru _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)rerrrr_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_piperurIrrrDr3rrrIs  zBaseProactorEventLoop.closecs|j||IdHSrB)rurv)r-rnrrr sock_recvszBaseProactorEventLoop.sock_recvcs|j||IdHSrB)ruZ recv_into)r-rZbufrrrsock_recv_intosz$BaseProactorEventLoop.sock_recv_intocs|j||IdHSrB)rur)r-rrmrrr sock_sendallsz"BaseProactorEventLoop.sock_sendallcs|j||IdHSrB)ruZconnect)r-rrrrr sock_connectsz"BaseProactorEventLoop.sock_connectcs|j|IdHSrB)ruacceptrArrr 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_sizerQminseekrusendfile) 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)rirjrZ sock_sendfiler rrn)r-Ztransprrrrnrrr_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.) rtrrurvrrryrorprqrSrz_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)rtrr rRrrrrurrQr:rSr rrIrryrrz)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:rHru _stop_servingrI)r-rrrrrr`s  z#BaseProactorEventLoop._stop_serving)NNN)N)NNN)NN)NN)NN)N)NNrN)r8r_r`rrrrrrrrIrrrrrrrrrrrrrrrrdrrr3rrlsN            +r)$ra__all__rrr rbrrrrrrrrr r r logr rZ_FlowControlMixinZ BaseTransportrZ ReadTransportreZWriteTransportr|rZDatagramTransportrZ TransportrrZ BaseEventLooprrrrrsV           n