ó
H`¾Tc           @   s  d  Z  d d l m Z d d l m Z m Z m Z m Z m	 Z	 d d l m
 Z
 m Z m Z d d l m Z d d l m Z d d l Z d	 Z d
 „  Z e g Z d e f d „  ƒ  YZ e ƒ  e _ Z e e _ d e f d „  ƒ  YZ d e f d „  ƒ  YZ d „  Z d „  Z d „  Z d S(   sž  Extensible class instrumentation.

The :mod:`sqlalchemy.ext.instrumentation` package provides for alternate
systems of class instrumentation within the ORM.  Class instrumentation
refers to how the ORM places attributes on the class which maintain
data and track changes to that data, as well as event hooks installed
on the class.

.. note::
    The extension package is provided for the benefit of integration
    with other object management packages, which already perform
    their own instrumentation.  It is not intended for general use.

For examples of how the instrumentation extension is used,
see the example :ref:`examples_instrumentation`.

.. versionchanged:: 0.8
   The :mod:`sqlalchemy.orm.instrumentation` was split out so
   that all functionality having to do with non-standard
   instrumentation was moved out to :mod:`sqlalchemy.ext.instrumentation`.
   When imported, the module installs itself within
   :mod:`sqlalchemy.orm.instrumentation` so that it
   takes effect, including recognition of
   ``__sa_instrumentation_manager__`` on mapped classes, as
   well :data:`.instrumentation_finders`
   being used to determine class instrumentation resolution.

i   (   t   instrumentation(   t   ClassManagert   InstrumentationFactoryt   _default_state_gettert   _default_dict_gettert   _default_manager_getter(   t
   attributest   collectionst   base(   t   util(   t   exciÿÿÿÿNt   __sa_instrumentation_manager__c         C   s   t  |  t d ƒ S(   s;   Find user-specified instrumentation management for a class.N(   t   getattrt   INSTRUMENTATION_MANAGERt   None(   t   cls(    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt%   find_native_user_instrumentation_hookA   s    t   ExtendedInstrumentationRegistryc           B   s€   e  Z d  Z e j ƒ  Z e j ƒ  Z e j ƒ  Z e Z	 d „  Z
 d „  Z d „  Z d „  Z d „  Z d „  Z d „  Z d „  Z RS(	   s„   Extends :class:`.InstrumentationFactory` with additional
    bookkeeping, to accommodate multiple types of
    class managers.

    c         C   sM   xF t  D]: } | | ƒ } | d  k	 r |  j | | ƒ } | | f Sq Wd Sd  S(   N(   NN(   t   instrumentation_findersR   t   _extended_class_manager(   t   selft   class_t   findert   factoryt   manager(    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   _locate_extended_factorya   s    c         C   sG   |  j  | ƒ j | g ƒ } | rC t d | j t | ƒ f ƒ ‚ n  d  S(   NsR   multiple instrumentation implementations specified in %s inheritance hierarchy: %r(   t!   _collect_management_factories_fort
   differencet	   TypeErrort   __name__t   list(   R   R   R   t   existing_factories(    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   _check_conflictsj   s    c         C   s“   | | ƒ } t  | t ƒ s- t | | ƒ } n  | t k rV |  j rV t |  _ t ƒ  n  | j ƒ  |  j | <| j ƒ  |  j	 | <| j
 ƒ  |  j | <| S(   N(   t
   isinstanceR   t   _ClassInstrumentationAdaptert	   _extendedt   Truet   _install_instrumented_lookupst   manager_gettert   _manager_finderst   state_gettert   _state_finderst   dict_gettert   _dict_finders(   R   R   R   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR   s   s    	
c         C   s¨   t  j | ƒ } t ƒ  } x| | D]t } |  j | ƒ } | d k	 rS | j | j ƒ q x0 t D]" } | | ƒ } | d k	 rZ PqZ qZ Wd } | j | ƒ q W| j d ƒ | S(   sc  Return a collection of factories in play or specified for a
        hierarchy.

        Traverses the entire inheritance graph of a cls and returns a
        collection of instrumentation factories for those classes. Factories
        are extracted from active ClassManagers, if available, otherwise
        instrumentation_finders is consulted.

        N(	   R	   t   class_hierarchyt   sett   manager_of_classR   t   addR   R   t   discard(   R   R   t	   hierarchyt	   factoriest   memberR   R   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR   „   s    
	c         C   sJ   | |  j  k r0 |  j  | =|  j | =|  j | =n  t t |  ƒ j | ƒ d  S(   N(   R'   R)   R+   t   superR   t
   unregister(   R   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR5   Ÿ   s
    

c         C   s)   | d  k r d  S|  j j | t ƒ | ƒ S(   N(   R   R'   t   getR   (   R   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR.   ¦   s    c         C   s7   | d  k r t d ƒ ‚ n  |  j j | j t ƒ | ƒ S(   Ns   None has no persistent state.(   R   t   AttributeErrorR)   R6   t	   __class__R   (   R   t   instance(    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   state_of«   s    	c         C   s7   | d  k r t d ƒ ‚ n  |  j j | j t ƒ | ƒ S(   Ns   None has no persistent state.(   R   R7   R+   R6   R8   R   (   R   R9   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   dict_of±   s    	(   R   t
   __module__t   __doc__t   weakreft   WeakKeyDictionaryR'   R)   R+   t   FalseR#   R   R    R   R   R5   R.   R:   R;   (    (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR   V   s   									t   InstrumentationManagerc           B   s§   e  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(   s	  User-defined class instrumentation extension.

    :class:`.InstrumentationManager` can be subclassed in order
    to change
    how class instrumentation proceeds. This class exists for
    the purposes of integration with other object management
    frameworks which would like to entirely modify the
    instrumentation methodology of the ORM, and is not intended
    for regular usage.  For interception of class instrumentation
    events, see :class:`.InstrumentationEvents`.

    The API for this class should be considered as semi-stable,
    and may change slightly with new releases.

    .. versionchanged:: 0.8
       :class:`.InstrumentationManager` was moved from
       :mod:`sqlalchemy.orm.instrumentation` to
       :mod:`sqlalchemy.ext.instrumentation`.

    c         C   s   d  S(   N(    (   R   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   __init__×   s    c         C   s   t  | d | ƒ d  S(   Nt   _default_class_manager(   t   setattr(   R   R   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   manageÚ   s    c         C   s   t  | d ƒ d  S(   NRC   (   t   delattr(   R   R   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   disposeÝ   s    c         C   s   d „  } | S(   Nc         S   s   |  j  S(   N(   RC   (   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR6   á   s    (    (   R   R   R6   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR&   à   s    	c         C   s   d  S(   N(    (   R   R   t   keyt   inst(    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   instrument_attributeå   s    c         C   s   d  S(   N(    (   R   R   RH   RI   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   post_configure_attributeè   s    c         C   s   t  | | | ƒ d  S(   N(   RD   (   R   R   RH   RI   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   install_descriptorë   s    c         C   s   t  | | ƒ d  S(   N(   RF   (   R   R   RH   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   uninstall_descriptorî   s    c         C   s   t  | | | ƒ d  S(   N(   RD   (   R   R   RH   t   implementation(    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   install_memberñ   s    c         C   s   t  | | ƒ d  S(   N(   RF   (   R   R   RH   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   uninstall_memberô   s    c         C   s   t  j | ƒ S(   N(   R   t   prepare_instrumentation(   R   R   RH   t   collection_class(    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   instrument_collection_class÷   s    c         C   s   | j  S(   N(   t   __dict__(   R   R   R9   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   get_instance_dictú   s    c         C   s   d  S(   N(    (   R   R   R9   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   initialize_instance_dictý   s    c         C   s   t  | d | ƒ d  S(   Nt   _default_state(   RD   (   R   R   R9   t   state(    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   install_state   s    c         C   s   t  | d ƒ d  S(   NRW   (   RF   (   R   R   R9   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   remove_state  s    c         C   s   d „  S(   Nc         S   s   t  |  d ƒ S(   NRW   (   R   (   R9   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   <lambda>  s    (    (   R   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR(     s    c            s   ‡  ‡ f d †  S(   Nc            s   ˆ j  ˆ  |  ƒ S(   N(   RU   (   RI   (   R   R   (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR[   
  s    (    (   R   R   (    (   R   R   sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR*   	  s    (   R   R<   R=   RB   RE   RG   R&   RJ   RK   RL   RM   RO   RP   RS   RU   RV   RY   RZ   R(   R*   (    (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRA   ½   s$   																R"   c           B   sÂ   e  Z d  Z d „  Z d „  Z d „  Z d „  Z e d „ Z d „  Z	 d „  Z
 d „  Z d	 „  Z d
 „  Z d „  Z d „  Z d d „ Z d „  Z d d „ Z d „  Z d „  Z d „  Z d „  Z RS(   s?   Adapts a user-defined InstrumentationManager to a ClassManager.c         C   sG   | |  _  |  j  j | ƒ |  _ |  j  j | ƒ |  _ t j |  | ƒ d  S(   N(   t   _adaptedR(   t
   _get_stateR*   t	   _get_dictR   RB   (   R   R   t   override(    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRB     s    	c         C   s   |  j  j |  j |  ƒ d  S(   N(   R\   RE   R   (   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRE     s    c         C   s   |  j  j |  j ƒ d  S(   N(   R\   RG   R   (   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRG     s    c         C   s   |  j  j |  j ƒ S(   N(   R\   R&   R   (   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR&     s    c         C   s<   t  j |  | | | ƒ | s8 |  j j |  j | | ƒ n  d  S(   N(   R   RJ   R\   R   (   R   RH   RI   t
   propagated(    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRJ      s    c         C   s7   t  t |  ƒ j | ƒ |  j j |  j | |  | ƒ d  S(   N(   R4   R"   RK   R\   R   (   R   RH   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRK   %  s    c         C   s   |  j  j |  j | | ƒ d  S(   N(   R\   RL   R   (   R   RH   RI   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRL   )  s    c         C   s   |  j  j |  j | ƒ d  S(   N(   R\   RM   R   (   R   RH   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRM   ,  s    c         C   s   |  j  j |  j | | ƒ d  S(   N(   R\   RO   R   (   R   RH   RN   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRO   /  s    c         C   s   |  j  j |  j | ƒ d  S(   N(   R\   RP   R   (   R   RH   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRP   2  s    c         C   s   |  j  j |  j | | ƒ S(   N(   R\   RS   R   (   R   RH   RR   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRS   5  s    	c         C   sE   t  |  j d d  ƒ } | r+ | | | | ƒ St j |  | | | ƒ Sd  S(   Nt   initialize_collection(   R   R\   R   R   Ra   (   R   RH   RX   R   t   delegate(    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRa   9  s
    c         C   s)   |  j  j |  j  ƒ } |  j | | ƒ | S(   N(   R   t   __new__t   setup_instance(   R   RX   R9   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   new_instanceA  s    c         C   s$   |  j  | ƒ r t S|  j | ƒ Sd S(   s‚   Install a default InstanceState if none is present.

        A private convenience method used by the __init__ decorator.
        N(   t	   has_stateR@   Rd   (   R   R9   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   _new_state_if_noneF  s    c         C   sT   |  j  j |  j | ƒ | d  k r7 |  j | |  ƒ } n  |  j  j |  j | | ƒ | S(   N(   R\   RV   R   R   t   _state_constructorRY   (   R   R9   RX   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRd   P  s
    c         C   s   |  j  j |  j | ƒ d  S(   N(   R\   RZ   R   (   R   R9   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   teardown_instanceZ  s    c         C   s1   y |  j  | ƒ Wn t j k
 r( t SXt Sd  S(   N(   R]   t   orm_exct   NO_STATER@   R$   (   R   R9   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRf   ]  s
    c         C   s   |  j  S(   N(   R]   (   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR(   e  s    c         C   s   |  j  S(   N(   R^   (   R   (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR*   h  s    N(   R   R<   R=   RB   RE   RG   R&   R@   RJ   RK   RL   RM   RO   RP   RS   Ra   R   Re   Rg   Rd   Ri   Rf   R(   R*   (    (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR"     s(   												

			c           C   s,   t  t d t j d t j d t j ƒ ƒ d S(   sº  Replace global class/object management functions
    with ExtendedInstrumentationRegistry implementations, which
    allow multiple types of class managers to be present,
    at the cost of performance.

    This function is called only by ExtendedInstrumentationRegistry
    and unit tests specific to this behavior.

    The _reinstall_default_lookups() function can be called
    after this one to re-establish the default functions.

    t   instance_statet   instance_dictR.   N(   t   _install_lookupst   dictt   _instrumentation_factoryR:   R;   R.   (    (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyR%   l  s
    		c           C   s#   t  t d t d t d t ƒ ƒ d S(   s   Restore simplified lookups.Rl   Rm   R.   N(   Rn   Ro   R   R   R   (    (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   _reinstall_default_lookups‚  s
    c         C   sg   |  d a  |  d a |  d a t  t _  t _  t _  t t _ t _ t _ t t _ t _ t _ d  S(   NRl   Rm   R.   (   Rl   Rm   R.   t   orm_baseR   t   orm_instrumentation(   t   lookups(    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyRn     s    


(   R=   t   ormR    Rs   t   orm.instrumentationR   R   R   R   R   R   R   R   Rr   t    R	   R
   Rj   R>   R   R   R   R   Rp   t   objectRA   R"   R%   Rq   Rn   (    (    (    sd   /var/www/send.findwatt.com/datamanager/lib/python2.7/site-packages/sqlalchemy/ext/instrumentation.pyt   <module>   s"   (		c	P_		