Repository URL to install this package:
Version:
4.0.99 ▾
|
contego
/
home
/
tvault
/
.virtenv
/
lib
/
python2.7
/
site-packages
/
sqlalchemy
/
sql
/
visitors.pyc
|
---|
ó EYc @ s2 d Z d d l m Z d d l m Z d d l Z d d l m Z d d d d d d d d d d d d g Z d e f d YZ d Z d e j e e f d YZ d e f d YZ d e f d YZ d e f d YZ d Z d Z d Z d Z d Z d Z d Z d S( sO Visitor/traversal interface and library functions. SQLAlchemy schema and expression constructs rely on a Python-centric version of the classic "visitor" pattern as the primary way in which they apply functionality. The most common use of this pattern is statement compilation, where individual expression classes match up to rendering methods that produce a string result. Beyond this, the visitor system is also used to inspect expressions for various information and patterns, as well as for usage in some kinds of expression transformation. Other kinds of transformation use a non-visitor traversal system. For many examples of how the visit system is used, see the sqlalchemy.sql.util and the sqlalchemy.sql.compiler modules. For an introduction to clause adaption, see http://techspot.zzzeek.org/2008/01/23/expression-transformations/ iÿÿÿÿ( t dequei ( t utilN( t exct VisitableTypet Visitablet ClauseVisitort CloningVisitort ReplacingCloningVisitort iteratet iterate_depthfirstt traverse_usingt traverset traverse_depthfirstt cloned_traverset replacement_traversec B s e Z d Z d Z RS( se Metaclass which assigns a `_compiler_dispatch` method to classes having a `__visit_name__` attribute. The _compiler_dispatch attribute becomes an instance method which looks approximately like the following:: def _compiler_dispatch (self, visitor, **kw): '''Look for an attribute named "visit_" + self.__visit_name__ on the visitor, and call it with the same kw params.''' visit_attr = 'visit_%s' % self.__visit_name__ return getattr(visitor, visit_attr)(self, **kw) Classes having no __visit_name__ attribute will remain unaffected. c C sH | d k r( t | d r( t | n t t | j | | | d S( NR t __visit_name__( t hasattrt _generate_dispatcht superR t __init__( t clst clsnamet basest clsdict( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR 7 s ( t __name__t __module__t __doc__R ( ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR ' s c sw d j k rs j } t | t rO t j d | f d } n f d } d | _ | _ n d S( sY Return an optimized visit dispatch function for the cls for use by the compiler. R s visit_%sc sG y | } Wn# t k r5 t j | n X| | | Sd S( N( t AttributeErrorR t UnsupportedCompilationError( t selft visitort kwt meth( R t getter( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyt _compiler_dispatchK s c sW d | j } y t | | } Wn# t k rE t j | n X| | | Sd S( Ns visit_%s( R t getattrR R R ( R R R t visit_attrR ( R ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR" V s s Look for an attribute named "visit_" + self.__visit_name__ on the visitor, and call it with the same kw params. N( t __dict__R t isinstancet strt operatort attrgetterR R" ( R t visit_nameR" ( ( R R! sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR ? s c B s e Z d Z RS( sT Base class for visitable objects, applies the ``VisitableType`` metaclass. ( R R R ( ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR f s c B sY e Z d Z i Z d Z d Z d Z e j d Z e d Z d Z RS( sZ Base class for visitor objects which can traverse using the traverse() function. c K sD x= | j D]2 } t | d | j d } | r | | | Sq Wd S( Ns visit_%s( t _visitor_iteratorR# R t None( R t objR t vR ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyt traverse_singleu s c C s t | | j S( sa traverse the given expression structure, returning an iterator of all elements. ( R t __traverse_options__( R R- ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR { s c C s t | | j | j S( s2 traverse and visit the given expression structure.( R R0 t _visitor_dict( R R- ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR s c C sJ i } x= t | D]/ } | j d r t | | | | d <q q W| S( Nt visit_i ( t dirt startswithR# ( R t visitorst name( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR1 s c c s. | } x! | r) | Vt | d d } q Wd S( s8 iterate through this visitor and each 'chained' visitor.t _nextN( R# R, ( R R. ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR+ s c C s t | j d } | | _ | S( s 'chain' an additional ClauseVisitor onto this ClauseVisitor. the chained visitor will receive all visit events after this one. iÿÿÿÿ( t listR+ R7 ( R R t tail( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyt chain s ( R R R R0 R/ R R R t memoized_propertyR1 t propertyR+ R: ( ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR m s c B s e Z d Z d Z d Z RS( sa Base class for visitor objects which can traverse using the cloned_traverse() function. c C s g | D] } | j | ^ q S( s` Apply cloned traversal to the given list of elements, and return the new list. ( R ( R t list_t x( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyt copy_and_processª s c C s t | | j | j S( s2 traverse and visit the given expression structure.( R R0 R1 ( R R- ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR ± s ( R R R R? R ( ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR ¤ s c B s e Z d Z d Z d Z RS( sf Base class for visitor objects which can traverse using the replacement_traverse() function. c C s d S( s receive pre-copied elements during a cloning traversal. If the method returns a new element, the element is used instead of creating a simple copy of the element. Traversal will halt on the newly returned element if it is re-encountered. N( R, ( R t elem( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyt replace¾ s c s" f d } t | j | S( s2 traverse and visit the given expression structure.c s7 x0 j D]% } | j | } | d k r | Sq Wd S( N( R+ RA R, ( R@ R. t e( R ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyRA Ê s ( R R0 ( R R- RA ( ( R sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR Ç s ( R R R RA R ( ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR ¸ s c C s | j | } | s | g St } t | g } xJ | r | j } | j | x$ | j | D] } | j | qf Wq7 Wt | S( sw traverse the given expression structure, returning an iterator. traversal is configured to be breadth-first. ( t get_childrenR t popleftt appendt iter( R- t optst childrent traversalt stackt tt c( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR Ò s c C s | j | } | s | g St | g } t } xJ | r | j } | j | x$ | j | D] } | j | qf Wq7 Wt | S( su traverse the given expression structure, returning an iterator. traversal is configured to be depth-first. ( RC R t popt appendleftRE RF ( R- RG RH RJ RI RK RL ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR ç s c C s= x6 | D]. } | j | j d } | r | | q q W| S( sS visit the given expression structure using the given iterator of objects. N( t getR R, ( t iteratorR- R5 t targetR ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR ü s c C s t t | | | | S( sX traverse and visit the given expression structure using the default iterator. ( R R ( R- RG R5 ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR s c C s t t | | | | S( s[ traverse and visit the given expression structure using the depth-first iterator. ( R R ( R- RG R5 ( ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR s c sU i t | j d g f d | d k rQ | } n | S( sM clone the given expression structure, allowing modifications by visitors.t stop_onc s | k r | St | k rw | j t | <} | j d j | j d } | rw | | qw n t | Sd S( Nt clone( t idt _clonet _copy_internalsRO R R, ( R@ t newelemR ( RS t clonedRR R5 ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyRS s N( t setRO R, ( R- RG R5 ( ( RS RX RR R5 sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyR s c sq i t g | j d g D] } t | ^ q f d | d k rm | | } n | S( sg clone the given expression structure, allowing element replacement by a given replacement function.RR c s t | k s! d | j k r% | S | } | d k rT j t | | S| k r | j | <} | j d | n | Sd S( Nt no_replacement_traverseRS ( RT t _annotationsR, t addRU RV ( R@ R RW ( RS RX RA RR ( sL /home/tvault/.virtenv/lib/python2.7/site-packages/sqlalchemy/sql/visitors.pyRS 7 s N( RY RO RT R, ( R- RG RA R>