//usr/lib64/lib64//lib64/lib64//
ۜSec @ s d Z d d l Z d d l Z d d l Z d d l Z d d l Z d d l Z d d l Z d d l Z d d l
Z
d d l Z d d l Z d d l
Z
d d l Z d Z d Z e j e
j e e d d Z d Z d e j f d YZ i Z e
j
d
Z e
j
d
Z d e f d YZ d
e f d YZ d Z d e f d YZ d e j e f d YZ d e f d YZ d e f d YZ! d Z" d Z# d e f d YZ$ d S( s RPC 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.
iNc C s t j | } | S( N( t marshalt loads( t mst co( ( s# /usr/lib64/python2.7/idlelib/rpc.pyt
unpickle_code- s c C s t j | } t | f f S( N( R t dumpsR ( R R ( ( s# /usr/lib64/python2.7/idlelib/rpc.pyt pickle_code2 s i i s 127.0.0.1t RPCServerc B s8 e Z d d Z d Z d Z d Z d Z RS( c C s/ | d k r t } n t j j | | | d S( N( t Nonet
RPCHandlert SocketServert TCPServert __init__( t selft addrt handlerclass( ( s# /usr/lib64/python2.7/idlelib/rpc.pyR G s c C s d S( s@ Override TCPServer method, no bind() phase for connecting entityN( ( R
( ( s# /usr/lib64/python2.7/idlelib/rpc.pyt server_bindL s c C s | j j | j d S( s Override 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( t sockett connectt server_address( R
( ( s# /usr/lib64/python2.7/idlelib/rpc.pyt server_activateP s c C s | j | j f S( s: Override TCPServer method, return already connected socket( R R ( R
( ( s# /usr/lib64/python2.7/idlelib/rpc.pyt get_requestY s c C s y Wn t k
r n t j } | d d d IJ| d IJ| d t j j IJ| d I| IJ| d It | IJt j d | | d IJ| d d IJt j
d
n Xd S( s Override 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.
s
t -i( s Unhandled server exception!s
Thread: %ss Client Address: s Request: t files#
*** Unrecoverable, server exiting!i N( t
SystemExitt syst
__stderr__t threadingt
currentThreadt getNamet reprt tracebackt print_exct ost _exit( R
t requestt client_addresst erf( ( s# /usr/lib64/python2.7/idlelib/rpc.pyt handle_error] s
N( t __name__t
__module__R R R R R R&