o
    E6d                    @  s  d Z ddlmZ ddlZddlZddlmZ ddlmZ ddlmZ ddlm	Z	 dd	l
mZ dd
l
mZ ddl
mZ ddl
mZ ddl
mZ ddl
mZ ddl
mZ ddl
mZ ddl
mZ ddl
mZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlm Z  ddlm!Z! ddlm"Z" ddlm#Z# ddlm$Z$ ddlm%Z% dd l&m'Z' dd!l(m)Z) dd"l*m+Z+ dd#lm,Z, dd$lm-Z- d%d&l
m.Z. d%d
l
mZ/ d%d'l
m0Z0 d%d(l
m1Z1 d%d)l
m2Z2 d%dl
mZ d%dl2mZ3 d%d*l2m4Z4 d%d+l5m6Z6 d%d,l5m7Z7 e	rdd-lm8Z8 d%d.l9m:Z: 					/	dbd0d1Z;ej<j=d/d/d2G d3d4 d4e$Z>e1j?ej<j=d5d/d2G d6d7 d7e$Z@e1j?ej<j=d5d8G d9d: d:e@ZAe1j?ej<j=d5d5d;ej<j=d5d5d5d<ej<j=d5d=G d>d? d?e$ZBG d@dA dAZCG dBdC dCe$ZDe1j?ej8j=d5d=G dDdE dEe$ZEe1j?ej8j=dFdGej8j=ddGG dHdI dIeDZFe1j?ej8j=d5dGej8j=dJdGej8j=dKdGej8j=dLdGej8j=dMdGG dNdO dOeDejGe1jHZIG dPdQ dQZJG dRdS dSeDZKej8j=dTdGG dUdV dVeKZLe1j?ej8j=dWdGG dXdY dYeKZMe1j?ej8j=dZdGej8j=d/dGG d[d\ d\eDZNe1j?ej8j=d]dGG d^d_ d_eKejGZOd`da ZPdS )czWsqlalchemy.orm.interfaces.LoaderStrategy
   implementations, and related MapperOptions.    )annotationsN)Any)Dict)Tuple)TYPE_CHECKING   )
attributes)exc)
interfaces)loading)path_registry)
properties)query)relationships)
unitofwork)util)_DEFER_FOR_STATE)_RAISE_FOR_STATE)_SET_DEFERRED_EXPIRED)ATTR_WAS_SET)LoaderCallableStatus)PASSIVE_OFF)PassiveFlag)_column_descriptions)ORMCompileState)ORMSelectCompileState)QueryContext)LoaderStrategy)StrategizedProperty)_state_session)InstanceState)Load)	_none_set)AliasedClass   )event)inspect)log)sql)visitors)LABEL_STYLE_TABLENAME_PLUS_COL)Select)RelationshipProperty)ColumnElementFc	                   s   g }
|o| j |r| jr|
t | j| jjv r+| jj| j \|
fdd |r3|
tj |rG| j	  rG| j
rG|
 fdd |jD ]C}| |j| ju r|j| jstj|j| jf| |||oq| jpq| jtju ||||| p{| j | jd|	}|
D ]}|||  qqJd S )Nc                   s   t j| |j fi S N)orm_utilZ_validator_eventskeydescprop)fnopts pC:\Users\jesus\OneDrive\Desktop\erpjis_fastapi\backend\jisbackend\Lib\site-packages\sqlalchemy/orm/strategies.py<lambda>X   s
    z%_register_attribute.<locals>.<lambda>c                   s   t |  S r.   )r   Zbackref_listenersr1   )backrefuselistr6   r7   r8   f   s    )Zparent_tokenr:   compare_function	useobjectZtrackparenttypecallable	callable_active_history
impl_classZsend_modified_eventsdoc)r:   Zsingle_parentappendsingle_parent_validatorr0   parentZ
validatorsr   Ztrack_cascade_eventsZback_populatesZ_effective_sync_backrefZself_and_descendants_propsgetclass_managerZ_attr_has_implr   Zregister_attribute_implclass_	directionr
   Z	ONETOMANYZviewonlyrA   )r3   mapperr<   r;   r=   r>   Zproxy_propertyr?   r@   kwZlisten_hooksmr2   hookr6   )r9   r4   r5   r:   r7   _register_attributeB   s^   





rN   )
instrumentdeferredc                      s8   e Zd ZdZdZ fddZ	d
ddZdd	 Z  ZS )UninstrumentedColumnLoaderzRepresent a non-instrumented MapperProperty.

    The polymorphic_on argument of mapper() often results in this,
    if the argument is against the with_polymorphic selectable.

    columnsc                      t  || | jj| _d S r.   )super__init__parent_propertyrS   selfrD   strategy_key	__class__r6   r7   rV         z#UninstrumentedColumnLoader.__init__Nc           	      K  s*   | j D ]}|r|j | }||| qd S r.   )rS   _append_dedupe_col_collection)	rY   compile_statequery_entitypathloadoptadaptercolumn_collectionkwargscr6   r6   r7   setup_query   s
   


z&UninstrumentedColumnLoader.setup_queryc	           	      C  s   d S r.   r6   	rY   contextr`   ra   rb   rJ   resultrc   
populatorsr6   r6   r7   create_row_processor   s   z/UninstrumentedColumnLoader.create_row_processorr.   )	__name__
__module____qualname____doc__	__slots__rV   rg   rl   __classcell__r6   r6   r[   r7   rQ      s    
rQ   Tc                      s@   e Zd ZdZdZ fddZ	dddZdd	 Zd
d Z  Z	S )ColumnLoaderz8Provide loading behavior for a :class:`.ColumnProperty`.)rS   is_compositec                   s*   t  || | jj| _t| jd| _d S )Ncomposite_class)rU   rV   rW   rS   hasattrrt   rX   r[   r6   r7   rV      s   
zColumnLoader.__init__Fc	                 K  sv   | j D ]}
|r|r||
}
|
d u r d S n|j |
 }
||
| q| j d }|r4|j | }|d u r4d S ||| j< d S Nr   )rS   Zadapt_check_presentr^   rW   )rY   r_   r`   ra   rb   rc   rd   memoized_populatorsZcheck_for_adaptre   rf   fetchr6   r6   r7   rg      s   




zColumnLoader.setup_queryc                 C  s`   d| _ | jd j}| jjp"| jd jp"|jd uo"|j|jd | ju }t	| j|d|j
|d d S )NTr   F)r<   r;   r?   )is_class_levelrS   typerW   r?   primary_keyZversion_id_col_columntopropertyrF   rN   compare_values)rY   rJ   Zcoltyper?   r6   r6   r7   init_class_attribute   s"   



z!ColumnLoader.init_class_attributec	                 C  s\   | j D ]}	|r|j |	 }	||	d}
|
r!|d | j|
f  d S q|d | jdf d S )NFquickexpireT)rS   _getterrB   r0   )rY   ri   r`   ra   rb   rJ   rj   rc   rk   colgetterr6   r6   r7   rl     s   

z!ColumnLoader.create_row_processorF)
rm   rn   ro   rp   rq   rV   rg   r   rl   rr   r6   r6   r[   r7   rs      s    
!rs   )Zquery_expressionc                      s4   e Zd Z fddZdd Zdd Zdd Z  ZS )	ExpressionColumnLoaderc                   s<   t  || t d  t fdd| jjD | _d S )Nc                 3  s    | ]	}|   V  qd S r.   )compare.0rf   nullr6   r7   	<genexpr>%  s    
z2ExpressionColumnLoader.__init__.<locals>.<genexpr>)	rU   rV   r(   r   labelanyrW   rS   _have_default_expressionrX   r[   r   r7   rV     s
   zExpressionColumnLoader.__init__c                 K  s   d }	|rd|j v r|j d g}	n| jr| jj}	|	d u rd S |	D ]}
|r(|j|
 }
||
| q|	d }|r@|j| }|d u r@d S ||| j< d S )N
expressionr   )
local_optsr   rW   rS   r^   )rY   r_   r`   ra   rb   rc   rd   rx   re   rS   rf   ry   r6   r6   r7   rg   )  s"   

z"ExpressionColumnLoader.setup_queryc	                 C  s|   |r:d|j v r<|j d g}	|	D ]}
|r|j|
 }
||
d}|r-|d | j|f  d S q|d | jdf d S d S d S )Nr   Fr   r   T)r   rS   r   rB   r0   )rY   ri   r`   ra   rb   rJ   rj   rc   rk   rS   r   r   r6   r6   r7   rl   M  s   
z+ExpressionColumnLoader.create_row_processorc                 C  s(   d| _ t| j|d| jd jjdd d S )NTFr   )r<   r;   Zaccepts_scalar_loader)rz   rN   rW   rS   r{   r~   rY   rJ   r6   r6   r7   r   g  s   
z+ExpressionColumnLoader.init_class_attribute)rm   rn   ro   rV   rg   rl   r   rr   r6   r6   r[   r7   r     s
    $r   )rP   rO   )rP   rO   	raiseload)Z
do_nothingc                      sP   e Zd ZdZdZ fddZdd Zdd Z		dd
dZdd Z	dd Z
  ZS )DeferredColumnLoaderzAProvide loading behavior for a deferred :class:`.ColumnProperty`.)rS   groupr   c                   sJ   t  || t| jdrtd| jdd| _| jj| _| jj	| _	d S )Nru   z8Deferred loading for composite types not implemented yetr   F)
rU   rV   rv   rW   NotImplementedErrorstrategy_optsrF   r   rS   r   rX   r[   r6   r7   rV   ~  s   
zDeferredColumnLoader.__init__c	           
   
   C  s   |j r"|jjjr"| j|jjjv r"| jd|||||||| d S | js=| j	r-| jj
}	n| jj}	|d | j|	f d S |d | jdf d S )N)rP   FrO   Tnewr   F)refresh_stater   _compile_options_only_load_propsr0   rW   _get_strategyrl   rz   r   Z_raise_column_loaderZ_deferred_column_loaderrB   )
rY   ri   r`   ra   rb   rJ   rj   rc   rk   Zset_deferred_for_local_stater6   r6   r7   rl     s4   z)DeferredColumnLoader.create_row_processorc                 C  s,   d| _ t| j|d| jd jj| jdd d S )NTFr   )r<   r;   r>   Zload_on_unexpire)rz   rN   rW   rS   r{   r~   _load_for_stater   r6   r6   r7   r     s   
z)DeferredColumnLoader.init_class_attributeNc	           
      K  s   |j jr| jjs*|rt| j| jjs*|r#| j	r#|j
d| j	 ds*|r?| j|v r?| jdj|||||||fi |	 d S | jrIt|| j< d S | jsSt|| j< d S t|| j< d S )Nzundefer_group_%sFr   )compile_optionsZ_render_for_subqueryrW   Z_renders_in_subqueriessetrS   intersectionrD   Z_should_undefer_in_wildcardr   r   rF   r0   r   rg   rz   r   r   r   r   )
rY   r_   r`   ra   rb   rc   rd   rx   Zonly_load_propsrK   r6   r6   r7   rg     sP   




z DeferredColumnLoader.setup_queryc                   s   j stjS |tj@ stjS jj} jr  fdd|j	D }n j g}fdd|D }t
}|d u rBtdt j f  jrL |d tjt|t tjS )Nc                   s4   g | ]}t |trt |jtr|j jkr|jqS r6   )
isinstancer   strategyr   r   r0   )r   prY   r6   r7   
<listcomp>  s    
z8DeferredColumnLoader._load_for_state.<locals>.<listcomp>c                   s   g | ]	}| j v r|qS r6   )Z
unmodified)r   k)stater6   r7   r     s    zfParent instance %s is not bound to a Session; deferred load operation of attribute '%s' cannot proceedraise)r0   r   
ATTR_EMPTYr   SQL_OKPASSIVE_NO_RESULTmanagerrJ   r   Ziterate_propertiesr   orm_excDetachedInstanceErrorr/   	state_strr   _invoke_raise_loadr   Zload_scalar_attributesr   r   r   )rY   r   passivelocalparentZtoloadr   sessionr6   )rY   r   r7   r     s0   

z$DeferredColumnLoader._load_for_statec                 C  s   t d| f )Nz+'%s' is not available due to raiseload=Truesa_excInvalidRequestErrorrY   r   r   lazyr6   r6   r7   r   "  s   z'DeferredColumnLoader._invoke_raise_loadr.   )rm   rn   ro   rp   rq   rV   rl   r   rg   r   r   rr   r6   r6   r[   r7   r   s  s    
3
3(r   c                   @  s*   e Zd ZdZddddZejfd	d
ZdS )LoadDeferredColumnsz7serializable loader object used by DeferredColumnLoaderFr0   strr   boolc                 C  s   || _ || _d S r.   )r0   r   )rY   r0   r   r6   r6   r7   rV   +  s   
zLoadDeferredColumns.__init__c                 C  s>   | j }|jj}|j| }| jrd}nd}||}|||S )N)rP   Tr   )r   T)r   r   )r0   r   rJ   rE   r   r   r   )rY   r   r   r0   r   r3   rZ   r   r6   r6   r7   __call__/  s   

zLoadDeferredColumns.__call__Nr   )r0   r   r   r   )rm   rn   ro   rp   rV   r   r   r   r6   r6   r6   r7   r   (  s    r   c                      s,   e Zd ZdZdZ fddZdd Z  ZS )AbstractRelationshipLoaderz0LoaderStratgies which deal with related objects.)rJ   targetr:   entityc                   s:   t  || | jj| _| jj| _| jj| _| jj| _d S r.   )rU   rV   rW   rJ   r   r   r:   rX   r[   r6   r7   rV   E  s
   


z#AbstractRelationshipLoader.__init__c	           	   
   C  s    | j d||||||||S )N))r   	immediate)rW   r   rl   rh   r6   r6   r7   #_immediateload_create_row_processorL  s   z>AbstractRelationshipLoader._immediateload_create_row_processor)rm   rn   ro   rp   rq   rV   r   rr   r6   r6   r[   r7   r   @  s
    r   c                   @  s   e Zd ZdZdS )DoNothingLoaderzRelationship loader that makes no change to the object's state.

    Compared to NoLoader, this loader does not initialize the
    collection/attribute to empty/none; the usual default LazyLoader will
    take effect.

    N)rm   rn   ro   rp   r6   r6   r6   r7   r   e  s    r   Znoload)r   c                   @  s$   e Zd ZdZdZdd Zdd ZdS )NoLoaderzQProvide loading behavior for a :class:`.Relationship`
    with "lazy=None".

    r6   c                 C  s    d| _ t| j|d| jjd d S )NT)r<   r=   )rz   rN   rW   collection_classr   r6   r6   r7   r   |  s   
zNoLoader.init_class_attributec	           
        s$    fdd}	|d   j|	f d S )Nc                   s(    j rt| | j d S d | j< d S r.   )r:   r   init_state_collectionr0   r   dict_rowr   r6   r7   invoke_no_load  s   z5NoLoader.create_row_processor.<locals>.invoke_no_loadr   )rB   r0   )
rY   ri   r`   ra   rb   rJ   rj   rc   rk   r   r6   r   r7   rl     s   zNoLoader.create_row_processorN)rm   rn   ro   rp   rq   r   rl   r6   r6   r6   r7   r   q  s
    
r   selectr   raise_on_sqlZbaked_selectc                      s   e Zd ZU dZdZded< ded< ded< ded< d	ed
< d# fddZdd Zdd Zdd Z	dd Z
ddddejfddZdd Zeddd  Zd!d" Z  ZS )$
LazyLoaderztProvide loading behavior for a :class:`.Relationship`
    with "lazy=True", that is loads when first accessed.

    )
_lazywhere_rev_lazywhereZ_lazyload_reverse_option	_order_byuse_getis_aliased_class_bind_to_col_equated_columns_rev_bind_to_col_rev_equated_columns_simple_lazy_clause_raise_always_raise_on_sqlzColumnElement[bool]r   zDict[str, ColumnElement[Any]]r   r   r   RelationshipProperty[Any]rW   rD   rZ   Tuple[Any, ...]c                   s8  t  || | jd dk| _| jd dk| _t| jj| _| jj	}|
 \| _| _| _|j
dd\| _| _| _| jjrJdd t| jjD | _nd | _| jd| | j | j om| j om| jjd	 j| jdd
| jjd| _| jrt| jD ]}|| jjv r| jj| D ]
}| j| | j|< qqw| jd|  d S d S )Nr   r   r   T)Zreverse_directionc                 S  s   g | ]
}t |d diqS )
_orm_adaptT)sql_util_deep_annotater   elemr6   r6   r7   r     s    z'LazyLoader.__init__.<locals>.<listcomp>z%s lazy loading clause %sr   FZuse_proxiesZcompare_keysequivalentsz4%s will use Session.get() to optimize instance loads)rU   rV   r   r   r   r&   r   r   rW   _join_conditionZcreate_lazy_clauser   r   r   r   r   r   order_byr   to_listr   loggerinfor:   _get_clauser   rJ   _equivalent_columnsr   list)rY   rD   rZ   Zjoin_conditionr   rf   r[   r6   r7   rV     sR   


zLazyLoader.__init__c              	   C  sv   d| _ | jj}| jjrd}d}n| jjtjus| js&|r!d}d}n	d}d}nd }}t| j|d| j	| jj
||d d S )NTF)r<   r>   r=   r?   _deferred_history)rz   rW   _legacy_inactive_history_styler?   rI   r
   	MANYTOONEr   rN   r   r   )rY   rJ   r   r?   r   r6   r6   r7   r     s0   
zLazyLoader.init_class_attributec                   sd   t | jddi}|| j} g dd }t|i d|i  fdd}t|i d|i}|fS )Nr   Tc                 S  s
   d| _ d S )NF)unique	bindparamr6   r6   r7   visit_bindparam&  s   
zFLazyLoader._memoized_attr__simple_lazy_clause.<locals>.visit_bindparamr   c                   sL   | j  v r| j | j  d f d S | jd u r$| jd | jf d S d S r.   )Z_identifying_keyrB   r0   callablevaluer   Zbind_to_colparamsr6   r7   r   +  s   

)r   r   r   r   r)   traverseZcloned_traverse)rY   Z	lazywhere	criterionr   r6   r   r7   "_memoized_attr__simple_lazy_clause  s   

z-LazyLoader._memoized_attr__simple_lazy_clausec                 C  s   | j \}}|d u rt|dd |D S | jj}| }t|}|tj	@ r+|tj	N }i }|D ]%\}	}
}|
d urP|rH|tj
@ rH||||
|}n||||
|}|||	< q/||fS )Nc                 S  s   g | ]\}}}|qS r6   r6   )r   r0   identr   r6   r6   r7   r   B      z4LazyLoader._generate_lazy_clause.<locals>.<listcomp>)r   r   Zadapt_criterion_to_nullrW   rD   objr   instance_dictr   ZINIT_OKLOAD_AGAINST_COMMITTED#_get_committed_state_attr_by_column_get_state_attr_by_column)rY   r   r   r   Z
param_keysrJ   or   r   r0   r   r   r6   r6   r7   _generate_lazy_clause=  s,   




z LazyLoader._generate_lazy_clausec                 C  s   t d| |f )Nz&'%s' is not available due to lazy='%s'r   r   r6   r6   r7   r   ]  s   
zLazyLoader._invoke_raise_loadNr6   c                 C  s  |j s| jjs
|jr|jstjS |j  }d }	| jo| p|j }
|t	j
@ s'|
r.|tj@ s1|r1tjS | jrG|t	j@ sG|
r@|t	j@ rG| ||d t|}|sb|t	j@ rUtjS tdt|| j f |
r| |||}	tj|	v rstjS tj|	v r{tjS t|	rd S | j |jv r|t	j@ stjS |j| j|	||d}|d ur|tj u rd S |S |t	j
@ r|t	j@ stjS | !|||	||||||	S )Nr   zbParent instance %s is not bound to a Session; lazy load operation of attribute '%s' cannot proceed)r   Zlazy_loaded_from)"r0   rW   Zload_on_pendingZ_load_pendingZ
session_idr   r   r   _extra_criteriar   r   r   ZNON_PERSISTENT_OKr   r   NO_RAISEZRELATED_OBJECT_OKr   r   r   r   r/   r   _get_ident_for_use_getZ	NEVER_SETr"   
issupersetdictDEFERRED_HISTORY_LOADr   Z_identity_lookupr   ZPASSIVE_CLASS_MISMATCH_emit_lazyload)rY   r   r   rb   extra_criteriaextra_optionsalternate_effective_pathexecution_optionspendingprimary_key_identityr   r   instancer6   r6   r7   r   b  s   





zLazyLoader._load_for_statec                   sD   j j}tj@ r|jn|jj  fddjjD S )Nc                   s"   g | ]} j | d qS )r   r   r   pkr   Zget_attrr   rY   r   r6   r7   r     s    z5LazyLoader._get_ident_for_use_get.<locals>.<listcomp>)r   rJ   r   r   r   r  r  r|   )rY   r   r   r   instance_mapperr6   r  r7   r    s   
z!LazyLoader._get_ident_for_use_getzsqlalchemy.orm.strategy_optionsc
                   s  t jj j }
tj|
g|
jtt	j
d}tj}|d|d7 } jjd ur.| j jj}|j }|s9|tj@ rAt ddi|_ j}|jsL|rt|jrt|d u rW|j j }n| j }|j}|rp|jrpd}|t j|f7 }||_n|d u r|jj j }n| j }|r| j|7  _| jd|i7  _|r jr|t j!@ s "||d t#j$|||||	dS  j%r j%|_& fdd	}| j'| jff7  _' (||\}}|	rt j)*|	d
|i}	nd
|i}	 j|j+v r|t j,@ st-j.S |rt /tj0|1 rd S nt /tj2|1 rd S  jr|t j!@ s "||d |f|_3|j4|||	d}|5 6 7 } j8r6|S t9|}|rN|dkrJt :d j  |d S d S )N)_raw_columns_propagate_attrs_label_styler   F)Z_invoke_all_eagers_lazy_loaded_fromZ	autoflush_current_pathr   )load_optionsr  c                   sR    j jD ]"}|jtju r&|jr&t|jts&j	
| jj|j ||  qd S r.   )rW   Z_reverse_propertyrI   r
   r   Z_use_getr   r   r   r!   Z_construct_for_existing_pathr   r  rD   ZlazyloadZprocess_compile_state)compile_contextrevrY   strategy_optionsr6   r7   _lazyload_reverse6  s   
z4LazyLoader._emit_lazyload.<locals>._lazyload_reverseZ_sa_orm_load_options)r  r   zKMultiple rows returned with uselist=False for lazily-loaded attribute '%s' r   );r   Z	preloadedZorm_strategy_optionsr   __clause_element__r+   _create_raw_selectr  r*   r   default_compile_optionsr   Zdefault_load_optionsrW   Z	secondaryselect_fromrJ   r0   r   ZNO_AUTOFLUSHimmutabledict_execution_optionsr   r  r  Z	load_pathr/   LoaderCriteriaOption_with_options_path_registryr   r   r   r  r   r   Zload_on_pk_identityr   _order_by_clausesZ_with_context_optionsr  
EMPTY_DICT
merge_withr  r	  r   r   Zhas_intersectionr"   valuesZ
_never_setZ_where_criteriaexecuter   Zscalarsallr:   lenwarn)rY   r   r   r  r   rb   r  r  r  r  Zclauseelementstmtr  r  r   effective_pathr5   r"  Zlazy_clauser   rj   lr6   r   r7   r
    s   





zLazyLoader._emit_lazyloadc	              
     s   | j  |jjr |jjjr | j |jjjv r | ||||||||S | jr(|rI|jrIt	
|jt | ||jr8||nd  }	|d | j |	f d S |jsO|jra fdd}
|d | j |
f d S d S )Nr   c                   s   |  |  d S r.   )_resetr   r0   r6   r7   reset_for_lazy_callable  s   	z@LazyLoader.create_row_processor.<locals>.reset_for_lazy_callable)r0   r  Z_is_user_refreshr   r   r   r   rz   r  r    Z"_instance_level_callable_processorrG   LoadLazyAttribute_generate_extra_criteriarB   populate_existingZalways_refresh)rY   ri   r`   ra   rb   rJ   rj   rc   rk   Zset_lazy_callabler9  r6   r8  r7   rl     sF   
zLazyLoader.create_row_processor)rD   r   rZ   r   )rm   rn   ro   rp   rq   __annotations__rV   r   r   r  r   r   r-  r   r  Zpreload_moduler
  rl   rr   r6   r6   r[   r7   r     s0   
 	<"  	
p
 r   c                   @  s.   e Zd ZdZdd Zdd ZejfddZdS )	r:  a  semi-serializable loader object used by LazyLoader

    Historically, this object would be carried along with instances that
    needed to run lazyloaders, so it had to be serializable to support
    cached instances.

    this is no longer a general requirement, and the case where this object
    is used is exactly the case where we can't really serialize easily,
    which is when extra criteria in the loader option is present.

    We can't reliably serialize that as it refers to mapped entities and
    AliasedClass objects that are local to the current process, which would
    need to be matched up on deserialize e.g. the sqlalchemy.ext.serializer
    approach.

    c                 C  s   || _ |j| _|| _|| _d S r.   r0   rZ   rb   r  )rY   r0   Zinitiating_strategyrb   r  r6   r6   r7   rV     s   
zLoadLazyAttribute.__init__c                 C  s(   | j d ur
td | j| j| jddS )NzvCan't reliably serialize a lazyload() option that contains additional criteria; please use eager loading for this caser6   r>  )r  r   r3  r0   rZ   rb   r   r6   r6   r7   __getstate__  s   
zLoadLazyAttribute.__getstate__c                 C  s:   | j }|jj}|j| }|j| j }|j||| j| jdS )N)rb   r  )	r0   r   rJ   rE   Z_strategiesrZ   r   rb   r  )rY   r   r   r0   r  r3   r   r6   r6   r7   r     s   
zLoadLazyAttribute.__call__N)	rm   rn   ro   rp   rV   r?  r   r   r   r6   r6   r6   r7   r:    s
    r:  c                   @  s   e Zd ZdZdZdddZdS )
PostLoaderz;A relationship loader that emits a second SELECT statement.r6   Nc                 C  sF  |j jptjj| }| }td|i}|r#|j	dd }|dk}	nd }d}	|d ura| j
js9td| j
 d|j	dt|  |}|	sQ|dk rQ|d||fS |	sa|dt|  |d	 i}tj||| j
rp|d||fS || j
 }
|| j
 }|
|jd
s|r|jd |kr|d||fS n|| jr|d||fS |d||fS )NZsa_top_level_orm_contextrecursion_depthFz'recursion_depth option on relationship z0 not valid for non-self-referential relationshipZ_recursion_depth_r   r   loaderr$   T)r_   current_pathr/   PathRegistryrootZ_get_top_level_contextr   r'  r   rF   rW   Z_is_self_referentialr   r   r  idunionr   PostLoadZpath_existscontainsr   lengthcontains_mapperrJ   )rY   ri   ra   rb   
join_depthr5  Ztop_level_contextr  rA  Zunlimited_recursionpath_w_propZeffective_path_w_propr6   r6   r7   _setup_for_recursion  sn   


zPostLoader._setup_for_recursionr.   )rm   rn   ro   rp   rq   rO  r6   r6   r6   r7   r@    s    r@  r   c                      s8   e Zd ZdZ fddZdd Zdd Zdd	 Z  ZS )
ImmediateLoaderrM  c                   rT   r.   rU   rV   rW   rM  rX   r[   r6   r7   rV   I  r]   zImmediateLoader.__init__c                 C     | j d| d S N)r   r   rW   r   r   r   r6   r6   r7   r   M     z$ImmediateLoader.init_class_attributec	                 C  s^   |  |||| j\}	}
}}|
stjtjB }ntjtjB }tj	||	| j
| j| j||||	 d S r.   )rO  rM  r   ZPASSIVE_NO_FETCH_RELATEDr   r  r   r   rI  callable_for_pathrD   rW   _load_for_path)rY   ri   r`   ra   rb   rJ   rj   rc   rk   r5  
run_loaderr  rA  flagsr6   r6   r7   rl   R  s(   z$ImmediateLoader.create_row_processorc	                 C  s   |rt |jj}	|| f|	_| }
|	f}nd }	|}
d}| j}| jd}|D ](\}}|j	}|s5||vrP|j
||||
|d}|ttjfvrP||||| q(d S )Nr6   rU  )r  r  r  )r!   ra   r   Z_recurseri   _truncate_recursiver0   rW   r   r  r   r   r   r   get_implset_committed_value)rY   ri   ra   states	load_onlyrb   r[  rA  r  Znew_optr  r  r0   
lazyloaderr   	overwriter   r   r6   r6   r7   rY  x  s>   
zImmediateLoader._load_for_path)	rm   rn   ro   rq   rV   r   rl   rY  rr   r6   r6   r[   r7   rP  E  s    &rP  subqueryc                      s   e Zd ZdZ fddZdd Zdd Zdd	 Zd
d Zdd Z	dd Z
dd ZG dd dZdd Zdd Zdd Zdd Z  ZS )SubqueryLoaderrQ  c                   rT   r.   rR  rX   r[   r6   r7   rV     r]   zSubqueryLoader.__init__c                 C  rS  rT  rV  r   r6   r6   r7   r     rW  z#SubqueryLoader.init_class_attributec                   s   |}|j }t|d }| j|r!| j|d u r!| j| j }n||d  }|rK|j| jj| t	|t	 }|rJt
j|| d  7 n||j}	 fdd|	D }
 |
|fS )Nr   r   c                   s&   g | ]}t jd  j j| jqS r   )getattrra   r   r}   r0   r   leftmost_mapperZnew_subq_pathr6   r7   r     s    

z0SubqueryLoader._get_leftmost.<locals>.<listcomp>)ra   r/   Z_class_to_mapperrD   isarW   	_entitiesentity_zeror+  r2  r   rE  Zcoercelocal_columns)rY   orig_query_entity_index	subq_pathZcurrent_compile_stateis_rootZgiven_subq_pathZsubq_mapperZleftmost_prop
additionalZleftmost_colsleftmost_attrr6   rg  r7   _get_leftmost  s4   
zSubqueryLoader._get_leftmostc                 C  s*  |  d }tjtj}|j|j |}|js0d|_|j	j
|gdd t||dD R   |dd |D | }	|	|_|j}
|
du rKd|_n|
d u rfdd |	D D ]}t|	|jsed|_ nqV|jsld	|_|jdu r|jrt|	|j}|r||	|  |t }tj||dd
}|S )NFc                 S  s    h | ]}|d  dur|d  qS )r   Nr6   )r   entr6   r6   r7   	<setcomp>  s
    z?SubqueryLoader._generate_from_original_query.<locals>.<setcomp>)r_   c                 S  s   g | ]}t jt jj|qS r6   )r(   Z	coercionsexpectZrolesZColumnsClauseRole)r   r  r6   r6   r7   r         z@SubqueryLoader._generate_from_original_query.<locals>.<listcomp>Tc                 S  s   h | ]}|j qS r6   )tabler   r6   r6   r7   rt  -  s    r6   use_mapper_path)Z_cloneZ	correlater   Query__new____dict__updateZ	_from_objZ_enable_assertionsr&  Znon_generativer   Z_adapt_col_listZ_get_current_adapterr  distinct_target_keyZ	_distinctr   r  r|   Z_has_row_limiting_clauser,  r   Z expand_column_list_from_order_byZ_set_entitiesZset_label_styler*   rc  r/   r#   )rY   orig_compile_state
orig_queryrh  rq  leftmost_relationshipZorig_entityqq2Ztarget_colsr~  tZto_addZembed_q
left_aliasr6   r6   r7   _generate_from_original_query  sX   z,SubqueryLoader._generate_from_original_queryc                   s   g }t | }t|D ]'\}\}}|dkr)||d  d j}||r&|n|}	n|}	||	|jf qt|dk r=| nt|d d }
|
j	rL|
j
 ntj|
j
dd jj} fdd|D }|| fS )	Nr   r   r$   rB  Trx  c                   s    g | ]}t  jj| jqS r6   )rf  rD   r}   r0   r   parent_aliasrY   r6   r7   r   r  s    z2SubqueryLoader._prep_for_joins.<locals>.<listcomp>)r   pairs	enumeraterJ   ri  rB   r0   r2  r&   r   r   r/   r#   rW   rl  )rY   r  rn  to_joinr  irJ   r3   Zprev_mapperZ	to_appendr   
local_cols
local_attrr6   r  r7   _prep_for_joinsI  s*   
zSubqueryLoader._prep_for_joinsc                 C  s.  t |}|dkrt||d d |g}nu|dkr3t||d d |t||d d |g}nX|dkrdd |dd D }g }|rl|d}	t|	d |	d }
|r`|
|d d }
n|
|}
||
 |sFt||d d |d jg| t||d d |g }|D ]}
||
}q|S )Nr   r   r$   rB  c                 S  s:   g | ]}t |d  jst|d  n|d  j|d fqS )r   r   )r&   r   r/   r#   r   )r   itemr6   r6   r7   r     s    z/SubqueryLoader._apply_joins.<locals>.<listcomp>)r2  rf  of_typepoprB   rD   join)rY   r  r  r  r  effective_entityZltjmiddleinnerr  attrr6   r6   r7   _apply_joinsx  sF   
	



zSubqueryLoader._apply_joinsc           	      C  sB   |j }|r|jr|t| j||f7 }||}|j| }|S r.   )r*  r  r/   r)  r   r;  Z_with_current_pathoptions)	rY   ri   r  rn  rewritten_pathr  r  rb   new_optionsr6   r6   r7   _setup_options  s   

	
zSubqueryLoader._setup_optionsc                   s&    j jr fdd}|| j }|S )Nc                       |  j tt jj7  _ d S r.   eager_order_bytupler   r   rW   r   r  r   r6   r7   _setup_outermost_orderby     zISubqueryLoader._setup_outermost_orderby.<locals>._setup_outermost_orderby)rW   r   _add_context_option)rY   r  r  r6   r   r7   r    s   z'SubqueryLoader._setup_outermost_orderbyc                   @  s4   e Zd ZdZdZdd Zdd Zdd Zd	d
 ZdS )zSubqueryLoader._SubqCollectionszGiven a :class:`_query.Query` used to emit the "subquery load",
        provide a load interface that executes the query at the
        first moment a value is needed.

        r   r  r  r   subq_datac                 C  s4   |j | _ |j| _|j| _|jpi | _|| _d | _d S r.   r  )rY   ri   r  r6   r6   r7   rV     s   
z(SubqueryLoader._SubqCollections.__init__c                 C  s    | j d u r	|   | j ||S r.   )r  _loadrF   )rY   r0   defaultr6   r6   r7   rF     s   
z#SubqueryLoader._SubqCollections.getc                 C  s   t t| _| j}|jd u sJ || j}| jjr|	 }t|
| j
}t|dd D ]\}}| j| dd |D  q.d S )Nc                 S  s   | dd  S )Nr   r6   xr6   r6   r7   r8   	  s    z7SubqueryLoader._SubqCollections._load.<locals>.<lambda>c                 s      | ]}|d  V  qdS )r   Nr6   r   vvr6   r6   r7   r   
      z8SubqueryLoader._SubqCollections._load.<locals>.<genexpr>)collectionsdefaultdictr   r  r  r   Zwith_sessionr  Z_populate_existingr<  r   	itertoolsgroupbyextend)rY   r  rowsr   vr6   r6   r7   r    s   z%SubqueryLoader._SubqCollections._loadc                 C  s   | j d u r|   d S d S r.   )r  r  )rY   r   r   r   r6   r6   r7   rC    s   
z&SubqueryLoader._SubqCollections.loaderN)	rm   rn   ro   rp   rq   rV   rF   r  rC  r6   r6   r6   r7   _SubqCollections  s    	
r  c              	   C  s  |j }|jjr|jjrd S |j|}d|_|| j }||j	dd }	|	d ur*|	}
n| j
}
|jjdtjjtjjf\}}|tjju }|| }|| }|jjdtf|j}t|d}|jrq|jjd u rntd| |f  |j}|j|dd}| ||||\}}}}| ||||||}t|
}|jj|jdtf|d||fi|_|d}|  ||\}}}|j!| }| "|||||
}| #||||||
|}| $|}|S )	NTpath_with_polymorphic)Zsubquery_pathsNr  ormzsubqueryloader for "%s" must invoke lambda callable at %r in order to produce a new query, decreasing the efficiency of caching for this statement.  Consider using selectinload() for more effective full-lambda cachingF)legacy)%r_   r   _enable_eagerloadsZ_for_refresh_staterj  indexZloaders_require_bufferingrW   rF   r   r   r   r(  r/   rE  rF  rd  r   Z_get_plugin_class_for_pluginZ_is_lambda_elementr  r  r   r3  Z	_resolvedZ_create_entities_collectionrr  r  rz  r.  r  Z_set_enable_single_critr  Zadd_columnsr  r  r  )rY   ri   r`   ra   r   rb   rc   r_   rm  with_poly_entityr  rn  r  ro  r  Zcompile_state_clsr  rh  rq  r  r  r  r  r  r  r6   r6   r7   _setup_query_from_rowproc  s   	

	






	z(SubqueryLoader._setup_query_from_rowprocc	              
     sf  |j r| |||||| |S | |||| j\}	}
}	}	|
s d S t|jts(d S | jj| j	 j
js8td|  t|dkrIt|j| jsHd S nt|d | jsTd S | ||||d | }|d u rfd S |jd u smJ || j }| jj}||jd}|d u r| ||}||jd|  r fdd|D }| jr| ||||| d S | ||||| d S )NJ'%s' does not support object population - eager loading cannot be applied.r   rB  r  c                      g | ]} j | qS r6   rR   r   rc   r6   r7   r     r   z7SubqueryLoader.create_row_processor.<locals>.<listcomp>)r   r   rO  rM  r   r_   r   rD   rG   r0   implsupports_populationr   r   r2  r/   _entity_isark  r  r   rW   rl  rF   r   r  r   r:   _create_collection_loader_create_scalar_loader)rY   ri   r`   ra   rb   rJ   rj   rc   rk   _rZ  r  r  r  r6   r  r7   rl     sp   
		


z#SubqueryLoader.create_row_processorc                   t   | | fddfdd}|d jf |d j|f |jr8|d j jf d S d S )Nc                   s*     |d}| j| || d S )Nr6   )rF   r]  r0   r^  )r   r   r   
collectionr  rY   tuple_getterr6   r7   load_collection_from_subq  s   zKSubqueryLoader._create_collection_loader.<locals>.load_collection_from_subqc                      j |vr | || d S d S r.   r8  r   )r  rY   r6   r7   &load_collection_from_subq_existing_row     
zXSubqueryLoader._create_collection_loader.<locals>.load_collection_from_subq_existing_rowr   existingeagerZ_tuple_getterrB   r0   invoke_all_eagersrC  )rY   ri   rj   r  r  rk   r  r6   )r  r  rY   r  r7   r    s   
z(SubqueryLoader._create_collection_loaderc                   r  )Nc                   sL     |d}t|dkrtd  |d }| j| || d S )Nr.   r   LMultiple rows returned with uselist=False for eagerly-loaded attribute '%s' r   )rF   r2  r   r3  r]  r0   r^  )r   r   r   r  Zscalarr  r6   r7   load_scalar_from_subq  s   zCSubqueryLoader._create_scalar_loader.<locals>.load_scalar_from_subqc                   r  r.   r8  r   )r  rY   r6   r7   "load_scalar_from_subq_existing_row  r  zPSubqueryLoader._create_scalar_loader.<locals>.load_scalar_from_subq_existing_rowr   r  r  r  )rY   ri   rj   r  r  rk   r  r6   )r  r  rY   r  r7   r    s   
z$SubqueryLoader._create_scalar_loader)rm   rn   ro   rq   rV   r   rr  r  r  r  r  r  r  r  rl   r  r  rr   r6   r6   r[   r7   rd    s     1d/4"4 	Yrd  Zjoinedc                      s   e Zd ZdZdZ fddZdd Z			dd	d
Zdd Zdd Z	dd Z
dd Z	dddZdd Zdd Zdd Zdd Z  ZS )JoinedLoaderz[Provide loading behavior for a :class:`.Relationship`
    using joined eager loading.

    rM  c                   rT   r.   rR  rX   r[   r6   r7   rV   /  r]   zJoinedLoader.__init__c                 C  rS  rT  rV  r   r6   r6   r7   r   3  rW  z!JoinedLoader.init_class_attributeNFc	                 K  sP  |j jsdS | jrd|_|| j }d}
|r| |||jnd}|dur0| |||||\}}}n0||jdsM| j	rE|j
d | j	krDdS n|| jrMdS | ||||||||\}}}}d|_||jdd}|durrt|j}
nd}
|| j }tj|| j|||||
| j|d	 tj|j}|r|durtdd	d
 |jD |_dS dS )z@Add a left outer join to the statement that's being constructed.NTFrC  r$   r  )with_polymorphicparentmapperchained_from_outerjoinzDetected unaliased columns when generating joined load.  Make sure to use aliased=True or flat=True when using joined loading with with_polymorphic().c                 S  s   g | ]}|d ur|qS r.   r6   r   r6   r6   r7   r     s    z,JoinedLoader.setup_query.<locals>.<listcomp>)r   r  r:   multi_row_eager_loadersrW   _init_user_defined_eager_procr   $_setup_query_on_user_defined_adapterrJ  rM  rK  rL  rJ   _generate_row_adapterZeager_adding_joinsrF   r&   Zwith_polymorphic_mappersr   r   Z_setup_entity_queryr   ZNONE_SETr   secondary_columnsr   r   )rY   r_   r`   ra   rb   rc   rd   r  r  re   r  user_defined_adapterclausesadd_to_collectionr  Z	has_nonesr6   r6   r7   rg   8  s   

zJoinedLoader.setup_queryc           
      C  s   d|j vrdS |jj}||jdd}|dur|S |j d }|dd  \}}|d urEt|tr5|j|}t	j
t	jj|j||jjdd}n#||jdr`||jd}	t	j
t	jj|	|jjd}n|j|jd }||d| |S )NZeager_from_aliasF user_defined_eager_row_processor)
selectabler   Zlimit_on_entityr  )r   )r   ra   rD   rF   r   r   r   r   aliasr/   
ORMAdapter_TraceAdaptRoleZJOINEDLOAD_USER_DEFINED_ALIASrJ   r   rJ  Z JOINEDLOAD_PATH_WITH_POLYMORPHICZ_polymorphic_adaptersr   )
rY   rb   r_   Ztarget_attributesra   rc   r  Zroot_mapperr3   r  r6   r6   r7   r    sP   


z*JoinedLoader._init_user_defined_eager_procc                 C  sV   | |}|r|r||}||jd| n|r#|}||jd| |j}|||fS )Nr  )Z_get_entity_clauseswrapr   r   primary_columns)rY   ri   r   ra   rc   r  r  r6   r6   r7   r    s"   


z1JoinedLoader._setup_query_on_user_defined_adapterc	                 C  s  | |jdd }	|	r|	}
n"t| j}|jr|j}nd }tj| j|d ur)|j	ddnd ddd}
t|
}|j
d| ftjtjj|| jjdddd}|jsLJ |d urY|j d| jjn| jj}|sad}|j| j||||||||rr|jnd	f	 |j}||jd
| ||||fS )Nr  T)flat)r  r  ry  Zjoinedloader_ormadapterF)r   Zadapt_requiredZallow_label_resolveZanonymize_labels	innerjoinr6   eager_row_processor)rF   r   r&   r   r   r  r/   r#   rJ   Z_anonymous_fromclauseZ_memor  r  ZJOINEDLOAD_MEMOIZED_ADAPTERr   r   rW   r  Zcreate_eager_joinsrB   _create_eager_joinr  r  r   )rY   r_   r   ra   rb   rc   rd   r  r  r  Zto_adaptZinspZalt_selectableZto_adapt_inspr  r  r  r6   r6   r7   r  	  sd   
	
z"JoinedLoader._generate_row_adapterc
              	     sD  |d u r|j }
n|}
|jo|j}d }||jvr?|s?|jr?t|j|j}t|dkr/t	
d|r?|j|d  }|d |}}|d u rI||j}}|j||}|rt|ddrq|j|
 jrc|
n j}t|j j j}nttj j|jdd j j}n j}|jsJ | p| p|dkp|jj}|	}|jd	 j fd
}|r|t fdd|D 7 }|rtj||j|| p|jjp|ot|tj j j |d}n	  |||||}||j|< |j|_!|st" jj#D ]}|
j$j%&|r|r|j'| }|(||j) q jj*r | j+t|j,-t./ jj*7  _+d S d S )Nr   zCan't identify which query entity in which to joined eager load from.   Please use an exact match when specifying the join path.r   r   FTrx  Zunnestedadditional_entity_criteriar6   c                 3  s"    | ]}|j r| jV  qd S r.   )Zpropagate_to_loadersZ_resolve_where_criteriarJ   )r   Zaer   r6   r7   r   	  s    

z2JoinedLoader._create_eager_join.<locals>.<genexpr>isouter
_left_memo_right_memor  )0rJ   r  Z_should_nest_selectableZeager_joinsZfrom_clausesr   Z#find_left_clause_that_matches_givenr  r2  r   r   
setdefaultrf  aliased_inspZ_entity_for_mapperri  rD   r   r0   rW   r/   r#   r   rk  Zrepresents_outer_joinZglobal_attributesrF   r  _ORMJoinr   r(   ZJoin_splice_nested_inner_joinstop_onZ_find_columnsZprimaryjoinZpersist_selectablerf   Zcontains_columnrS   r^   r  r   r  _target_adapterZcopy_and_processr   r   )rY   r_   r`   ra   rc   r  r  r  r  r  r   Zshould_nest_selectableZquery_entity_keyZindexesZclauseZdefault_towrapZtowrapZefmonclauseZattach_on_outsideZextra_join_criteriar  	eagerjoinr   r6   r   r7   r  N	  s   


	






zJoinedLoader._create_eager_joinc           
   	   C  s<  |du rt |tjsJ n1t |tjjr| ||j||||S t |tjs>|d |r<tj||j	|d||d j
|dS d S | ||j||||j}|d u rkd}| ||j||||j}|d u rj|dushJ dd S nd}|r|js{|js{||}	ntj|j||j|j|jd}	ntj||j|j|j|jd}	|j|	_|	S )	NFr  rB  r  z9assertion failed attempting to produce joined eager loadsT)r  r  )r  r  )r   r/   r  r(   r  ZFromGroupingr  elementri  r  rJ   rightr  leftr  r  Z_splice_into_centerr  r  )
rY   ra   Zjoin_objr  r  r  ZsplicingZtarget_joinZright_splicer  r6   r6   r7   r  	  s   

z&JoinedLoader._splice_nested_inner_joinc           	      C  s   |j }|r| |||jnd}|dur(|}|jr!|r!||j}n|jr'|j}n||jd}|d u r5dS | j||r>|S dS )NFr  )r_   r  r   Zcompound_eager_adapterr  rF   rJ   Z_result_has_identity_key)	rY   ri   rj   rc   ra   rb   r_   r  	decoratorr6   r6   r7   _create_eager_adapterF
  s0   
z"JoinedLoader._create_eager_adapterc	              
   C  s   | j j| j jjstd|  | jrd|_|| j	 }	| 
||||	|}
|
durP| j}t|| j|||	| j |
}| jsF| |||| d S | |||| d S | j	d|||||||| d S )Nr  TFrU  )rD   rG   r0   r  r  r   r   r:   Zloaders_require_uniquingrW   r   r   Z_instance_processorrJ   r   r  r  r   rl   )rY   ri   r`   ra   rb   rJ   rj   rc   rk   Zour_pathZeager_adapterr0   	_instancer6   r6   r7   rl   j
  sP   

	z!JoinedLoader.create_row_processorc                   sv    fdd} fdd} fdd}|d  | j|f |d  | j|f jr9|d	  | j|f d S d S )
Nc                   sJ   t | |}t|d}|j | f<  |}|d ur#|| d S d S NZappend_without_eventr   r   r   ZUniqueAppenderrB   )r   r   r   r  result_listinstr  ri   r0   r6   r7   #load_collection_from_joined_new_row
  s   zSJoinedLoader._create_collection_loader.<locals>.load_collection_from_joined_new_rowc                   sh   | fj v rj | f }nt | |}t|d}|j | f<  |}|d ur2|| d S d S r  r  )r   r   r   r  r  r  r  r6   r7   (load_collection_from_joined_existing_row
  s   zXJoinedLoader._create_collection_loader.<locals>.load_collection_from_joined_existing_rowc                       | d S r.   r6   r   r  r6   r7    load_collection_from_joined_exec
     zPJoinedLoader._create_collection_loader.<locals>.load_collection_from_joined_execr   r  r  rB   r0   r  )rY   ri   r0   r  rk   r  r  r  r6   r  r7   r  
  s   z&JoinedLoader._create_collection_loaderc                   st    fdd} fdd} fdd}|d  j|f |d  j|f |jr8|d	  j|f d S d S )
Nc                   s    ||< d S r.   r6   r   )r  r0   r6   r7   load_scalar_from_joined_new_row
  s   zKJoinedLoader._create_scalar_loader.<locals>.load_scalar_from_joined_new_rowc                   s>    |}|v r|| urt d  d S d S ||< d S )Nr  )r   r3  )r   r   r   r  r  r0   rY   r6   r7   $load_scalar_from_joined_existing_row
  s   
zPJoinedLoader._create_scalar_loader.<locals>.load_scalar_from_joined_existing_rowc                   r	  r.   r6   r   r
  r6   r7   load_scalar_from_joined_exec
  r  zHJoinedLoader._create_scalar_loader.<locals>.load_scalar_from_joined_execr   r  r  r  )rY   ri   r0   r  rk   r  r  r  r6   r  r7   r  
  s   z"JoinedLoader._create_scalar_loader)NNFr   )rm   rn   ro   rp   rq   rV   r   rg   r  r  r  r  r  r   rl   r  r  rr   r6   r6   r[   r7   r  $  s(    
w9M !
Y$:/r  Zselectinc                      st   e Zd ZdZedg dZdZ fddZdd Z	d	d
 Z
dd Zdd Zdd Zdd Zdd Zdd Z  ZS )SelectInLoader)rM  	omit_join_parent_alias_query_info_fallback_query_infoZ	queryinfo)load_only_childload_with_joinin_exprpk_colszero_idxchild_lookup_colsi  c                   s   t  || | jj| _| jjtju }| jjd ur| jj| _n| jd}|r,|j	| _n| j
jd j|jdd| j
jd| _| jrU|rN|  | _|  | _d S |  | _d S |  | _d S )NrU  r   TFr   )rU   rV   rW   rM  rI   r
   r   r  r   r   rD   r   r   r   r   _init_for_omit_join_m2or  _init_for_joinr  _init_for_omit_join)rY   rD   rZ   Zis_m2ora  r[   r6   r7   rV     s,   


zSelectInLoader.__init__c                   s   t jjj   fddt D   fddjjD  }}t|dkr1t	j
| }d}n|d }d}dd|||d S )	Nc                 3  s2    | ]}j j|d D ]	}| | fV  qqdS )r6   N)rD   r   rF   )r   r   equivpk_to_fkrY   r6   r7   r   4  s    
z5SelectInLoader._init_for_omit_join.<locals>.<genexpr>c                   s   g | ]
}| v r | qS r6   r6   r   r   )r"  r6   r7   r   :  s    z6SelectInLoader._init_for_omit_join.<locals>.<listcomp>r   Fr   T)r  rW   r   Zlocal_remote_pairsr}  r   rD   r|   r2  r(   tuple_
query_info)rY   r  Zfk_colsr  r  r6   r!  r7   r  0  s   


z"SelectInLoader._init_for_omit_joinc                   sb   | j j}t|dkrtj| }d}n|d }d}| jd  fdd|D }| dd||||S )Nr   Fr   TrU  c                   r  r6   r  r  ra  r6   r7   r   P  r   z:SelectInLoader._init_for_omit_join_m2o.<locals>.<listcomp>)rJ   r|   r2  r(   r$  rW   r   r%  )rY   r  r  r  Zlookup_colsr6   r&  r7   r  F  s   
z&SelectInLoader._init_for_omit_join_m2oc                   sj   t | jj| _t| j  fdd| jjD }t|dkr%tj| }d}n|d }d}| 	dd|||d S )Nc                      g | ]}  |qS r6   _adapt_elementr#  Zpa_inspr6   r7   r   Y      
z1SelectInLoader._init_for_join.<locals>.<listcomp>r   Fr   T)
r#   rD   rH   r  r&   r|   r2  r(   r$  r%  )rY   r  r  r  r6   r*  r7   r  V  s   


zSelectInLoader._init_for_joinc                 C  rS  rT  rV  r   r6   r6   r7   r   d  rW  z#SelectInLoader.init_class_attributec	                 C  s   |j r| ||||||||S | j|||| jd\}	}
}}|
s!d S | jj| j jjs1t	
d|  t|dkrBt|j| jsAd S nt|d | jsMd S |	}|| j }||jdd }|d uret|}n| j}tj||| j| j| j||||	 d S )NrQ  r  r   rB  r  )r   r   rO  rM  rD   rG   r0   r  r  r   r   r2  r/   r  rk  rW   rF   r   r&   r   r   rI  rX  rY  )rY   ri   r`   ra   rb   rJ   rj   rc   rk   r5  rZ  r  rA  Zselectin_pathrN  r  r  r6   r6   r7   rl   i  sh   
	

z#SelectInLoader.create_row_processorc	                   s  |r	j |vr	d S j}	|	jrRtt}
g }j|D ]6\}jtfdd|	j	D }t
j|v r:j}	 nd |vrI|
| |f q||f q|	js\dd |D }
|	j}|	j}|	jsvjrvfdd|D }|}tjdg|R  }| } }tj||gttjddd	}|	js|}n|jtjjj  }|!|"t#$d
} j%j&}|j }| j'u r|j(}n|j(} j'j(} fddt)||D }|r|j*r|t+|, f7 }|d ur|- }|j.| }|/d|i} j0r|j1dd}jj2r=|	js0jj2}jr*fdd|D }|j2| }nfdd}|3|j}|	jrM4|
||	| | d S 5|
|	| | d S )Nc                 3  s$    | ]} j |tjd V  qdS )r  N)r  r   ZPASSIVE_NO_FETCH)r   Zlk)rJ   r   
state_dictr6   r7   r     s    
z0SelectInLoader._load_for_path.<locals>.<genexpr>c                 S  s$   g | ]\}}|j d  ||j|fqS )r   )r0   r  )r   r   rb  r6   r6   r7   r     s    z1SelectInLoader._load_for_path.<locals>.<listcomp>c                   r'  r6   r(  r#  r  r6   r7   r     r+  r  r  )Zcompile_state_pluginZplugin_subject)r  r  r   r  primary_keysc                   s   g | ]
\}}|  |qS r6   )Z'_adapt_cached_option_to_uncached_option)r   Zorig_optZuncached_opt)ri   r6   r7   r   M  s    r  T)r<  c                   r'  r6   r(  r   r-  r6   r7   r   k  s    c                   r  r.   r  r  r   r6   r7   r  r  r  z?SelectInLoader._load_for_path.<locals>._setup_outermost_orderby)6r0   r  r  r  r  r   rD   r  r  r  r   r   r  rB   r  r  r  r   r)  r/   ZBundler#  r+   r$  r*   r   r%  r&  r  r  rf  rW   r  filterZin_r(   r   r_   Zselect_statementr   r*  zipr  r)  r;  r\  r  Z_update_compile_optionsr<  r  r   r  _load_via_child_load_via_parent)rY   ri   ra   r_  r`  r  rb   rA  r  r%  
our_statesnone_statesrb  Zrelated_identr  r  Z
bundle_entZ
bundle_sqlZ
entity_sqlr  r  r5  r  Zcached_optionsZuncached_optionsr  r  r6   )ri   r  rJ   rY   r   r,  r7   rY    s   








	


	
zSelectInLoader._load_for_pathc                   s   | j }t|}|r_|d| j }	|| jd  }dd |jj|d fdd|	D i|d D }
|	D ]*}|
|d }|| D ]\}}}|sK| j|v rKq>|| j	|||sW|n|g q>q2|s	|D ]\}}}|sn| j|v rnqa|| j	||d  qad S )Nr   c                 S  s   i | ]\}}||qS r6   r6   )r   r   r  r6   r6   r7   
<dictcomp>  s    z2SelectInLoader._load_via_child.<locals>.<dictcomp>r.  c                   s   g | ]} j r|d  n|qS re  r  )r   r0   r%  r6   r7   r     rv  z2SelectInLoader._load_via_child.<locals>.<listcomp>r   r  )
r:   sorted
_chunksizer   r0  r   rF   r0   r]  r^  )rY   r3  r4  r%  r  ri   r  r:   Zour_keyschunkdatar0   Zrelated_objr   r   rb  r6   r7  r7   r1    sB   		"zSelectInLoader._load_via_childc                   s$  | j }|rdnd }|r|d| j }|| jd  } fdd|D }	tt}
t|jj|d|	i|d	 dd D ]\}}|
| 
d	d
 |D  q:|D ]>\}}}}|s[| j|v r[qM|
||}|s|rt|dkrrtd|   || j|||d  qM|| j||| qM|sd S d S )Nr6   r   c                   s&   g | ]\}}}} j r|d  n|qS re  r6  )r   r0   r   r,  rb  r7  r6   r7   r     s    
z3SelectInLoader._load_via_parent.<locals>.<listcomp>r.  r8  c                 S  s   | d S rw   r6   r  r6   r6   r7   r8     s    z1SelectInLoader._load_via_parent.<locals>.<lambda>c                 s  r  )r   Nr6   r  r6   r6   r7   r     r  z2SelectInLoader._load_via_parent.<locals>.<genexpr>r   r  )r:   r:  r  r  r   r  r  r   r0  r   r  r0   rF   r2  r   r3  r]  r^  )rY   r3  r%  r  ri   r  r:   Z_empty_resultr;  r.  r<  r   r  r0   r   r,  rb  r  r6   r7  r7   r2    sJ   


zSelectInLoader._load_via_parent)rm   rn   ro   rq   r  
namedtupler%  r:  rV   r  r  r  r   rl   rY  r1  r2  rr   r6   r6   r[   r7   r  
  s"    M T7r  c                   sT   fdd  fdd} fdd}t j| d|dddd	 t j| d
|dddd	 d S )Nc                   sT   |d ur(|j  j kr(|t|}|r(||ur(tjdt|| j f dd|S )NzsInstance %s is already associated with an instance of %s via its %s attribute, and is only allowed a single parent.Zbbf1)code)	r0   	hasparentr   Zinstance_stater   r   r/   Zinstance_strrH   )r   r   oldvalue	initiatorr?  )r3   r6   r7   	_do_check  s   z*single_parent_validator.<locals>._do_checkc                   s    | |d |S r.   r6   )r   r   rA  rB  r6   r7   rB         z'single_parent_validator.<locals>.appendc                   s    | |||S r.   r6   )r   r   r@  rA  rC  r6   r7   set_  rD  z%single_parent_validator.<locals>.set_rB   T)rawretvalr?   r   )r%   listen)r2   r3   rB   rE  r6   )rB  r3   r7   rC     s   rC   )NNNNFN)Qrp   
__future__r   r  r  typingr   r   r   r    r   r	   r   r
   r   r   r   r   r   r   r   r/   baser   r   r   r   r   r   r   ri   r   r   r   r   r   r   r   r   r   r    r!  r!   r"   r#   r%   r   r&   r'   r(   r   r)   Zsql.selectabler*   r+   r,   Zsql.elementsr-   rN   ZColumnPropertyZstrategy_forrQ   Zclass_loggerrs   r   r   r   r   r   r   ZMemoizedSlotsZ
Identifiedr   r:  r@  rP  rd  r  r  rC   r6   r6   r6   r7   <module>   s   	
Q+ZV 0%
&

    )4L`          W   z