File "rpc.cpython-34.pyc"

Full Path: /home/attunedd/public_html/byp/izo/con7ext_sym404/rintoar.txt/opt/alt/python34/lib64/python3.4/idlelib/__pycache__/rpc.cpython-34.pyc
File size: 20.51 KB
MIME-type: text/x-bytecode.python
Charset: 8 bit


e f.Q@sdZddlZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
ddlZddlZddl
Z
ddlZddlZddZddZdddZGd	d
d
ejZddZd
ZGdddejZiZe
jdZe
jdZGdddeZGdddeZddZ GdddeZ!Gdddej"eZ#GdddeZ$GdddeZ%ddZ&d d!Z'Gd"d#d#eZ(d$d%Z)dS)&aRPC Implemention, 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.

NcCs+tj|}t|tjs't|S)N)marshalloads
isinstancetypesCodeTypeAssertionError)mscor
0/opt/alt/python34/lib64/python3.4/idlelib/rpc.py
unpickle_code/srcCs4t|tjsttj|}t|ffS)N)rrrrrdumpsr)r	rr
r
rpickle_code4srcCs2tj}t||}|j||jS)N)ioBytesIOCodePicklerdumpgetvalue)objZprotocolfpr
r
rr
9s
r
c@s0eZdZieej6ZejejdS)rN)	__name__
__module____qualname__rrrdispatch_tableupdatecopyregr
r
r
rr?sriz	127.0.0.1c@sOeZdZdddZddZddZdd	Zd
dZdS)	RPCServerNcCs/|dkrt}ntjj|||dS)N)
RPCHandlersocketserver	TCPServer__init__)selfaddrZhandlerclassr
r
rr"Hs	zRPCServer.__init__cCsdS)z@Override TCPServer method, no bind() phase for connecting entityNr
)r#r
r
rserver_bindMszRPCServer.server_bindcCs|jj|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)socketZconnectserver_address)r#r
r
rserver_activateQszRPCServer.server_activatecCs|j|jfS)z:Override TCPServer method, return already connected socket)r&r')r#r
r
rget_requestZszRPCServer.get_requestcCsyWntk
rYntj}tdddd|tdd|tdtjjd|td|d|tdt|d|tj	d|td	d|tddd|t
jd
YnXdS)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.

        
-(filezUnhandled server exception!z
Thread: %szClient Address: z	Request: z#
*** Unrecoverable, server exiting!rN)
SystemExitsys
__stderr__print	threadingcurrent_threadnamerepr	traceback	print_excos_exit)r#requestZclient_addressZerfr
r
rhandle_error^s
	zRPCServer.handle_error)rrrr"r%r(r)r;r
r
r
rrFs
	rc@sreZdZdZddddZddZddZd	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);SocketIOrNcCsdtj|_|dk	r'||_n||_|dkrEt}n||_i|_i|_dS)N)	r2r3
sockthread	debuggingsockobjecttableobjtable	responsescvars)r#r?rAr>r
r
rr"s				zSocketIO.__init__cCs/|j}d|_|dk	r+|jndS)N)r?close)r#r?r
r
rrDs		zSocketIO.closecCstjddS)z!override for specific exit actionrN)r8r9)r#r
r
rexithookszSocketIO.exithookcGsi|js
dS|jdttjj}x"|D]}|dt|}q4Wt|dtjdS)N r-)	r>locationstrr2r3r4r1r/r0)r#argssar
r
rdebugs	 
zSocketIO.debugcCs||j|<dS)N)rA)r#oidobjectr
r
rregisterszSocketIO.registercCs'y|j|=Wntk
r"YnXdS)N)rAKeyError)r#rMr
r
r
unregisters
zSocketIO.unregistercCs*|jd|y|\}\}}}}Wntk
rDdSYnX||jkredd|ffS|j|}|dkri}	t||	d|	fS|dkri}
t||
d|
fSt||sdd|ffSt||}y|d	kr9|||}t|tr/t	|}nd|fS|d
kret
j||||ffdSdd|fSWntk
rYnt
k
rYntk
rYnstk
r}
zd
|
fSWYdd}
~
XnEd}t||||fdtjtjdtjdSYnXdS)Nz
localcall:ERRORBad request formatzUnknown object id: %r__methods__OK__attributes__zUnsupported method name: %rCALLQUEUEQUEUEDzUnsupported message type: %sCALLEXCzU*** Internal Error: rpc.py:SocketIO.localcall()

 Object: %s 
 Method: %s 
 Args: %s
r-	EXCEPTION)rRrS)rYN)r[N)rL	TypeErrorrA_getmethods_getattributeshasattrgetattrrRemoteObject	remoteref
request_queueZputr.KeyboardInterruptOSError	Exceptionr1r/r0r6r7)r#seqr:howrM
methodnamerIkwargsrmethods
attributesmethodZretZexmsgr
r
r	localcallsT
	








 zSocketIO.localcallcCs8|jd|||j||||}|j|S)Nzremotecall:asynccall: )rL	asynccallasyncreturn)r#rMrirIrjrgr
r
r
remotecallszSocketIO.remotecallcCs8|jd|||j||||}|j|S)Nzremotequeue:asyncqueue: )rL
asyncqueuerq)r#rMrirIrjrgr
r
rremotequeueszSocketIO.remotequeuecCsd||||ff}|j}tj|jkrUtj}||j|<n|jd||||||j||f|S)NrWz
asynccall:%d:)newseqr2r3r=	ConditionrCrL
putmessage)r#rMrirIrjr:rgcvarr
r
rrpszSocketIO.asynccallcCsd||||ff}|j}tj|jkrUtj}||j|<n|jd||||||j||f|S)NrXzasyncqueue:%d:)rur2r3r=rvrCrLrw)r#rMrirIrjr:rgrxr
r
rrsszSocketIO.asyncqueuecCsG|jd||j|dd}|jd|||j|S)Nz#asyncreturn:%d:call getresponse(): waitg?zasyncreturn:%d:response: )rLgetresponsedecoderesponse)r#rgresponser
r
rrqszSocketIO.asyncreturncCs|\}}|dkr|S|dkr,dS|dkrI|jddS|dkrp|jd|jdS|dkr|jd|t|n|d	kr|jd
||nt||dS)NrUrYr[zdecoderesponse: EXCEPTIONEOFzdecoderesponse: EOFrRzdecoderesponse: Internal ERROR:rZzdecoderesponse: Call Exception:)rLdecode_interrupthookRuntimeErrorSystemError)r#r|rhwhatr
r
rr{s&


	zSocketIO.decoderesponsecCs
tdS)N)EOFError)r#r
r
rr~szSocketIO.decode_interrupthookcCsDy|jddddWn#tk
r?|jddSYnXdS)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.

        myseqNryg?zmainloop:return)rzrrL)r#r
r
rmainloops


zSocketIO.mainloopcCsU|j||}|dk	rQ|\}}|dkrQ||j|f}qQn|S)NrU)_getresponse_proxify)r#rryr|rhrr
r
rrzszSocketIO.getresponsecCsHt|trt||jSt|trDtt|j|S|S)N)rRemoteProxyRPCProxyrMlistmapr)r#rr
r
rr's
zSocketIO._proxifycCs|jd|tj|jkrQx|j||}|dk	r(|Sq(Wn}|j|}|jx||jkr|jqkW|j|}|jd||f|j|=|j|=|j	|SdS)Nz_getresponse:myseq:z-_getresponse:%s: thread woke up: response: %s)
rLr2r3r=pollresponserCacquirerBryrelease)r#rryr|rxr
r
rr/s"


	


zSocketIO._getresponsecCs|jd|_}|S)N)nextseq)r#rgr
r
rruEszSocketIO.newseqcCs|jd|dyt|}Wn4tjk
r[tdt|dtjYnXtj	dt
||}xt
|dkryDtjg|jgg\}}}|jj
|dt}Wn$ttfk
rtdYnX||d}q{WdS)Nzputmessage:%d:rzCannot pickle:r-z<izsocket no longer exists)rLr
pickleZ
PicklingErrorr1r5r/r0structZpacklenselectr?sendBUFSIZEAttributeErrorr\re)r#messagerJrwxnr
r
rrwIs$ zSocketIO.putmessagecCs|jt|j|jkrtj|jjggg|\}}}t|dkredSy|jjt}Wnt	k
rt
YnXt|dkrt
n|j|7_|jn|jS)Nr)_stage0rbuffbufneedrr?filenoZrecvrrer_stage1)r#ryrrrrJr
r
r
pollpacket]s
-
	
zSocketIO.pollpacketcCsv|jdkrrt|jdkrr|jdd}|jdd|_tjd|d|_d|_ndS)Nrrz<i)bufstaterrrZunpackr)r#rJr
r
rrms
$zSocketIO._stage0cCsp|jdkrlt|j|jkrl|jd|j}|j|jd|_d|_d|_|SdS)Nrrr)rrrr)r#packetr
r
rrts'		zSocketIO._stage1cCs|j|}|dkrdSytj|}Wnmtjk
rtddtjtdt|dtjtj	dtjtddtjYnX|S)Nz-----------------------r-zcannot unpickle packet:)
rrrZUnpicklingErrorr1r/r0r5r6print_stack)r#ryrrr
r
rpollmessage|szSocketIO.pollmessagec
Csxytjd}Wntjk
r-Yn,X|\}}|d|ff}|j|y#|j|}|dkr{dSWn5tk
r|jdSYntk
rdSYnX|\}}|d}|j	d||f|d	kr^|j	d||j
||}|j	d||f|dkrI|j||fq|dkrqqq||krn|S|jj|d}	|	dk	r|	j||j
|<|	j|	jqqqWdS)
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.

        rrUNzpollresponse:%d:myseq:%srWrXzpollresponse:%d:localcall:call:z%pollresponse:%d:localcall:response:%s)zCALLzQUEUE)response_queuegetqueueZEmptyrwrr
handle_EOFrrLrorCrrBnotifyr)
r#rryZqmsgrgr|rZresqrhcvr
r
rrsN



	
	



zSocketIO.pollresponsecCsq|j|jdxI|jD]>}|j|}|jd|j|<|j|jq!W|jdS)z+action taken upon link being closed by peerrr}N)zEOFN)EOFhookrLrCrrBrrrE)r#keyrr
r
rrs





zSocketIO.handle_EOFcCsdS)zBClasses using rpc client/server can override to augment EOF actionNr
)r#r
r
rrszSocketIO.EOFhook)"rrrrr"rDrErLrOrQrorrrtrprsrqr{r~rrzrrrurwrrrrrrrrrrr
r
r
rr<}s>.


I
r<c@seZdZdS)raN)rrrr
r
r
rrasracCs t|}|t|<t|S)N)idr@r)rrMr
r
rrbs
rbc@seZdZddZdS)rcCs
||_dS)N)rM)r#rMr
r
rr"szRemoteProxy.__init__N)rrrr"r
r
r
rrsrc@s@eZdZdZdZddZddZddZd	S)
rFz#ScCs6||_tj||tjj||||dS)N)Zcurrent_handlerr<r"r BaseRequestHandler)r#r?r$Zsvrr
r
rr"s	zRPCHandler.__init__cCs|jdS)z(handle() method required by socketserverN)r)r#r
r
rhandleszRPCHandler.handlecCs
t||S)N)r)r#rMr
r
rget_remote_proxyszRPCHandler.get_remote_proxyN)rrrr>rGr"rrr
r
r
rrs
rc@sReZdZdZdZdZejejddZ	ddZ
dd	Zd
S)	RPCClientFz#CrcCs9tj|||_|jj||jjddS)Nr)r&listening_sockZbindZlisten)r#addressZfamilytyper
r
rr"szRPCClient.__init__cCsz|jj\}}|jr7td|dtjn|dtkrZtj||ntd|dtjt	dS)Nz****** Connection request from r-rz** Invalid host: )
racceptr>r1r/r0	LOCALHOSTr<r"re)r#Zworking_sockrr
r
rrs	zRPCClient.acceptcCs
t||S)N)r)r#rMr
r
rrszRPCClient.get_remote_proxyN)rrrr>rGrr&ZAF_INETZSOCK_STREAMr"rrr
r
r
rrs
rc@sLeZdZdZdZddZddZddZdd	ZdS)
rNcCs||_||_dS)N)sockiorM)r#rrMr
r
rr"#s	zRPCProxy.__init__cCs|jdkr|jn|jj|rDt|j|j|S|jdkr`|jn||jkr|jj|jd|fi}|St	|dS)N__getattribute__)
_RPCProxy__methods_RPCProxy__getmethodsrMethodProxyrrM_RPCProxy__attributes_RPCProxy__getattributesrrr)r#r4valuer
r
r__getattr__'s

zRPCProxy.__getattr__cCs%|jj|jdfi|_dS)NrV)rrrrMr)r#r
r
rZ__getattributes5szRPCProxy.__getattributescCs%|jj|jdfi|_dS)NrT)rrrrMr)r#r
r
rZ__getmethods9szRPCProxy.__getmethods)	rrrrrr"rrrr
r
r
rrsrcCsvx<t|D].}t||}t|r
d||<q
q
Wt|trrx!|jD]}t||qXWndS)Nr)dirr`callablerr	__bases__r])rrkr4attrsuperr
r
rr]=sr]cCsCx<t|D].}t||}t|s
d||<q
q
WdS)Nr)rr`r)rrlr4rr
r
rr^Hsr^c@s(eZdZddZddZdS)rcCs||_||_||_dS)N)rrMr4)r#rrMr4r
r
rr"Ps		zMethodProxy.__init__cOs%|jj|j|j||}|S)N)rrrrMr4)r#rIrjrr
r
r__call__Us!zMethodProxy.__call__N)rrrr"rr
r
r
rrNsrcCs|dkrdSdt_t|}ytjj|WnLtk
rd}|j|d}|j|d}tjj|YnXtjjd|t_dS)z9Override standard display hook to use non-locale encodingNasciibackslashreplacestrictr*)	builtins_r5r/stdoutwriteUnicodeEncodeErrorencodedecode)rtextencodingbytesr
r
rdisplayhook]s	
r)*__doc__r/r8rr&rr rrr2rr6rrrrrrr
ZPicklerrrrr!rr@ZQueuercrrNr<rarbrrrrrr]r^rrr
r
r
r<module>sJ
2j