
mKc        )   @   s  d  d d d g 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 l Z d d k	 l
 Z
 l Z l Z l Z l Z l Z d d k l Z d d	 k l Z l Z l Z l Z d d
 k l Z l Z y d d k l Z Wn# e j
 o d d k l Z n Xd   Z e i e i e  g  Z  d d d f D] Z! e  e" e# h  e!     qJ[  Z$ d e% f d     YZ& f  h  d  Z' d   Z( d e) f d     YZ* d   Z+ d   Z, d e% f d     YZ- d e% f d     YZ. h e i/ e i0 f d 6e i1 e i2 f d 6Z3 d  e% f d     YZ4 d e5 f d     YZ6 d e% f d      YZ7 d!   Z8 h  d"  Z9 e: e: e: e; d#  Z< d$ e% f d%     YZ= d& e% f d'     YZ> e; d(  Z? d) e7 f d*     YZ@ d+ e7 f d,     YZA d- eA f d.     YZB d/ e7 f d0     YZC d1 e7 f d2     YZD d3 e7 f d4     YZE e9 d5 d6 d7 d8 d9 d: d; d< d= d> d? d@ dA dB dC dD dE dF dG dH dI dJ dK f  ZF dL eF f dM     YZG e9 dN d7 d8 d: d< d@ dO dP dQ dR d d dG dS dT dU d f  ZH e9 dV d< d: d@ d; dA f  ZI e9 dW dX dY dZ d[ d\ d] d^ d_ d` f	  ZJ h da dY 6da d_ 6db d[ 6db d\ 6eJ _K d e4 f dc     YZL eL i dd e i  eL i de e i  eL i df e iM eC  eL i dg e iN eA  eL i dh e iO eA  eL i di e iP eA  eL i dj e iQ eA  eL i dk e iR eB  eL i dl e eJ  eL i dm eS eG  eL i dn eT eH  eL i d& e> eE  eL i do e? eI  eL i d$ e= eD  eL i db dp e@ dq eU eL i da dq eU d S(r   t   BaseManagert   SyncManagert	   BaseProxyt   TokeniN(   t
   format_exc(   t   Processt   current_processt   active_childrent   Poolt   utilt
   connection(   t   AuthenticationString(   t   exitt   Popent   assert_spawningt   ForkingPickler(   t   Finalizet   info(   t   PicklingErrorc         C   s   t  i  |  i |  i   f f S(   N(   t   arrayt   typecodet   tostring(   t   a(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   reduce_array&   s    t   itemst   keyst   valuesc           B   s8   e  Z d  Z d Z d   Z d   Z d   Z d   Z RS(	   s4   
    Type to uniquely indentify a shared object
    t   typeidt   addresst   idc         C   s!   | | | |  _  |  _ |  _ d  S(   N(   R   R   R   (   t   selfR   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   __init__6   s    c         C   s   |  i  |  i |  i f S(   N(   R   R   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   __getstate__9   s    c         C   s   | \ |  _  |  _ |  _ d  S(   N(   R   R   R   (   R   t   state(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   __setstate__<   s    c         C   s   d |  i  |  i |  i f S(   Ns#   Token(typeid=%r, address=%r, id=%r)(   R   R   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   __repr__?   s    (   s   typeids   addresss   id(   t   __name__t
   __module__t   __doc__t	   __slots__R   R    R"   R#   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR   0   s   			c         C   sP   |  i  | | | | f  |  i   \ } } | d j o | St | |   d S(   sL   
    Send a message to manager using connection `c` and return response
    s   #RETURNN(   t   sendt   recvt   convert_to_error(   t   cR   t
   methodnamet   argst   kwdst   kindt   result(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   dispatchG   s
    c         C   s   |  d j o | S|  d j o% t  |  t j p t  t |  S|  d j o) t  |  t j p t  t d |  St d  Sd  S(   Ns   #ERRORs
   #TRACEBACKs   #UNSERIALIZABLEs   Unserializable message: %s
s   Unrecognized message type(   t   typet   strt   AssertionErrort   RemoteErrort
   ValueError(   R/   R0   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR*   Q   s    R5   c           B   s   e  Z d    Z RS(   c         C   s)   d d d d t  |  i d  d d S(   Ns   
t   -iK   i    (   R3   R-   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   __str__^   s    (   R$   R%   R8   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR5   ]   s   c         C   sQ   g  } xD t  |   D]6 } t |  |  } t | d  o | i |  q q W| S(   s4   
    Return a list of names of methods of `obj`
    t   __call__(   t   dirt   getattrt   hasattrt   append(   t   objt   tempt   namet   func(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   all_methodse   s     c         C   s:   g  } t  |   D]" } | d d j o | | q q ~ S(   sP   
    Return a list of names of methods of `obj` which do not start with '_'
    i    t   _(   RB   (   R>   t   _[1]R@   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   public_methodsp   s    t   Serverc        	   B   s   e  Z d  Z d d d d d d d d d	 g	 Z d
   Z d   Z d   Z d   Z d   Z d   Z	 d   Z
 h e	 d 6e
 d 6e d 6Z d   Z d   Z d   Z d   Z d   Z d   Z d   Z d   Z d   Z RS(   sM   
    Server class which runs in a process controlled by a manager object
    t   shutdownt   createt   accept_connectiont   get_methodst
   debug_infot   number_of_objectst   dummyt   increft   decrefc         C   s   t  | t  p t  | |  _ t |  |  _ t | \ } } | d | d d  |  _ |  i i |  _ h d  d f d 6|  _
 h  |  _ t i   |  _ d |  _ d  S(   NR   t   backlogi   i    (    (   t
   isinstancet   bytesR4   t   registryR   t   authkeyt   listener_clientt   listenerR   t   Nonet	   id_to_objt   id_to_refcountt	   threadingt   RLockt   mutext   stop(   R   RS   R   RT   t
   serializert   Listenert   Client(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR      s    		c         C   s   |  t    _ z ym xf y |  i i   } Wn t t f j
 o
 q n Xt i d |  i d | f  } t	 | _
 | i   q Wn t t f j
 o n XWd d |  _ |  i i   Xd S(   s(   
        Run the server forever
        t   targetR-   Ni  (   R   t   _manager_serverRV   t   acceptt   OSErrort   IOErrorRZ   t   Threadt   handle_requestt   Truet   daemont   startt   KeyboardInterruptt
   SystemExitR]   t   close(   R   R+   t   t(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   serve_forever   s    			c         C   s  d } } } yu t i | |  i  t i | |  i  | i   } | \ } } } } | |  i j p t d |  t |  |  } Wn" t	 j
 o d t
   f }	 nI Xy | | | |  } Wn" t	 j
 o d t
   f }	 n Xd | f }	 y | i |	  Wnu t	 j
 oi }
 y | i d t
   f  Wn t	 j
 o n Xt i d |	  t i d |  t i d |
  n X| i   d S(   s)   
        Handle a new connection
        s   %r unrecognizeds
   #TRACEBACKs   #RETURNs   Failure to send message: %rs    ... request was %rs    ... exception was %rN(   RW   R
   t   deliver_challengeRT   t   answer_challengeR)   t   publicR4   R;   t	   ExceptionR   R(   R	   R   Rm   (   R   R+   t   funcnameR0   t   requestt   ignoreR-   R.   RA   t   msgt   e(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRg      s4    c         C   s  t  i d t i   i  | i } | i } |  i } x|  i py$d } } |   } | \ } } }	 }
 | | \ } } } | | j o# t
 d | t |  | f   n t | |  } y | |	 |
   } Wn! t j
 o } d | f } nt X| o | i | d  } | oF |  i | | |  \ } } t | |  i |  } d | | f f } n d | f } Wn t
 j
 o | d j o d t   f } qQy8 |  i | } | |  | | | |	 |
  } d | f } WqQt j
 o d t   f } qQXn[ t j
 o- t  i d t i   i  t i d  n# t j
 o d t   f } n Xy@ y | |  Wn+ t j
 o } | d	 t |  f  n XWq7 t j
 oY } t  i d
 t i   i  t  i d |  t  i d |  | i   t i d  q7 Xq7 Wd S(   sQ   
        Handle requests from the proxies in a particular process/thread
        s$   starting server thread to service %rs+   method %r of %r object is not in exposed=%rs   #ERRORs   #PROXYs   #RETURNs
   #TRACEBACKs$   got EOF -- exiting thread serving %ri    s   #UNSERIALIZABLEs   exception in thread serving %rs    ... message was %rs    ... exception was %ri   N(   R	   t   debugRZ   t   current_threadR@   R)   R(   RX   R]   RW   t   AttributeErrorR2   R;   Rs   t   getRH   R   R   R   t   fallback_mappingt   EOFErrort   sysR   t   reprR   Rm   (   R   t   connR)   R(   RX   R,   R>   Ru   t   identR-   R.   t   exposedt	   gettypeidt   functiont   resRx   Rw   R   t   ridentt   rexposedt   tokent   fallback_funcR0   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   serve_client   sn    				 

			
c         C   s   | S(   N(    (   R   R   R   R>   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   fallback_getvalue  s    c         C   s
   t  |  S(   N(   R3   (   R   R   R   R>   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   fallback_str  s    c         C   s
   t  |  S(   N(   R   (   R   R   R   R>   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   fallback_repr  s    R8   R#   s	   #GETVALUEc         C   s   d  S(   N(    (   R   R+   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRM      s    c         C   s   |  i  i   z g  } |  i i   } | i   xU | D]M } | d j o: | i d | |  i | t |  i | d  d  f  q6 q6 Wd i |  SWd |  i  i	   Xd S(   sO   
        Return some info --- useful to spot problems with refcounting
        i    s     %s:       refcount=%s
    %siK   s   
N(
   R\   t   acquireRX   R   t   sortR=   RY   R3   t   joint   release(   R   R+   R0   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRK   #  s    
 	(c         C   s   t  |  i  d S(   s*   
        Number of shared objects
        i   (   t   lenRX   (   R   R+   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRL   5  s    c         C   s
  z y t  i d  | i d	  t i t i j o) t  i d  t i t _ t i t _ n t  i	 d  x( t
   D] } t  i d  | i   qs Wx( t
   D] } t  i d  | i   q Wt  i	   t  i d  Wn d d k } | i   n XWd t d  Xd S(
   s'   
        Shutdown this process
        s!   manager received shutdown messages   #RETURNs   resetting stdout, stderri    s&   terminating a child process of managers   manager exiting with exitcode 0iN(   s   #RETURNN(   R	   Ry   R(   RW   R   t   stdoutt
   __stdout__t
   __stderr__t   stderrt   _run_finalizersR   t	   terminateR   R   t	   tracebackt	   print_excR   (   R   R+   t   pR   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRG   ;  s.    
 
 
c         O   si  |  i  i   zG|  i | \ } } } } | d j o0 t |  d j o | p t  | d }	 n | | |   }	 | d j o t |	  } n | d j	 o4 t |  t j p t  t	 |  t	 |  } n d t
 |	  }
 t i d | |
  |	 t |  | f |  i |
 <|
 |  i j o d |  i |
 <n |  i | |
  |
 t |  f SWd |  i  i   Xd S(   s>   
        Create a new shared object and return its id
        i   i    s   %xs&   %r callable returned object with id %rN(   R\   R   RS   RW   R   R4   RE   R2   t   dictt   listR   R	   Ry   t   setRX   RY   RN   t   tupleR   (   R   R+   R   R-   R.   t   callableR   t   method_to_typeidt	   proxytypeR>   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRH   [  s(    "c         C   s   t  |  i | i d  S(   sL   
        Return the methods of the shared object indicated by token
        i   (   R   RX   R   (   R   R+   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRJ     s    c         C   s-   | t  i   _ | i d  |  i |  d S(   s=   
        Spawn a new thread to serve this connection
        s   #RETURNN(   s   #RETURNN(   RZ   Rz   R@   R(   RW   R   (   R   R+   R@   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRI     s    c         C   s9   |  i  i   z |  i | c d 7<Wd  |  i  i   Xd  S(   Ni   (   R\   R   RY   R   (   R   R+   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRN     s    c         C   s   |  i  i   zn |  i | d j p t  |  i | c d 8<|  i | d j o( |  i | =|  i | =t i d |  n Wd  |  i  i   Xd  S(   Ni   i    s   disposing of obj with id %r(   R\   R   RY   R4   RX   R	   Ry   R   (   R   R+   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRO     s    (   R$   R%   R&   Rr   R   Ro   Rg   R   R   R   R   R}   RM   RK   RL   RG   RH   RJ   RI   RN   RO   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRF   z   s.   			"	J			
				 	&			t   Statec           B   s#   e  Z d  g Z d Z d Z d Z RS(   t   valuei    i   i   (   R$   R%   R'   t   INITIALt   STARTEDt   SHUTDOWN(    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s   	t   picklet	   xmlrpclibc           B   s   e  Z d  Z h  Z e Z d d d d  Z d   Z d   Z	 d   Z
 d   Z e d    Z d   Z d d	  Z d
   Z d   Z d   Z d   Z e d    Z e d    Z e d d d d e d   Z RS(   s!   
    Base class for managers
    R   c         C   ss   | d  j o t   i } n | |  _ t |  |  _ t   |  _ t i |  i _	 | |  _
 t | \ |  _ |  _ d  S(   N(   RW   R   RT   t   _addressR   t   _authkeyR   t   _stateR   R   t   _serializerRU   t	   _Listenert   _Client(   R   R   RT   R^   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    		c         C   s%   t  |   i |  i |  i |  i f f S(   N(   R2   t   from_addressR   R   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt
   __reduce__  s    c         C   s<   |  i  i t i j p t  t |  i |  i |  i |  i	  S(   sX   
        Return server object with serve_forever() method and address attribute
        (
   R   R   R   R   R4   RF   t	   _registryR   R   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt
   get_server  s    c         C   sN   t  |  i \ } } | |  i d |  i } t | d d  t i |  i _	 d S(   s>   
        Connect manager object to the server process
        RT   RM   N(
   RU   R   R   R   R1   RW   R   R   R   R   (   R   R_   R`   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   connect  s    c      	   C   s8  |  i  i t i j p t  t i d t  \ } } t d t	 |   i
 d |  i |  i |  i |  i | f  |  _ d i d   |  i i D  } t	 |   i d | |  i _ |  i i   | i   | i   |  _ | i   t i |  i  _ t i |  t	 |   i d |  i |  i |  i |  i  |  i f d d |  _ d	 S(
   s@   
        Spawn a server process for this manager object
        t   duplexRa   R-   t   :c         s   s   x |  ] } t  |  Vq Wd  S(   N(   R3   (   t   .0t   i(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pys	   <genexpr>  s   	 R7   t   exitpriorityi    N(   R   R   R   R   R4   R
   t   Pipet   FalseR   R2   t   _run_serverR   R   R   R   t   _processR   t	   _identityR$   R@   Rj   Rm   R)   R   R	   R   t   _finalize_managerR   RG   (   R   t   readert   writerR   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRj     s$    

c         C   sS   |  i  | | | |  } | i | i  | i   t i d | i  | i   d S(   s@   
        Create a server, report its address and run it
        s   manager serving at %rN(   t   _ServerR(   R   Rm   R	   R   Ro   (   t   clsRS   R   RT   R^   R   t   server(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s
    
c      	   O   s   |  i  i t i j p
 t d  |  i |  i d |  i } z) t | d d | f | |  \ } } Wd | i
   Xt | |  i |  | f S(   sP   
        Create a new shared object; return the token and exposed tuple
        s   server not yet startedRT   RH   N(   R   R   R   R   R4   R   R   R   R1   RW   Rm   R   (   R   R   R-   R.   R   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   _create  s     )c         C   s   |  i  i |  d S(   sC   
        Join the manager process (if it has been spawned)
        N(   R   R   (   R   t   timeout(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    c         C   sA   |  i  |  i d |  i } z t | d d  SWd | i   Xd S(   sS   
        Return some info about the servers shared objects and connections
        RT   RK   N(   R   R   R   R1   RW   Rm   (   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   _debug_info!  s    c         C   sA   |  i  |  i d |  i } z t | d d  SWd | i   Xd S(   s5   
        Return the number of shared objects
        RT   RL   N(   R   R   R   R1   RW   Rm   (   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   _number_of_objects+  s    c         C   s   |  S(   N(    (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt	   __enter__5  s    c         C   s   |  i    d  S(   N(   RG   (   R   t   exc_typet   exc_valt   exc_tb(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   __exit__8  s    c         C   s'  |  i    o t i d  y8 | | d | } z t | d d  Wd | i   XWn t j
 o n X|  i d d  |  i    oj t i d  t |  d  oI t i d	  |  i	   |  i d d
  |  i    o t i d  q q q n t
 i | _ y t i | =Wn t j
 o n Xd S(   sQ   
        Shutdown the manager process; will be registered as a finalizer
        s#   sending shutdown message to managerRT   RG   NR   g?s   manager still aliveR   s'   trying to `terminate()` manager processg?s#   manager still alive after terminate(   t   is_aliveR	   R   R1   RW   Rm   Rs   R   R<   R   R   R   R   R   t   _address_to_localt   KeyError(   t   processR   RT   R!   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR   ;  s.    
c         C   s   |  i  S(    (   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   <lambda>[  s    c   
         s,  d |  i  j o |  i i   |  _ n  d j o
 t  n | p t  d d  } | p t  d d  } | oc x` | i   D]N \ } } t |  t j p t	 d |  t |  t j p t	 d |  q Wn | | |  f |  i   <| o/    f d   }	   |	 _
 t |    |	  n d S(   s9   
        Register a typeid with the manager type
        R   t	   _exposed_t   _method_to_typeid_s   %r is not a stringc      	      s   t  i d    |  i   | |  \ } }  | |  i d |  d |  i d | } |  i | i d |  i } t | d  d | i	 f  | S(   Ns)   requesting creation of a shared %r objectt   managerRT   R   RO   (
   R	   Ry   R   R   R   R   R   R1   RW   R   (   R   R-   R.   R   t   expt   proxyR   (   R   R   (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR?   x  s    N(   t   __dict__R   t   copyRW   t	   AutoProxyR;   R   R2   R3   R4   R$   t   setattr(
   R   R   R   R   R   R   t   create_methodt   keyR   R?   (    (   R   R   s.   /usr/lib/python2.6/multiprocessing/managers.pyt   register]  s"    
 !)
	N(   R$   R%   R&   R   RF   R   RW   R   R   R   R   Rj   t   classmethodR   R   R   R   R   R   R   t   staticmethodR   t   propertyR   Rh   R   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR      s(   
					!		
	
		 	t   ProcessLocalSetc           B   s   e  Z d    Z d   Z RS(   c         C   s   t  i |  d    d  S(   Nc         S   s
   |  i    S(    (   t   clear(   R>   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    (   R	   t   register_after_fork(   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    c         C   s   t  |   d f S(   N(    (   R2   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    (   R$   R%   R   R   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s   	c           B   s   e  Z d  Z h  Z e i   Z d d d e d  Z	 d   Z
 d h  d  Z d   Z d   Z e d    Z d   Z d   Z d	   Z d
   Z d   Z RS(   s.   
    A base for proxies of shared objects
    c         C   sC  t  i i   zR t  i i | i d   } | d  j o) t i   t	   f } | t  i | i <n Wd  t  i i
   X| d |  _ | d |  _ | |  _ |  i i |  _ | |  _ | |  _ t | d |  _ | d  j	 o t |  |  _ n3 |  i d  j	 o |  i i |  _ n t   i |  _ | o |  i   n t i |  t  i  d  S(   Ni    i   (   R   t   _mutexR   R   R|   R   RW   R	   t   ForkAwareLocalR   R   t   _tlst   _idsett   _tokenR   t   _idt   _managerR   RU   R   R   R   R   RT   t   _increfR   t   _after_fork(   R   R   R^   R   RT   R   RN   t	   tls_idset(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s,    			c         C   s   t  i d  t   i } t i   i d j o | d t i   i 7} n |  i |  i i d |  i	 } t
 | d  d | f  | |  i _ d  S(   Ns   making connection to managert
   MainThreadt   |RT   RI   (   R	   Ry   R   R@   RZ   Rz   R   R   R   R   R1   RW   R   R
   (   R   R@   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   _connect  s    c         C   s;  y |  i  i } WnB t j
 o6 t i d t i   i  |  i   |  i  i } n X| i	 |  i
 | | | f  | i   \ } } | d j o | S| d j o | \ } } |  i i | i d }	 |	 | |  i d |  i d |  i d | }
 |  i | i d |  i } t | d	 d | i f  |
 St | |   d	 S(
   sW   
        Try to call a method of the referrent and return a copy of the result
        s#   thread %r does not own a connections   #RETURNs   #PROXYiR   RT   R   RO   N(   R   R
   R{   R	   Ry   RZ   Rz   R@   R   R(   R   R)   R   R   R   R   R   R   R   R1   RW   R   R*   (   R   R,   R-   R.   R   R/   R0   R   R   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   _callmethod  s*    	
c         C   s   |  i  d  S(   s9   
        Get a copy of the value of the referent
        s	   #GETVALUE(   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt	   _getvalue  s    c      
   C   s   |  i  |  i i d |  i } t | d  d |  i f  t i d |  i i	  |  i
 i |  i  |  i o
 |  i i } t i |  t i d |  i |  i | |  i |  i
 |  i  f d d |  _ d  S(   NRT   RN   s	   INCREF %rR-   R   i
   (   R   R   R   R   R1   RW   R   R	   Ry   R   R   t   addR   R   R   R   t   _decrefR   t   _close(   R   R   R!   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    c         C   s   | i  |  i  | d  j p | i t i j oq yE t i d |  i  | |  i d | } t	 | d  d |  i f  Wq t
 j
 o } t i d |  q Xn t i d |  i  | o@ t | d  o0 t i d t i   i  | i i   | ` n d  S(   Ns	   DECREF %rRT   RO   s   ... decref failed %ss%   DECREF %r -- manager already shutdownR
   s-   thread %r has no more proxies so closing conn(   t   discardR   RW   R   R   R   R	   Ry   R   R1   Rs   R<   RZ   Rz   R@   R
   Rm   (   R   RT   R!   t   tlst   idsetR   R   Rx   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s     	c         C   sD   d  |  _ y |  i   Wn& t j
 o } t i d |  n Xd  S(   Ns   incref failed: %s(   RW   R   R   Rs   R	   R   (   R   Rx   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s
    	c         C   s   h  } t  i   o |  i | d <n t |  d t  o* |  i | d <t t |  i |  i	 | f f St t
 |   |  i |  i	 | f f Sd  S(   NRT   t   _isautoR   (   R   t   thread_is_spawningR   R;   R   R   t   RebuildProxyR   R   R   R2   (   R   R.   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    c         C   s
   |  i    S(   N(   R   (   R   t   memo(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   __deepcopy__*  s    c         C   s*   d t  |   i |  i i d t |   f S(   Ns   <%s object, typeid %r at %s>s   0x%x(   R2   R$   R   R   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR#   -  s    c         C   s:   y |  i  d  SWn" t j
 o t |   d  d SXd S(   sV   
        Return representation of the referent (or a fall-back if that fails)
        R#   is   ; '__str__()' failed>N(   R   Rs   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR8   1  s    N(    (   R$   R%   R&   R   R	   t   ForkAwareThreadLockR   RW   Rh   R   R   R   R   R   R   R   R   R   R   R#   R8   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s   %								c         C   s   t  t   d d  } | o& | i | i j o | i | i d S| i d t  o t  t   d t  } |  | | d | | Sd S(   s   
    Function used for unpickling proxy objects.

    If possible the shared object is returned, or otherwise a proxy for it.
    Rb   i    RN   t   _inheritingN(	   R;   R   RW   R   RX   R   t   popRh   R   (   RA   R   R^   R.   R   RN   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR   >  s    c      	   B   s   e  |  } y | |  | f SWn e j
 o n Xh  } x  | D] } d | | f | UqA We |  e f |  } | | _ | | |  | f <| S(   sC   
    Return an proxy type whose methods are given by `exposed`
    sL   def %s(self, *args, **kwds):
        return self._callmethod(%r, args, kwds)(   R   R   R2   R   R   (   R@   R   t   _cachet   dict   metht	   ProxyType(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   MakeProxyTypeS  s     	c   
      C   s   t  | d } | d j oC | |  i d | } z t | d d |  f  } Wd | i   Xn | d j o | d j	 o | i } n | d j o t   i } n t d |  i	 |  } | |  | d | d | d | }	 t
 |	 _ |	 S(   s*   
    Return an auto-proxy for `token`
    i   RT   RJ   Ns   AutoProxy[%s]R   RN   (   RU   RW   R   R1   Rm   R   R   RT   R  R   Rh   R   (
   R   R^   R   RT   R   RN   R   R   R  R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR   i  s    		t	   Namespacec           B   s   e  Z d    Z d   Z RS(   c         K   s   |  i  i |  d  S(   N(   R   t   update(   R   R.   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    c         C   su   |  i  i   } g  } x? | D]7 \ } } | i d  p | i d | | f  q q W| i   d t i d |  S(   NRC   s   %s=%rs   Namespace(%s)s   , (   R   R   t
   startswithR=   R   R3   R   (   R   R   R?   R@   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR#     s     
(   R$   R%   R   R#   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s   	t   Valuec           B   s>   e  Z e d   Z d   Z d   Z d   Z e e e  Z RS(   c         C   s   | |  _  | |  _ d  S(   N(   t	   _typecodet   _value(   R   R   R   t   lock(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    	c         C   s   |  i  S(   N(   R  (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR|     s    c         C   s   | |  _  d  S(   N(   R  (   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    c         C   s    d t  |   i |  i |  i f S(   Ns
   %s(%r, %r)(   R2   R$   R  R  (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR#     s    (	   R$   R%   Rh   R   R|   R   R#   R   R   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s
   			c         C   s   t  i  |  |  S(   N(   R   (   R   t   sequenceR  (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   Array  s    t   IteratorProxyc           B   sD   e  Z d Z d   Z d   Z d   Z d   Z d	   Z d
   Z RS(   t   __next__t   nextR(   t   throwRm   c         C   s   |  S(   N(    (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   __iter__  s    c         G   s   |  i  d |  S(   NR  (   R   (   R   R-   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s    c         G   s   |  i  d |  S(   NR  (   R   (   R   R-   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s    c         G   s   |  i  d |  S(   NR(   (   R   (   R   R-   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR(     s    c         G   s   |  i  d |  S(   NR  (   R   (   R   R-   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s    c         G   s   |  i  d |  S(   NRm   (   R   (   R   R-   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyRm     s    (   s   __next__s   nexts   sends   throws   close(	   R$   R%   R   R  R  R  R(   R  Rm   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s   					t   AcquirerProxyc           B   s5   e  Z d Z e d  Z d   Z d   Z d   Z RS(   R   R   c         C   s   |  i  d | f  S(   NR   (   R   (   R   t   blocking(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    c         C   s   |  i  d  S(   NR   (   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    c         C   s   |  i  d  S(   NR   (   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    c         C   s   |  i  d  S(   NR   (   R   (   R   R   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    (   s   acquires   release(   R$   R%   R   Rh   R   R   R   R   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s
   		t   ConditionProxyc           B   s,   e  Z d Z d	 d  Z d   Z d   Z RS(
   R   R   t   waitt   notifyt
   notify_allc         C   s   |  i  d | f  S(   NR  (   R   (   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s    c         C   s   |  i  d  S(   NR  (   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s    c         C   s   |  i  d  S(   NR  (   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s    (   s   acquires   releases   waits   notifys
   notify_allN(   R$   R%   R   RW   R  R  R  (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s   	t
   EventProxyc           B   s5   e  Z d Z d   Z d   Z d   Z d	 d  Z RS(
   t   is_setR   R   R  c         C   s   |  i  d  S(   NR  (   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s    c         C   s   |  i  d  S(   NR   (   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    c         C   s   |  i  d  S(   NR   (   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    c         C   s   |  i  d | f  S(   NR  (   R   (   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s    (   s   is_sets   sets   clears   waitN(   R$   R%   R   R  R   R   RW   R  (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s
   			t   NamespaceProxyc           B   s)   e  Z d Z d   Z d   Z d   Z RS(   t   __getattribute__t   __setattr__t   __delattr__c         C   sD   | d d j o t  i |  |  St  i |  d  } | d | f  S(   Ni    RC   R   R  (   t   objectR  (   R   R   t
   callmethod(    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   __getattr__  s    c         C   sJ   | d d j o t  i |  | |  St  i |  d  } | d | | f  S(   Ni    RC   R   R   (   R"  R   R  (   R   R   R   R#  (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    c         C   sD   | d d j o t  i |  |  St  i |  d  } | d | f  S(   Ni    RC   R   R!  (   R"  R!  R  (   R   R   R#  (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR!    s    (   s   __getattribute__s   __setattr__s   __delattr__(   R$   R%   R   R$  R   R!  (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR    s   		t
   ValueProxyc           B   s/   e  Z d Z d   Z d   Z e e e  Z RS(   R|   R   c         C   s   |  i  d  S(   NR|   (   R   (   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR|     s    c         C   s   |  i  d | f  S(   NR   (   R   (   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s    (   s   gets   set(   R$   R%   R   R|   R   R   R   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR%    s   		t   BaseListProxyt   __add__t   __contains__t   __delitem__t   __delslice__t   __getitem__t   __getslice__t   __len__t   __mul__t   __reversed__t   __rmul__t   __setitem__t   __setslice__R=   t   countt   extendt   indext   insertR  t   removet   reverseR   t   __imul__t	   ListProxyc           B   s   e  Z d    Z d   Z RS(   c         C   s   |  i  d | f  |  S(   NR4  (   R   (   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   __iadd__  s    c         C   s   |  i  d | f  |  S(   NR9  (   R   (   R   R   (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR9    s    (   R$   R%   R;  R9  (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR:    s   	t	   DictProxyR   R   R|   t   has_keyt   popitemt
   setdefaultR	  t
   ArrayProxyt	   PoolProxyt   applyt   apply_asyncRm   t   imapt   imap_unorderedR   t   mapt	   map_asyncR   t   AsyncResultt   Iteratorc           B   s   e  Z d  Z RS(   s(  
    Subclass of `BaseManager` which supports a number of shared object types.

    The types registered are those intended for the synchronization
    of threads, plus `dict`, `list` and `Namespace`.

    The `multiprocessing.Manager()` function creates started instances of
    this class.
    (   R$   R%   R&   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyR     s   	t   Queuet   JoinableQueuet   Eventt   LockR[   t	   Semaphoret   BoundedSemaphoret	   ConditionR   R   R   R  R   R   (V   t   __all__t   osR   t   weakrefRZ   R   RJ  R   R   t   multiprocessingR   R   R   R   R	   R
   t   multiprocessing.processR   t   multiprocessing.forkingR   R   R   R   t   multiprocessing.utilR   R   t   cPickleR   t   ImportErrorR   R   R   RD   R@   R2   R;   t
   view_typesR"  R   R1   R*   Rs   R5   RB   RE   RF   R   R_   R`   t   XmlListenert	   XmlClientRU   R    R   R   R   R   R  RW   Rh   R   R  R  R  R  R  R  R  R  R%  R&  R:  R<  R@  RA  R   R   RL  RM  R[   RN  RO  RP  R   R   R   (    (    (    s.   /usr/lib/python2.6/multiprocessing/managers.pyt   <module>
   s   ."	<
			
 ,

	
		