Lc @ s d Z d d k Z d d k Z d d k Z d d k Z d d k Z d d k Z d d k Z d d k Z d d k Z d d k Z d d k Z d d k Z d d k Z d Z d Z e i e i e e d d Z d Z d e i f d YZ h Z e i d Z e i d Z d e f d YZ d e f d YZ d Z d e f d YZ d e i 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 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 i | } t | t i p t | S( N( t marshalt loadst isinstancet typest CodeTypet AssertionError( t mst co( ( s# /usr/lib64/python2.6/idlelib/rpc.pyt unpickle_code- s c C s6 t | t i p t t i | } t | f f S( N( R R R R R t dumpsR ( R R ( ( s# /usr/lib64/python2.6/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 s1 | d j o t } n t i i | | | d S( N( t Nonet RPCHandlert SocketServert TCPServert __init__( t selft addrt handlerclass( ( s# /usr/lib64/python2.6/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.6/idlelib/rpc.pyt server_bindL s c C s | i i | i 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.6/idlelib/rpc.pyt server_activateP s c C s | i | i f S( s: Override TCPServer method, return already connected socket( R R ( R ( ( s# /usr/lib64/python2.6/idlelib/rpc.pyt get_requestY s c C s y Wn t j o n t i } | d d d IJ| d IJ| d t i i IJ| d I| IJ| d It | IJt i d | | d IJ| d d IJt i 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.6/idlelib/rpc.pyt handle_error] s N( t __name__t __module__R R R R R R* ( ( ( s# /usr/lib64/python2.6/idlelib/rpc.pyR E s i t SocketIOc B s e Z d Z d d d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z d Z! RS( i c C sh t i | _ | d j o | | _ n | | _ | d j o t } n | | _ h | _ h | _ d S( N( R R t sockthreadR t debuggingt sockt objecttablet objtablet responsest cvars( R R0 R2 R/ ( ( s# /usr/lib64/python2.6/idlelib/rpc.pyR s c C s1 | i } d | _ | d j o | i n d S( N( R0 R t close( R R0 ( ( s# /usr/lib64/python2.6/idlelib/rpc.pyR5 s c C s t i d S( s! override for specific exit actionN( R% R&