%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /usr/local/lib/python3.8/idlelib/__pycache__/
Upload File :
Create Path :
Current File : //usr/local/lib/python3.8/idlelib/__pycache__/rpc.cpython-38.pyc

U

qaTR@sdZddlZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
ddlZddlZddl
Z
ddlZddlZddZddZd*ddZGd	d
d
ejZdZdZGd
dde
jZiZedZedZGdddZGdddZddZGdddZ Gddde
j!eZ"GdddeZ#GdddZ$ddZ%dd Z&Gd!d"d"Z'd#d$Z(e)d%krdd&l*m+Z+e+d'd(d)dS)+aRPC Implementation, originally written for the Python Idle IDE

For security reasons, GvR requested that Idle's Python execution server process
connect to the Idle process, which listens for the connection.  Since Idle has
only one client per server, this was not a limitation.

   +---------------------------------+ +-------------+
   | socketserver.BaseRequestHandler | | SocketIO    |
   +---------------------------------+ +-------------+
                   ^                   | register()  |
                   |                   | unregister()|
                   |                   +-------------+
                   |                      ^  ^
                   |                      |  |
                   | + -------------------+  |
                   | |                       |
   +-------------------------+        +-----------------+
   | RPCHandler              |        | RPCClient       |
   | [attribute of RPCServer]|        |                 |
   +-------------------------+        +-----------------+

The RPCServer handler class is expected to provide register/unregister methods.
RPCHandler inherits the mix-in class SocketIO, which provides these methods.

See the Idle run.main() docstring for further information on how this was
accomplished in Idle.

NcCst|}t|tjst|S)z*Return code object from marshal string ms.)marshalloads
isinstancetypesCodeTypeAssertionError)mscor
'/usr/local/lib/python3.8/idlelib/rpc.py
unpickle_code-s
rcCs$t|tjstt|}t|ffS)zBReturn unpickle function and tuple with marshalled co code object.)rrrrrdumpsr)r	rr
r
rpickle_code3s
rcCs$t}t||}|||S)z.Return pickled (or marshalled) string for obj.)ioBytesIOCodePicklerdumpgetvalue)objprotocolfpr
r
rr
9s

r
c@seZdZejeiejZdS)rN)__name__
__module____qualname__rrrcopyregdispatch_tabler
r
r
rrBsri z	127.0.0.1c@s6eZdZdddZddZddZdd	Zd
dZdS)
	RPCServerNcCs |dkrt}tj|||dSN)
RPCHandlersocketserver	TCPServer__init__)selfaddrZhandlerclassr
r
rr"KszRPCServer.__init__cCsdS)z@Override TCPServer method, no bind() phase for connecting entityNr
r#r
r
rserver_bindPszRPCServer.server_bindcCs|j|jdS)zOverride TCPServer method, connect() instead of listen()

        Due to the reversed connection, self.server_address is actually the
        address of the Idle Client to which we are connecting.

        N)socketconnectserver_addressr%r
r
rserver_activateTszRPCServer.server_activatecCs|j|jfS)z:Override TCPServer method, return already connected socket)r'r)r%r
r
rget_request]szRPCServer.get_requestcCszWntk
rYntj}td|dtd|dtdtj|dtd||dtdt||dtj	|dtd|dtd|dt
d	YnXd
S)zOverride TCPServer method

        Error message goes to __stderr__.  No error message if exiting
        normally or socket raised EOF.  Other exceptions not handled in
        server code will cause os._exit.

        z)
----------------------------------------filezUnhandled server exception!z
Thread: %szClient Address: z	Request: z#
*** Unrecoverable, server exiting!z(----------------------------------------rN)
SystemExitsys
__stderr__print	threadingcurrent_threadnamerepr	traceback	print_excos_exit)r#requestZclient_addresserfr
r
rhandle_erroraszRPCServer.handle_error)N)rrrr"r&r*r+r<r
r
r
rrIs

	rc@seZdZdZd;ddZddZddZd	d
ZddZd
dZ	ddZ
ddZddZddZ
ddZddZddZddZdd Zd!d"Zd#d$Zd%d&Zd'd(Zd)d*Zd+Zd,ZdZd-d.Zd/d0Zd1d2Zd3d4Zd5d6Zd7d8Z d9d:Z!dS)<SocketIOrNcCs@t|_|dk	r||_||_|dkr*t}||_i|_i|_dSr)	r2r3
sockthread	debuggingsockobjecttableobjtable	responsescvars)r#r@rBr?r
r
rr"s
zSocketIO.__init__cCs |j}d|_|dk	r|dSr)r@close)r#r@r
r
rrEszSocketIO.closecCstddS)z!override for specific exit actionrN)r8r9r%r
r
rexithookszSocketIO.exithookcGsN|js
dS|jdttj}|D]}|dt|}q&t|tjddS)N r,)	r?locationstrr2r3r4r1r/r0)r#argssar
r
rdebugszSocketIO.debugcCs||j|<dSr)rB)r#oidobjectr
r
rregisterszSocketIO.registercCs&z|j|=Wntk
r YnXdSr)rBKeyErrorr#rNr
r
r
unregisterszSocketIO.unregisterc
Cs|d|z|\}\}}}}Wntk
r6YdSX||jkrPdd|ffS|j|}|dkrxi}	t||	d|	fS|dkri}
t||
d|
fSt||sdd|ffSt||}zd|d	kr|||}t|trt	|}d|fWS|d
krt
||||ffWdSdd|fWSWntk
r4Ynt
k
rJYn|tk
r`Ynftk
r}
zd
|
fWYSd}
~
XYn8d}t||||ftjdtjtjdYdSXdS)Nz
localcall:)ERRORzBad request formatrTzUnknown object id: %r__methods__OK__attributes__zUnsupported method name: %rCALLQUEUE)QUEUEDNzUnsupported message type: %sCALLEXCzU*** Internal Error: rpc.py:SocketIO.localcall()

 Object: %s 
 Method: %s 
 Args: %s
r,)	EXCEPTIONN)rM	TypeErrorrB_getmethods_getattributeshasattrgetattrrRemoteObject	remoteref
request_queueputr.KeyboardInterruptOSError	Exceptionr1r/r0r6r7)r#seqr:howrN
methodnamerJkwargsrmethods
attributesmethodretexmsgr
r
r	localcallsT









zSocketIO.localcallcCs(|d|||||||}||S)Nzremotecall:asynccall: )rM	asynccallasyncreturnr#rNrkrJrlrir
r
r
remotecallszSocketIO.remotecallcCs(|d|||||||}||S)Nzremotequeue:asyncqueue: )rM
asyncqueuerurvr
r
rremotequeueszSocketIO.remotequeuecCs`d||||ff}|}t|jkr8t}||j|<|d||||||||f|S)NrXz
asynccall:%d:newseqr2r3r>	ConditionrDrM
putmessager#rNrkrJrlr:ricvarr
r
rrts
zSocketIO.asynccallcCs`d||||ff}|}t|jkr8t}||j|<|d||||||||f|S)NrYzasyncqueue:%d:rzr~r
r
rrxs
zSocketIO.asyncqueuecCs6|d||j|dd}|d||||S)Nz#asyncreturn:%d:call getresponse(): 皙?)waitzasyncreturn:%d:response: )rMgetresponsedecoderesponse)r#riresponser
r
rruszSocketIO.asyncreturncCs|\}}|dkr|S|dkr dS|dkr6|ddS|dkrT|d|dS|dkrp|d|t||d	kr|d
||t||dS)NrVrZr\zdecoderesponse: EXCEPTIONEOFzdecoderesponse: EOFrTzdecoderesponse: Internal ERROR:r[zdecoderesponse: Call Exception:)rMdecode_interrupthookRuntimeErrorSystemError)r#rrjwhatr
r
rrs&

zSocketIO.decoderesponsecCstdS)N)EOFErrorr%r
r
rrszSocketIO.decode_interrupthookcCs8z|jdddWn tk
r2|dYdSXdS)zListen on socket until I/O not ready or EOF

        pollresponse() will loop looking for seq number None, which
        never comes, and exit on EOFError.

        Nr)myseqrzmainloop:return)rrrMr%r
r
rmainloops

zSocketIO.mainloopcCs6|||}|dk	r2|\}}|dkr2|||f}|S)NrV)_getresponse_proxify)r#rrrrjrr
r
rr"szSocketIO.getresponsecCs4t|trt||jSt|tr0tt|j|S|Sr)rRemoteProxyRPCProxyrNlistmapr)r#rr
r
rr*s


zSocketIO._proxifycCs|d|t|jkr6|||}|dk	r|Sqn^|j|}|||jkr\|qH|j|}|d||f|j|=|j|=|	|SdS)Nz_getresponse:myseq:z-_getresponse:%s: thread woke up: response: %s)
rMr2r3r>pollresponserDacquirerCrrelease)r#rrrrr
r
rr2s"



zSocketIO._getresponsecCs|jd|_}|S)N)nextseq)r#rir
r
rr{HszSocketIO.newseqc	Cs|d|dzt|}Wn,tjk
rJtdt|tjdYnXt	dt
||}t
|dkrz0tg|jgg\}}}|j
|dt}Wn ttfk
rtdYnX||d}q`dS)Nzputmessage:%d:rzCannot pickle:r,<izsocket no longer exists)rMr
pickle
PicklingErrorr1r5r/r0structpacklenselectr@sendBUFSIZEAttributeErrorr]rg)r#messagerKrwxnr
r
rr}LszSocketIO.putmessagecCs|t|j|jkrt|jggg|\}}}t|dkrFdSz|jt}Wnt	k
rnt
YnXt|dkrt
|j|7_||S)Nr)_stage0rbuffbufneedrr@filenorecvrrgr_stage1)r#rrrrrKr
r
r
pollpacket`s
zSocketIO.pollpacketcCsR|jdkrNt|jdkrN|jdd}|jdd|_td|d|_d|_dS)Nrrr)bufstaterrrunpackr)r#rKr
r
rrps
zSocketIO._stage0cCsP|jdkrLt|j|jkrL|jd|j}|j|jd|_d|_d|_|SdS)Nrrr)rrrr)r#packetr
r
rrwszSocketIO._stage1cCs||}|dkrdSzt|}WnVtjk
rztdtjdtdt|tjdtj	tjdtdtjdYnX|S)Nz-----------------------r,zcannot unpickle packet:)
rrrUnpicklingErrorr1r/r0r5r6print_stack)r#rrrr
r
rpollmessages
zSocketIO.pollmessagec
Cs`ztd}Wntjk
r$Yn X|\}}|d|ff}||z||}|dkr^WdSWn2tk
r~|YdStk
rYdSX|\}}|d}|	d||f|dkr|	d||
||}|	d||f|dkr|||fq|d	krqq||kr |S|j|d}	|	dk	r|	||j
|<|	|	qqdS)
aRHandle messages received on the socket.

        Some messages received may be asynchronous 'call' or 'queue' requests,
        and some may be responses for other threads.

        'call' requests are passed to self.localcall() with the expectation of
        immediate execution, during which time the socket is not serviced.

        'queue' requests are used for tasks (which may block or hang) to be
        processed in a different thread.  These requests are fed into
        request_queue by self.localcall().  Responses to queued requests are
        taken from response_queue and sent across the link with the associated
        sequence numbers.  Messages in the queues are (sequence_number,
        request/response) tuples and code using this module removing messages
        from the request_queue is responsible for returning the correct
        sequence number in the response_queue.

        pollresponse() will loop until a response message with the myseq
        sequence number is received, and will save other responses in
        self.responses and notify the owning thread.

        rrVNzpollresponse:%d:myseq:%s)rXrYzpollresponse:%d:localcall:call:z%pollresponse:%d:localcall:response:%srXrY)response_queuegetqueueEmptyr}rr
handle_EOFrrMrsrDrrCnotifyr)
r#rrZqmsgrirrZresqrjcvr
r
rrsL






zSocketIO.pollresponsecCsV||d|jD]0}|j|}|d|j|<||q|dS)z+action taken upon link being closed by peerr)rNN)EOFhookrMrDrrCrrrF)r#keyrr
r
rrs




zSocketIO.handle_EOFcCsdS)zBClasses using rpc client/server can override to augment EOF actionNr
r%r
r
rrszSocketIO.EOFhook)NN)"rrrrr"rErFrMrPrSrsrwryrtrxrurrrrrrr{r}rrrrrrrrrrr
r
r
rr=s>
.


I
r=c@seZdZdS)rbN)rrrr
r
r
rrbsrbcCst|}|t|<t|Sr)idrAr)rrNr
r
rrcsrcc@seZdZddZdS)rcCs
||_dSr)rNrRr
r
rr"szRemoteProxy.__init__N)rrrr"r
r
r
rrsrc@s,eZdZdZdZddZddZddZd	S)
rFz#ScCs(||_t||tj||||dSr)Zcurrent_handlerr=r"r BaseRequestHandler)r#r@r$Zsvrr
r
rr"szRPCHandler.__init__cCs|dS)z(handle() method required by socketserverN)rr%r
r
rhandleszRPCHandler.handlecCs
t||SrrrRr
r
rget_remote_proxyszRPCHandler.get_remote_proxyN)rrrr?rHr"rrr
r
r
rrs
rc@s:eZdZdZdZdZejejfddZ	ddZ
dd	Zd
S)	RPCClientFz#CrcCs*t|||_|j||jddSNr)r'listening_sockbindlisten)r#addressfamilytyper
r
rr"szRPCClient.__init__cCsV|j\}}|jr$td|tjd|dtkr>t||ntd|tjdt	dS)Nz****** Connection request from r,rz** Invalid host: )
racceptr?r1r/r0	LOCALHOSTr=r"rg)r#Zworking_sockrr
r
rrszRPCClient.acceptcCs
t||SrrrRr
r
rr"szRPCClient.get_remote_proxyN)rrrr?rHrr'AF_INETSOCK_STREAMr"rrr
r
r
rrs
rc@s4eZdZdZdZddZddZddZdd	ZdS)
rNcCs||_||_dSr)sockiorN)r#rrNr
r
rr"+szRPCProxy.__init__cCsp|jdkr||j|r.t|j|j|S|jdkr@|||jkrd|j|jd|fi}|St	|dS)N__getattribute__)
_RPCProxy__methods_RPCProxy__getmethodsrMethodProxyrrN_RPCProxy__attributes_RPCProxy__getattributesrwr)r#r4valuer
r
r__getattr__/s


zRPCProxy.__getattr__cCs|j|jddi|_dS)NrWr
)rrwrNrr%r
r
rZ__getattributes=s

zRPCProxy.__getattributescCs|j|jddi|_dS)NrUr
)rrwrNrr%r
r
rZ__getmethodsAs

zRPCProxy.__getmethods)	rrrrrr"rrrr
r
r
rr&srcCsLt|D]}t||}t|rd||<qt|trH|jD]}t||q8dSr)dirracallablerr	__bases__r^)rrmr4attrsuperr
r
rr^Es



r^cCs,t|D]}t||}t|sd||<qdSr)rrar)rrnr4rr
r
rr_Ps
r_c@seZdZddZddZdS)rcCs||_||_||_dSr)rrNr4)r#rrNr4r
r
rr"YszMethodProxy.__init__cOs|j|j|j||}|Sr)rrwrNr4)r#rJrlrr
r
r__call__^szMethodProxy.__call__N)rrrr"rr
r
r
rrWsrcCs~|dkrdSdt_t|}ztj|Wn<tk
rfd}||d}||d}tj|YnXtjd|t_dS)z9Override standard display hook to use non-locale encodingNasciibackslashreplacestrict
)	builtins_r5r/stdoutwriteUnicodeEncodeErrorencodedecode)rtextencodingbytesr
r
rdisplayhookfsr__main__)mainzidlelib.idle_test.test_rpcr)	verbosity)N),__doc__rrrrr8rrrr'r rr/r2r6rrrr
Picklerrrrr!rrAQueuerdrr=rbrcrrrrrr^r_rrrZunittestrr
r
r
r<module>sR
	2

k


Zerion Mini Shell 1.0