File "streams.cpython-35.pyc"

Full Path: /home/attunedd/public_html/byp/izo/con7ext_sym404/rintoar.txt/opt/alt/python35/lib64/python3.5/asyncio/__pycache__/streams.cpython-35.pyc
File size: 20.41 KB
MIME-type: text/x-bytecode.python
Charset: 8 bit



Yf^	@sdZdddddddgZdd	lZeed
rOejddgd
dlmZd
dlmZd
dlmZd
dlm	Z	d
dlm
Z
d
dlmZd#Z
GdddeZGdddeZe
d	d	dd	de
ddZe
d	d	dd	de
ddZeed
rze
d	dd	de
ddZe
d	dd	de
ddZGddde	jZGd ddee	jZGd!ddZGd"ddZd	S)$zStream-related things.StreamReaderStreamWriterStreamReaderProtocolopen_connectionstart_serverIncompleteReadErrorLimitOverrunErrorNZAF_UNIXopen_unix_connectionstart_unix_server)
coroutines)compat)events)	protocols)	coroutine)loggercs(eZdZdZfddZS)rz
    Incomplete read error. Attributes:

    - partial: read bytes string before the end of stream was reached
    - expected: total number of expected bytes (or None if unknown)
    cs6tjdt||f||_||_dS)Nz-%d bytes read on a total of %r expected bytes)super__init__lenpartialexpected)selfrr)	__class__4/opt/alt/python35/lib64/python3.5/asyncio/streams.pyr s	zIncompleteReadError.__init__)__name__
__module____qualname____doc__rrr)rrrscs(eZdZdZfddZS)rzReached the buffer limit while looking for a separator.

    Attributes:
    - consumed: total number of to be consumed bytes.
    cstj|||_dS)N)rrconsumed)rmessager!)rrrr-szLimitOverrunError.__init__)rrrr rrr)rrr'slooplimitc	+s|dkrtj}td|d|}t|d||jfdd|||EdH\}}t|||}||fS)aA wrapper for create_connection() returning a (reader, writer) pair.

    The reader returned is a StreamReader instance; the writer is a
    StreamWriter instance.

    The arguments are all the usual arguments to create_connection()
    except protocol_factory; most common are positional host and port,
    with various optional keyword arguments following.

    Additional optional keyword arguments are loop (to set the event loop
    instance to use) and limit (to set the buffer limit passed to the
    StreamReader).

    (If you want to customize the StreamReader and/or
    StreamReaderProtocol classes, just copy the code -- there's
    really nothing special here except some convenience.)
    Nr$r#csS)Nrr)protocolrr<lambda>Ksz!open_connection.<locals>.<lambda>)rget_event_looprrZcreate_connectionr)	hostportr#r$kwdsreader	transport_writerr)r%rr2s)c+sKdkrtjfdd}j||||EdHS)aStart a socket server, call back for each client connected.

    The first parameter, `client_connected_cb`, takes two parameters:
    client_reader, client_writer.  client_reader is a StreamReader
    object, while client_writer is a StreamWriter object.  This
    parameter can either be a plain callback function or a coroutine;
    if it is a coroutine, it will be automatically converted into a
    Task.

    The rest of the arguments are all the usual arguments to
    loop.create_server() except protocol_factory; most common are
    positional host and port, with various optional keyword arguments
    following.  The return value is the same as loop.create_server().

    Additional optional keyword arguments are loop (to set the event loop
    instance to use) and limit (to set the buffer limit passed to the
    StreamReader).

    The return value is the same as loop.create_server(), i.e. a
    Server object which can be used to stop the service.
    Ncs.tdd}t|d}|S)Nr$r#)rr)r+r%)client_connected_cbr$r#rrfactoryks	zstart_server.<locals>.factory)rr'Z
create_server)r/r(r)r#r$r*r0r)r/r$r#rrPsc+s|dkrtj}td|d|}t|d||jfdd||EdH\}}t|||}||fS)z@Similar to `open_connection` but works with UNIX Domain Sockets.Nr$r#csS)Nrr)r%rrr&sz&open_unix_connection.<locals>.<lambda>)rr'rrZcreate_unix_connectionr)pathr#r$r*r+r,r-r.r)r%rr	ws&c+sHdkrtjfdd}j|||EdHS)z=Similar to `start_server` but works with UNIX Domain Sockets.Ncs.tdd}t|d}|S)Nr$r#)rr)r+r%)r/r$r#rrr0s	z"start_unix_server.<locals>.factory)rr'Zcreate_unix_server)r/r1r#r$r*r0r)r/r$r#rr
sc@s[eZdZdZdddZddZddZd	d
ZeddZ	dS)
FlowControlMixina)Reusable flow control logic for StreamWriter.drain().

    This implements the protocol methods pause_writing(),
    resume_reading() and connection_lost().  If the subclass overrides
    these it must call the super methods.

    StreamWriter.drain() must wait for _drain_helper() coroutine.
    NcCsF|dkrtj|_n	||_d|_d|_d|_dS)NF)rr'_loop_paused
_drain_waiter_connection_lost)rr#rrrrs			zFlowControlMixin.__init__cCs<|jstd|_|jjr8tjd|dS)NTz%r pauses writing)r4AssertionErrorr3	get_debugrdebug)rrrr
pause_writings	zFlowControlMixin.pause_writingcCsr|jstd|_|jjr7tjd||j}|dk	rnd|_|jsn|jddS)NFz%r resumes writing)	r4r7r3r8rr9r5done
set_result)rwaiterrrrresume_writings			zFlowControlMixin.resume_writingcCsud|_|jsdS|j}|dkr/dSd|_|jrHdS|dkrd|jdn
|j|dS)NT)r6r4r5r;r<
set_exception)rexcr=rrrconnection_losts				z FlowControlMixin.connection_lostccsn|jrtd|js"dS|j}|dksI|jsIt|jj}||_|EdHdS)NzConnection lost)r6ConnectionResetErrorr4r5	cancelledr7r3
create_future)rr=rrr
_drain_helpers				zFlowControlMixin._drain_helper)
rrrr rr:r>rArrErrrrr2s	r2csdeZdZdZddfddZddZfddZd	d
ZddZS)
ra=Helper class to adapt between Protocol and StreamReader.

    (This is a helper class instead of making StreamReader itself a
    Protocol subclass, because the StreamReader has other potential
    uses, and to prevent the user of the StreamReader to accidentally
    call inappropriate methods of the protocol.)
    Ncs;tjd|||_d|_||_d|_dS)Nr#F)rr_stream_reader_stream_writer_client_connected_cb	_over_ssl)rZ
stream_readerr/r#)rrrrs
			zStreamReaderProtocol.__init__cCs|jj||jddk	|_|jdk	rt|||j|j|_|j|j|j}tj	|r|jj
|dS)NZ
sslcontext)rF
set_transportget_extra_inforIrHrr3rGrZiscoroutineZcreate_task)rr,resrrrconnection_mades	z$StreamReaderProtocol.connection_madecsa|jdk	r;|dkr+|jjn|jj|tj|d|_d|_dS)N)rFfeed_eofr?rrArG)rr@)rrrrAs	z$StreamReaderProtocol.connection_lostcCs|jj|dS)N)rF	feed_data)rdatarrr
data_receivedsz"StreamReaderProtocol.data_receivedcCs|jj|jrdSdS)NFT)rFrNrI)rrrreof_receiveds
	z!StreamReaderProtocol.eof_received)	rrrr rrMrArQrRrr)rrrs
c@seZdZdZddZddZeddZdd	Zd
dZ	dd
Z
ddZddZdddZ
eddZdS)ra'Wraps a Transport.

    This exposes write(), writelines(), [can_]write_eof(),
    get_extra_info() and close().  It adds drain() which returns an
    optional Future on which you can wait for flow control.  It also
    adds a transport property which references the Transport
    directly.
    cCsI||_||_|dks3t|ts3t||_||_dS)N)
_transport	_protocol
isinstancerr7_readerr3)rr,r%r+r#rrrrs
		!	zStreamWriter.__init__cCsM|jjd|jg}|jdk	r<|jd|jddj|S)Nztransport=%rz	reader=%rz<%s> )rrrSrVappendjoin)rinforrr__repr__szStreamWriter.__repr__cCs|jS)N)rS)rrrrr,!szStreamWriter.transportcCs|jj|dS)N)rSwrite)rrPrrrr\%szStreamWriter.writecCs|jj|dS)N)rS
writelines)rrPrrrr](szStreamWriter.writelinescCs
|jjS)N)rS	write_eof)rrrrr^+szStreamWriter.write_eofcCs
|jjS)N)rS
can_write_eof)rrrrr_.szStreamWriter.can_write_eofcCs
|jjS)N)rSclose)rrrrr`1szStreamWriter.closeNcCs|jj||S)N)rSrK)rnamedefaultrrrrK4szStreamWriter.get_extra_infoccsi|jdk	r0|jj}|dk	r0||jdk	rS|jjrSdV|jjEdHdS)z~Flush the write buffer.

        The intended use is to write

          w.write(data)
          yield from w.drain()
        N)rV	exceptionrSZ
is_closingrTrE)rr@rrrdrain7s	zStreamWriter.drain)rrrr rr[propertyr,r\r]r^r_r`rKrrdrrrrr	sc@s0eZdZedddZddZddZdd	Zd
dZdd
Z	ddZ
ddZddZddZ
eddZeddZedddZed'ddZed d!Zejred"d#Zed$d%Zejr,d&d#ZdS)(rNcCs|dkrtd||_|dkr?tj|_n	||_t|_d|_d|_d|_	d|_
d|_dS)NrzLimit cannot be <= 0F)
ValueError_limitrr'r3	bytearray_buffer_eof_waiter
_exceptionrSr4)rr$r#rrrrRs						zStreamReader.__init__cCsdg}|jr,|jdt|j|jrB|jd|jtkre|jd|j|jr|jd|j|jr|jd|j|jr|jd|j|j	r|jdd	d
j
|S)Nrz%d byteseofzl=%dzw=%rze=%rzt=%rZpausedz<%s>rW)rirXrrjrg_DEFAULT_LIMITrkrlrSr4rY)rrZrrrr[es 			
				
zStreamReader.__repr__cCs|jS)N)rl)rrrrrcwszStreamReader.exceptioncCsD||_|j}|dk	r@d|_|js@|j|dS)N)rlrkrCr?)rr@r=rrrr?zs			zStreamReader.set_exceptioncCs;|j}|dk	r7d|_|js7|jddS)z1Wakeup read*() functions waiting for data or EOF.N)rkrCr<)rr=rrr_wakeup_waiters
		zStreamReader._wakeup_waitercCs(|jdkstd||_dS)NzTransport already set)rSr7)rr,rrrrJszStreamReader.set_transportcCs;|jr7t|j|jkr7d|_|jjdS)NF)r4rrirgrSresume_reading)rrrr_maybe_resume_transports!	z$StreamReader._maybe_resume_transportcCsd|_|jdS)NT)rjro)rrrrrNs	zStreamReader.feed_eofcCs|jo|jS)z=Return True if the buffer is empty and 'feed_eof' was called.)rjri)rrrrat_eofszStreamReader.at_eofcCs|jstd|s dS|jj||j|jdk	r|jrt|jd|jkry|jj	Wnt
k
rd|_Yn
Xd|_dS)Nzfeed_data after feed_eofrT)rjr7riextendrorSr4rrgZ
pause_readingNotImplementedError)rrPrrrrOs


zStreamReader.feed_dataccs|jdk	rtd||js5td|jrTd|_|jj|jj|_z|jEdHWdd|_XdS)zpWait until feed_data() or feed_eof() is called.

        If stream was paused, automatically resume it.
        NzH%s() called while another coroutine is already waiting for incoming dataz_wait_for_data after EOFF)	rkRuntimeErrorrjr7r4rSrpr3rD)rZ	func_namerrr_wait_for_datas

		
zStreamReader._wait_for_dataccsd}t|}y|j|EdH}Wntk
rX}z|jSWYdd}~Xntk
r}za|jj||jr|jd|j|=n
|jj|j	t
|jdWYdd}~XnX|S)aRead chunk of data from the stream until newline (b'
') is found.

        On success, return chunk that ends with newline. If only partial
        line can be read due to EOF, return incomplete line without
        terminating newline. When EOF was reached while no bytes read, empty
        bytes object is returned.

        If limit is reached, ValueError will be raised. In that case, if
        newline was found, complete line including newline will be removed
        from internal buffer. Else, internal buffer will be cleared. Limit is
        compared against part of the line without newline.

        If stream was paused, this function will automatically resume it if
        needed.
        s
Nr)r	readuntilrrrri
startswithr!clearrqrfargs)rsepseplenlineerrrreadlines

&zStreamReader.readlines
ccsYt|}|dkr$td|jdk	r<|jd}xt|j}|||kr|jj||}|dkrP|d|}||jkrtd||jrt|j}|jj	t
|d|jdEdHqEW||jkrtd||jd||}|jd||=|jt|S)	aVRead data from the stream until ``separator`` is found.

        On success, the data and separator will be removed from the
        internal buffer (consumed). Returned data will include the
        separator at the end.

        Configured stream limit is used to check result. Limit sets the
        maximal length of data that can be returned, not counting the
        separator.

        If an EOF occurs and the complete separator is still not found,
        an IncompleteReadError exception will be raised, and the internal
        buffer will be reset.  The IncompleteReadError.partial attribute
        may contain the separator partially.

        If the data cannot be read because of over limit, a
        LimitOverrunError exception  will be raised, and the data
        will be left in the internal buffer, so it can be read again.
        rz,Separator should be at least one-byte stringNrz2Separator is not found, and chunk exceed the limitrwz2Separator is found, but chunk is longer than limit)
rrfrlrifindrgrrjbytesryrrvrq)rZ	separatorr|offsetZbuflenZisepchunkrrrrws:			

zStreamReader.readuntilrccs|jdk	r|j|dkr(dS|dkryg}x/|j|jEdH}|s[P|j|q=Wdj|S|jr|jr|jdEdHt|jd|}|jd|=|j	|S)aRead up to `n` bytes from the stream.

        If n is not provided, or set to -1, read until EOF and return all read
        bytes. If the EOF was received and the internal buffer is empty, return
        an empty bytes object.

        If n is zero, return empty bytes object immediately.

        If n is positive, this function try to read `n` bytes, and may return
        less or equal bytes than requested, but at least one byte. If EOF was
        received before any byte is read, this function returns empty byte
        object.

        Returned value is not limited with limit, configured at stream
        creation.

        If stream was paused, this function will automatically resume it if
        needed.
        Nrread)
rlrrgrXrYrirjrvrrq)rnZblocksblockrPrrrrJs$	

zStreamReader.readccs
|dkrtd|jdk	r0|j|dkr@dSx_t|j|kr|jrt|j}|jjt|||jdEdHqCWt|j|krt|j}|jjn)t|jd|}|jd|=|j	|S)aRead exactly `n` bytes.

        Raise an IncompleteReadError if EOF is reached before `n` bytes can be
        read. The IncompleteReadError.partial attribute of the exception will
        contain the partial read bytes.

        if n is zero, return empty bytes object.

        Returned value is not limited with limit, configured at stream
        creation.

        If stream was paused, this function will automatically resume it if
        needed.
        rz*readexactly size can not be less than zeroNrreadexactly)
rfrlrrirjrryrrvrq)rrZ
incompleterPrrrr}s&		

zStreamReader.readexactlycCs|S)Nr)rrrr	__aiter__szStreamReader.__aiter__ccs'|jEdH}|dkr#t|S)Nr)rStopAsyncIteration)rvalrrr	__anext__szStreamReader.__anext__cCs|S)Nr)rrrrrsr)rrrrnrr[rcr?rorJrqrNrrrOrrvrrwrrr
ZPY35rrZPY352rrrrrPs,	 [2*		i)r __all__Zsockethasattrrsrr
rrrlogrrnEOFErrorr	Exceptionrrrr	r
ZProtocolr2rrrrrrr<module>sB				"B3G