Repository URL to install this package:
|
Version:
3.4.35 ▾
|
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>