o
    g.                     @  s  d dl mZ d dlmZ d dl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' ejrTd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)l1m2Z2 dd*l(m3Z3 dd+l(m4Z4 dd,l(m5Z5 dd-l(m6Z6 dd.l(m7Z7 dd/l(m8Z8 dd0l(m9Z9 dd1l*m:Z: dd2l+m;Z; dd3l+m<Z< dd4l+m=Z= dd5l+m>Z> dd6l+m?Z? dd7l+m@Z@ dd8lmAZA ed9ejBd:ZCed;e	d<ef d:ZDed=ejEd:ZFed>ed:ZGd?d@ ZHdAdB ZIddIdJZJddPdQZKeddWdXZLed<dYdd]dXZLedd`dXZLeddcdXZLeddedXZLeddhdXZLed	dldXZLed
dodXZLeddrdXZLeddvdXZLeddydXZLedd|dXZLedddXZLed<ddddXZLedddXZLedddXZLedddXZLddddddddXZLdddZMdddZNG dd dZOG dd dZPG dd dZQG dd deOZRG dd deOZSde#jTddfdddZUG dd deOZVG dd deOZWG dd deOZXG dd deOZYG dd deOZZG dd deOZ[G dd deSeOZ\G dd de\eOZ]G dd deOZ^G ddĄ deSeOZ_G ddƄ deWeSeOZ`G ddȄ deWeOZaG ddʄ deVeOZbG dd̄ deReOZcG dd΄ deWeOZdG ddЄ deWeSeOejeZfG dd҄ defeOZgG ddԄ defeOZhG ddք deReOZiG dd؄ deOZjG ddڄ deQeOZkG dd܄ dePeWeOZlG ddބ dePeReOZmG dd demZnG dd deOZoG dd de\ZpG dd deYeWeOZqG dd deOZrG dd deWeOZsG dd deVeOZtG dd derZuG dd deOZvG dd deOZwG dd deYeVeOZxG dd dexZyG dd deyZzG dd deYeVeOZ{G dd deVeOZ|G dd deVeOZ}i Z~eeD ]&ZeeeZedredd Zee v re e eZee~e< qese~ej ZeeeefD ]Zee~eje < qdS dS (      )annotationsN)Any)Callable)cast)Dict)Iterable)Iterator)List)NoReturn)Optional)overload)Sequence)Tuple)Type)TYPE_CHECKING)TypeVar)Union   )roles)visitors)is_from_clause)ExecutableOption)Options)HasCacheKey)	Visitable   )exc)
inspection)util)Literal)elements)lambdas)schema)
selectable)_ColumnExpressionArgument)_ColumnsClauseArgument)_DDLColumnArgument)_DMLTableArgument)_FromClauseArgument)_DMLTableElement)BindParameter)ClauseElement)ColumnClause)ColumnElement)NamedColumn)SQLCoreOperations)
TextClause)Column)_ColumnsClauseElement)_JoinTargetProtocol)
FromClause)HasCTE)
SelectBase)Subquery)_TraverseCallableType_SR)bound_F._StringOnlyR_Tc                 C  s   t | ttjf ot| d S )zhReturn whether or not the element is a "literal" in the context
    of a SQL expression construct.

    __clause_element__)
isinstancer   r"   SchemaEventTargethasattr)element rC   Z/var/www/html/ecg_monitoring/venv/lib/python3.10/site-packages/sqlalchemy/sql/coercions.py_is_literalN   s   
rE   c                 C  sr   t | tjrt | ts| D ]	}t|s dS qdS t | ttjtt	t
jjf o8t| d o8t | t p8t| t S )a  Return whether or not the element is a "literal" in the context
    of a SQL expression construct.

    does a deeper more esoteric check than _is_literal.   is used
    for lambda elements that have to distinguish values that would
    be bound vs. not without any context.

    FTr>   )r?   collections_abcr   str_deep_is_literalr   r"   r@   r   r   r   langhelperssymbolrA   type
issubclass)rB   elemrC   rC   rD   rH   Z   s,   



rH   	paramnamerG   meth_rst	param_rstreturnCallable[[_F], _F]c                 C  s   t | d||f S )Nz.. warning:: The %s argument to %s can be passed as a Python string argument, which will be treated as **trusted SQL text** and rendered as given.  **DO NOT PASS UNTRUSTED INPUT TO THIS PARAMETER**.)r   add_parameter_text)rN   rO   rP   rC   rC   rD   _document_text_coercion   s   rT   attrnamefnnameargs+Union[Sequence[_T], Sequence[Sequence[_T]]]Sequence[_T]c                 C  sb   |r,t |d tttfr,t|dkr,t |d tr%td|  d| dtd|d S td|S )Nr   r   zThe "z" argument to zt(), when referring to a sequence of items, is now passed as a series of positional elements, rather than as a list. rY   )r?   listsetdictlenr   ArgumentErrorr   )rU   rV   rW   rC   rC   rD   !_expression_collection_was_a_list   s   $
r_   roleType[roles.TruncatedLabelRole]rB   r   kwc                 K     d S NrC   r`   rB   rb   rC   rC   rD   expect      rf   as_keyType[roles.DMLColumnRole]ri   Literal[True]c                K  rc   rd   rC   )r`   rB   ri   rb   rC   rC   rD   rf         Type[roles.LiteralValueRole]BindParameter[Any]c                 K  rc   rd   rC   re   rC   rC   rD   rf      rg   !Type[roles.DDLReferredColumnRole]Union[Column[Any], str]c                 K  rc   rd   rC   re   rC   rC   rD   rf      rg   #Type[roles.DDLConstraintColumnRole]c                 K  rc   rd   rC   re   rC   rC   rD   rf      rg   Type[roles.StatementOptionRole]%Union[ColumnElement[Any], TextClause]c                 K  rc   rd   rC   re   rC   rC   rD   rf      rg   &Type[roles.LabeledColumnExprRole[Any]]_ColumnExpressionArgument[_T]NamedColumn[_T]c                 K  rc   rd   rC   re   rC   rC   rD   rf      rg   gUnion[Type[roles.ExpressionElementRole[Any]], Type[roles.LimitOffsetRole], Type[roles.WhereHavingRole]]ColumnElement[_T]c                 K  rc   rd   rC   re   rC   rC   rD   rf      s   	Union[Type[roles.ExpressionElementRole[Any]], Type[roles.LimitOffsetRole], Type[roles.WhereHavingRole], Type[roles.OnClauseRole], Type[roles.ColumnArgumentRole]]ColumnElement[Any]c                 K  rc   rd   rC   re   rC   rC   rD   rf      s   Type[roles.DMLTableRole]r'   r)   c                 K  rc   rd   rC   re   rC   rC   rD   rf      rg   Type[roles.HasCTERole]r5   c                 K  rc   rd   rC   re   rC   rC   rD   rf      rg   Type[roles.SelectStatementRole]r6   c                 K  rc   rd   rC   re   rC   rC   rD   rf     rg   Type[roles.FromClauseRole]r(   r4   c                 K  rc   rd   rC   re   rC   rC   rD   rf     rg   )explicit_subqueryr   r7   c                K  rc   rd   rC   )r`   rB   r   rb   rC   rC   rD   rf     rl   Type[roles.ColumnsClauseRole]_ColumnsClauseArgument[Any]r2   c                 K  rc   rd   rC   re   rC   rC   rD   rf      rg   Type[roles.JoinTargetRole]r3   c                 K  rc   rd   rC   re   rC   rC   rD   rf   (  rg   	Type[_SR]c                 K  rc   rd   rC   re   rC   rC   rD   rf   1  rg   F)apply_propagate_attrsargnamepost_inspectdisable_inspectionr   Optional[ClauseElement]r   Optional[str]r   boolr   c                K  s  | j rt|rt|drtj|| tjdi ||dS t|  }|}t|tj	t
jt
jtjfsd }	|jr=|j|fi |}	n}|}d}
|jrQt|| rQt|drQd}
nt|drid}
t|ddsc| }nnt|dsV|
s|jr|stj|dd}|d ur|r|j z| }	W n ty   ||| Y nw |	d u r|j|fd|i|}	n|}	nt|tjr|jdi |}	n|}	|d urtjrt|	ttfsJ |jst|	d	d r|	j|_|j|	j j!v r|j"r|j"|	f||d
|}	|	S |j#||	fd|i|S )N__code__)r   Fr>   Tis_clause_element)raiseerrr   _propagate_attrs)r   original_elementrC   )$allows_lambdacallablerA   r!   LambdaElementLambdaOptions_impl_lookupr?   r    CompilerElementr"   
SchemaItemFetchedValue	PyWrapper_resolve_literal_only_literal_coercion$_skip_clauseelement_for_target_matchgetattrr>   _use_inspectionr   inspect_post_inspectAttributeError_raise_for_expected_sa__py_wrapper_literaltypingr   r/   r+   r   _role_class	__class____mro___post_coercion_implicit_coercions)r`   rB   r   r   r   r   rb   implr   resolvedr   insprC   rC   rD   rf   9  s   			



c                 K  s"   | dd  t| |fddi|S )Nri   T)poprf   re   rC   rC   rD   expect_as_key  s   r   expressionsIterable[_DDLColumnArgument]wIterator[Tuple[Union[str, Column[Any]], Optional[ColumnClause[Any]], Optional[str], Optional[Union[Column[Any], str]]]]c           	      c  s    |D ]?}d }d }t | |}t|trt|tsJ | }}ng }|j}t|i d|i |r3|d }|d ur9|n|}||||fV  qd S )Ncolumnr   )rf   r?   rG   appendr   traverse)	r`   r   exprstrnamer   r   cols
col_appendadd_elementrC   rC   rD    expect_col_expression_collection  s    


r   c                   @  s^   e Zd ZU dZdd ZdZded< dZdZdd	 Z		ddddZ
		ddddddddZdS )RoleImpl)r   namer   c                 K  s   t  rd   )NotImplementedErrorselfrB   rb   rC   rC   rD   r     s   zRoleImpl._literal_coercionNr   r   Fc                 C  s    || _ |j| _t|tj| _d S rd   )r   
_role_namer   rL   r   UsesInspectionr   )r   
role_classrC   rC   rD   __init__  s   zRoleImpl.__init__rB   r   r   r   rb   rQ   c                 K  s   |  ||| d S rd   r   r   rB   r   r   rb   rC   rC   rD   r     s   zRoleImpl._implicit_coercionsadvicecodeerrOptional[Any]r   r   r   Optional[Exception]r
   c          
      K  sj   |d ur||urd||f }nt |}|rd| j||f }	nd| j|f }	|r-|	d| 7 }	tj|	|d|)Nz!%r object resolved from %r objectz$%s expected for argument %r; got %s.z%s expected, got %s. )r   )reprr   r   r^   )
r   rB   r   r   r   r   r   rb   gotmsgrC   rC   rD   r     s   zRoleImpl._raise_for_expectedrd   
rB   r   r   r   r   r   rb   r   rQ   r   NNrB   r   r   r   r   r   r   r   r   r   r   r   rb   r   rQ   r
   )__name__
__module____qualname__	__slots__r   r   __annotations__r   r   r   r   r   rC   rC   rC   rD   r     s    
 	r   c                   @     e Zd ZdZdd ZdS )_DeannotaterC   c                 K  s   ddl m} ||S )Nr   )_deep_deannotate)r   r   )r   r   rb   r   rC   rC   rD   r     s   z_Deannotate._post_coercionNr   r   r   r   r   rC   rC   rC   rD   r   	      r   c                   @  s   e Zd ZdZdZdS )_StringOnlyrC   TN)r   r   r   r   r   rC   rC   rC   rD   r     s    r   c                   @  s"   e Zd ZdZdddZdd ZdS )_ReturnsStringKeyrC   Nc                 K      t |tr|S | ||| d S rd   r?   rG   r   r   rC   rC   rD   r     s   
z%_ReturnsStringKey._implicit_coercionsc                 K     |S rd   rC   r   rC   rC   rD   r   !     z#_ReturnsStringKey._literal_coercionrd   r   r   r   r   r   r   rC   rC   rC   rD   r     s    
r   c                   @  s"   e Zd ZdZdd ZdddZdS )_ColumnCoercionsrC   c                 C  s   t d d S )Nz|implicitly coercing SELECT object to scalar subquery; please use the .scalar_subquery() method to produce a scalar subquery.)r   warn)r   rC   rC   rD   "_warn_for_scalar_subquery_coercion(  s   z3_ColumnCoercions._warn_for_scalar_subquery_coercionNc                 K  s   |}t |dds| ||| d S |jr|   | S |jr.t|tjr.|   |j	 S | j
jr7|jr7|S | ||| d S )Nr   F)r   r   _is_select_baser   scalar_subquery_is_from_clauser?   r#   r7   rB   r   r   _is_lambda_element)r   rB   r   r   rb   r   rC   rC   rD   r   /  s   
z$_ColumnCoercions._implicit_coercionsrd   )r   r   r   r   r   r   rC   rC   rC   rD   r   %  s    r   exc_clsType[exc.SQLAlchemyError]extrar   r   r
   c                 C  s6   |dt | |rd|f nd|rd| ndd |)Nzc%(extra)sTextual SQL expression %(expr)r %(argname)sshould be explicitly declared as text(%(expr)r)for argument %s z%s )r   r   r   )r   ellipses_string)rB   r   r   r   r   rC   rC   rD   _no_text_coercionA  s   r   c                   @     e Zd ZdZddddZdS )_NoTextCoercionrC   Nr   c                K  s6   t |trttj| jrt|| d S | || d S rd   )r?   rG   rL   r    r0   r   r   r   r   rB   r   rb   rC   rC   rD   r   V  s
   z!_NoTextCoercion._literal_coercionr   r   r   r   r   rC   rC   rC   rD   r   S      r   c                   @  s4   e Zd ZdZdZdZdZd	ddZddddZdS )
_CoerceLiteralsrC   FNc                 C  
   t ||S rd   r   r   rB   r   rC   rC   rD   _text_coercione     
z_CoerceLiterals._text_coercionr   c                K  s   t |tr| jr|dkrtjdddS | j||fi |S | jr8|d u r(t S |du r0t S |du r8t	 S | j
rJt |tjrJtjt|ddS | || d S )N*T)
is_literalF)r?   rG   _coerce_starr    r,   r   _coerce_constsNullFalse_True__coerce_numericsnumbersNumberr   r   rC   rC   rD   r   h  s   
z!_CoerceLiterals._literal_coercionrd   )	r   r   r   r   r   r   r  r   r   rC   rC   rC   rD   r   _  s    
r   c                   @  s,   e Zd ZdZ	d	dddddZdd ZdS )
LiteralValueImplTNF)type_literal_executec                K  s4   t |s| j|f||d| tjd ||d|dS )N)r   r   T)r  uniquer	  )rE   r   r    r*   )r   rB   r   r   r  r	  rb   rC   rC   rD   r     s   
z$LiteralValueImpl._implicit_coercionsc                 K  r   rd   rC   r   rC   rC   rD   r     r   z"LiteralValueImpl._literal_coercionrd   )r   r   r   r   r   r   rC   rC   rC   rD   r  }  s    r  c                      s2   e Zd ZdZ		dddddd fddZ  ZS )_SelectIsNotFromrC   Nr   rB   r   r   r   r   r   r   r   r   r   rb   rQ   r
   c                  sb   |st |tjst |tjrd|d ur|jn|f }d}nd }t j|f|||||d| J )NzETo create a FROM clause from a %s object, use the .subquery() method.89ve)r   r   r   r   r   )r?   r   SelectStatementRoler   superr   )r   rB   r   r   r   r   r   rb   r   rC   rD   r     s0   


z$_SelectIsNotFrom._raise_for_expectedr   r   r   r   r   r   r   __classcell__rC   rC   r  rD   r    s    r  c                   @  &   e Zd ZdZ	ddd
dZdd ZdS )HasCacheKeyImplrC   NrB   r   r   r   r   rb   rQ   c                 K  r   rd   )r?   r   r   r   rC   rC   rD   r        
z#HasCacheKeyImpl._implicit_coercionsc                 K  r   rd   rC   r   rC   rC   rD   r     r   z!HasCacheKeyImpl._literal_coercionrd   r   r   rC   rC   rC   rD   r    
    r  c                   @  r  )ExecutableOptionImplrC   NrB   r   r   r   r   rb   rQ   c                 K  r   rd   )r?   r   r   r   rC   rC   rD   r     r  z(ExecutableOptionImpl._implicit_coercionsc                 K  r   rd   rC   r   rC   rC   rD   r     r   z&ExecutableOptionImpl._literal_coercionrd   r   r   rC   rC   rC   rD   r    r  r  c                      s4   e Zd ZdZddddddZd	 fdd	Z  ZS )
ExpressionElementImplrC   NF)r   r  is_crudc             
   K  sp   |d u r|s|d u s|j st S ztj|||d|dW S  tjy7 } z| j||d W Y d }~d S d }~ww )NT)r
  _is_crudr   )should_evaluate_noner    r  r*   r   r^   r   )r   rB   r   r  r  rb   r   rC   rC   rD   r     s   
z'ExpressionElementImpl._literal_coercionc                   sD   t |tjr	d}nt |tjrd}nd }t j|f|||d|S )NzTTo create a column expression from a VALUES clause, use the .scalar_values() method.z`To create a column expression from a FROM clause row as a whole, use the .table_valued() method.r   r   r   )r?   r#   Valuesr   AnonymizedFromClauseRoler  r   r   rB   r   r   rb   r   r  rC   rD   r     s   z)ExpressionElementImpl._raise_for_expectedr   )r   r   r   r   r   r   r  rC   rC   r  rD   r    s
    r  c                   @  s.   e Zd ZdZdddddZddddZdS )	BinaryElementImplrC   N)bindparam_typer   c             
   K  sJ   z	|j |||dW S  tjy$ } z| j||d W Y d }~d S d }~ww )N)r  r  )_bind_paramr   r^   r   )r   rB   r   operatorr!  r   rb   r   rC   rC   rD   r     s   
z#BinaryElementImpl._literal_coercion)r!  c                K  s,   |j jr|j js||d ur|n|j }|S rd   )rK   _isnull_with_binary_element_type)r   r   r   r!  rb   rC   rC   rD   r   '  s
   z BinaryElementImpl._post_coercion)r   r   r   r   r   r   rC   rC   rC   rD   r     s    r   c                   @  s@   e Zd ZdZ	ddd
dZdd Zeddd Zdd Z	dS )InElementImplrC   NrB   r   r   r   r   rb   rQ   c                 K  sj   |j r,t|tjr|jjr| | | j|jfi |S | | | j| fi |S | 	||| d S rd   )
r   r?   r#   AliasrB   r   _warn_for_implicit_coercionr   selectr   r   rC   rC   rD   r   2  s   


z!InElementImpl._implicit_coercionsc                 C  s   t d|jj  d S )Nz_Coercing %s object into a select() for use in IN(); please pass a select() construct explicitly)r   r   r   r   )r   rM   rC   rC   rD   r(  F  s
   z)InElementImpl._warn_for_implicit_coercionzsqlalchemy.sql.elementsc                  s   t |rRi t|}|D ],}t|s/t|t jjjs*t|ds*| j	|fi | q||< q|d u r9t
 |< qrJt
j fdd|D  S  j|ddS | j	|fi | d S )Nr>   c                   s(   g | ]}|v r| n  |qS rC   )r"  ).0or   non_literal_expressionsr#  rC   rD   
<listcomp>c  s    
z3InElementImpl._literal_coercion.<locals>.<listcomp>T)	expanding)r   is_non_string_iterablerZ   rE   r?   	preloadedsql_elementsr-   rA   r   r    r  
ClauseListr"  )r   rB   r   r#  rb   r+  rC   r,  rD   r   M  s0   


zInElementImpl._literal_coercionc                K  sx   |j r| S t|tjrt|jdkrJ |j|dS t|tjr0|j	dd}d|_
||_|S t|tjr:| S |S )Nr   )againstT)maintain_key)r   r   r?   r    r3  r]   clauses
self_groupr*   _cloner/  	expand_opr#   r  scalar_values)r   rB   r   r#  rb   rC   rC   rD   r   r  s   zInElementImpl._post_coercionrd   r   )
r   r   r   r   r   r(  r   preload_moduler   r   rC   rC   rC   rD   r&  /  s    
$r&  c                   @  s*   e Zd ZdZdZdd ZddddZdS )	OnClauseImplrC   Tc                 K  s   |  | d S rd   r   r   rC   rC   rD   r     s   zOnClauseImpl._literal_coercionN)r   c                K  s   t |tjr|S |S rd   )r?   r   JoinTargetRole)r   r   r   rb   rC   rC   rD   r     s   zOnClauseImpl._post_coercion)r   r   r   r   r   r   r   rC   rC   rC   rD   r<    s
    r<  c                   @     e Zd ZdZdZdddZdS )WhereHavingImplrC   TNc                 C  r   rd   r   r   rC   rC   rD   r     r   zWhereHavingImpl._text_coercionrd   r   r   r   r   r   r   rC   rC   rC   rD   r?        r?  c                   @  r>  )StatementOptionImplrC   TNc                 C  
   t |S rd   r    r0   r   rC   rC   rD   r     r   z"StatementOptionImpl._text_coercionrd   r@  rC   rC   rC   rD   rB    rA  rB  c                   @     e Zd ZdZdS )ColumnArgumentImplrC   Nr   r   r   r   rC   rC   rC   rD   rF        rF  c                   @  rE  )ColumnArgumentOrKeyImplrC   NrG  rC   rC   rC   rD   rI    rH  rI  c                   @  s   e Zd ZdZdddZdS )StrAsPlainColumnImplrC   Nc                 C  rC  rd   )r    r,   r   rC   rC   rD   r     r   z#StrAsPlainColumnImpl._text_coercionrd   )r   r   r   r   r   rC   rC   rC   rD   rJ    s    rJ  c                   @  r>  )ByOfImplrC   TNc                 C  rC  rd   )r    _textual_label_referencer   rC   rC   rD   r     r   zByOfImpl._text_coercionrd   r@  rC   rC   rC   rD   rK    rA  rK  c                   @  r   )OrderByImplrC   c                 K  s$   t || jr|jd urt|S |S rd   )r?   r   _order_by_label_elementr    _label_reference)r   r   rb   rC   rC   rD   r     s
   


zOrderByImpl._post_coercionNr   rC   rC   rC   rD   rM    r   rM  c                   @     e Zd ZdZ	ddd
dZdS )GroupByImplrC   NrB   r   r   r   r   rb   rQ   c                 K  s   t |r
tj|j S |S rd   )r   r    r3  cr   rC   rC   rD   r     s   zGroupByImpl._implicit_coercionsrd   r   r   r   r   r   r   rC   rC   rC   rD   rQ        rQ  c                   @  s   e Zd ZdZddddZdS )DMLColumnImplrC   Frh   c                K  s   |r|j S |S rd   )key)r   rB   ri   rb   rC   rC   rD   r     s   zDMLColumnImpl._post_coercionNr   rC   rC   rC   rD   rU    r   rU  c                   @  r   )ConstExprImplrC   Nr   c                K  s@   |d u rt  S |du rt  S |du rt  S | || d S )NFT)r    r  r  r  r   r   rC   rC   rD   r     s   zConstExprImpl._literal_coercionr   rC   rC   rC   rD   rW    r   rW  c                   @  r  )TruncatedLabelImplrC   NrB   r   r   r   r   rb   rQ   c                 K  s    t |tr|S | ||| d S rd   r   r   rC   rC   rD   r     r  z&TruncatedLabelImpl._implicit_coercionsc                 K  s   t |tjr|S t|S )zcoerce the given value to :class:`._truncated_label`.

        Existing :class:`._truncated_label` and
        :class:`._anonymous_label` objects are passed
        unchanged.
        )r?   r    _truncated_labelr   rC   rC   rD   r     s   
z$TruncatedLabelImpl._literal_coercionrd   r   r   rC   rC   rC   rD   rX    r  rX  c                   @  r>  )DDLExpressionImplrC   TNc                 C  rC  rd   rD  r   rC   rC   rD   r     s   
z DDLExpressionImpl._text_coercionrd   r@  rC   rC   rC   rD   rZ    rA  rZ  c                   @  rE  )DDLConstraintColumnImplrC   NrG  rC   rC   rC   rD   r[  #  rH  r[  c                   @  rE  )DDLReferredColumnImplrC   NrG  rC   rC   rC   rD   r\  '  rH  r\  c                   @  r  )LimitOffsetImplrC   NrB   r   r   r   r   rb   rQ   c                 K  s   |d u rd S |  ||| d S rd   r   r   rC   rC   rD   r   .  s   z#LimitOffsetImpl._implicit_coercionsc                K  s(   |d u rd S t |}tj|||ddS )NT)r  r
  )r   asintr#   _OffsetLimitParam)r   rB   r   r  rb   valuerC   rC   rD   r   :  s   
z!LimitOffsetImpl._literal_coercionrd   r   r   rC   rC   rC   rD   r]  +  r  r]  c                      s&   e Zd ZdZ	dd fd
dZ  ZS )LabeledColumnExprImplrC   NrB   r   r   r   r   rb   rQ   c                   sX   t |tjr|d S t j||fd|i|}t |tjr#|d S | ||| d S Nr   )r?   r   ExpressionElementRolelabelr  r   r   )r   rB   r   r   rb   newr  rC   rD   r   I  s   

z)LabeledColumnExprImpl._implicit_coercionsrd   r   )r   r   r   r   r   r  rC   rC   r  rD   ra  F  s    ra  c                      sN   e Zd ZdZdZdZdZedej	Z
	d
dd fddZddd	Z  ZS )ColumnsClauseImplrC   Tz^\w\S*$N)r   c                  sF   |st |trdddd |D  d}t j|f|||d|S )NzDid you mean to say select(z, c                 s  s    | ]}t |V  qd S rd   )r   )r*  erC   rC   rD   	<genexpr>k  s    z8ColumnsClauseImpl._raise_for_expected.<locals>.<genexpr>z)?r  )r?   rZ   joinr  r   )r   rB   r   r   r   rb   r  rC   rD   r   e  s   z%ColumnsClauseImpl._raise_for_expectedc                 C  sH   t |}| j| }tdt||rd|f nd|rdndd )NzTextual column expression %(column)r %(argname)sshould be explicitly declared with text(%(column)r), or use %(literal_column)s(%(column)r) for more specificityr   r   literal_columnr   )r   r   rj  )rG   _guess_straight_columnmatchr   r^   r   r   )r   rB   r   guess_is_literalrC   rC   rD   r   r  s   
z ColumnsClauseImpl._text_coercionr   rd   )r   r   r   r   r   r  r   recompileIrk  r   r   r  rC   rC   r  rD   rf  \  s    rf  c                   @  rE  )ReturnsRowsImplrC   NrG  rC   rC   rC   rD   rq    rH  rq  c                      s4   e Zd ZdZddddZ	dd fddZ  ZS )StatementImplrC   Nr   c                K  sH   ||ur"t |ts"z|j W |S  ty!   td| d Y |S w |S )Na  Object %r should not be used directly in a SQL statement context, such as passing to methods such as session.execute().  This usage will be disallowed in a future release.  Please use Core select() / update() / delete() etc. with Session.execute() and other statement execution methods.1.4)r?   rG   _execute_on_connectionr   r   warn_deprecated)r   r   r   r   rb   rC   rC   rD   r     s    
zStatementImpl._post_coercionrB   r   r   r   r   rb   rQ   c                   s$   |j r|S t j||fd|i|S rb  )r   r  r   r   r  rC   rD   r     s   z!StatementImpl._implicit_coercionsrd   r   )r   r   r   r   r   r   r  rC   rC   r  rD   rr    s    rr  c                   @  rP  )SelectStatementImplrC   NrB   r   r   r   r   rb   rQ   c                 K  s    |j r| S | ||| d S rd   )_is_text_clausecolumnsr   r   rC   rC   rD   r     s   z'SelectStatementImpl._implicit_coercionsrd   r   rS  rC   rC   rC   rD   rv    rT  rv  c                   @  rE  )
HasCTEImplrC   NrG  rC   rC   rC   rD   ry    rH  ry  c                   @  rE  )	IsCTEImplrC   NrG  rC   rC   rC   rD   rz    rH  rz  c                   @  s6   e Zd ZdZdZddddZ	ddddddZdS )JoinTargetImplrC   TNr   c                K  s   |  || d S rd   r   r   rC   rC   rD   r     s   z JoinTargetImpl._literal_coercionF)legacyrB   r   r   r   r   r|  r   rb   rQ   c                K  s>   t |tjr|S |r|jrtjddd |S | ||| d S NzImplicit coercion of SELECT and textual SELECT constructs into FROM clauses is deprecated; please call .subquery() on any Core select or ORM Query object in order to produce a subquery object.rs  )version)r?   r   r=  r   r   ru  r   )r   rB   r   r   r|  rb   rC   rC   rD   r     s   	
z"JoinTargetImpl._implicit_coercionsrd   )rB   r   r   r   r   r   r|  r   rb   r   rQ   r   )r   r   r   r   r   r   r   rC   rC   rC   rD   r{    s    r{  c                   @  s4   e Zd ZdZ	dddddddZddddZdS )FromClauseImplrC   NFT)r   allow_selectrB   r   r   r   r   r   r   r  rb   rQ   c                K  sJ   |j r|r	| S |rtjddd |jS d S |jr|S | ||| d S r}  )r   subqueryr   ru  _implicit_subqueryrw  r   )r   rB   r   r   r   r  rb   rC   rC   rD   r     s   
	z"FromClauseImpl._implicit_coercions)
deannotatec                K  s   |r|  S |S rd   )_deannotate)r   rB   r  rb   rC   rC   rD   r     s   zFromClauseImpl._post_coercionrd   )rB   r   r   r   r   r   r   r   r  r   rb   r   rQ   r   )r   r   r   r   r   r   rC   rC   rC   rD   r    s    r  c                   @  s$   e Zd ZdZ	ddddddZdS )StrictFromClauseImplrC   NF)r  rB   r   r   r   r   r  r   rb   rQ   c                K  s0   |j r|rtjddd |jS | ||| d S r}  )r   r   ru  r  r   )r   rB   r   r   r  rb   rC   rC   rD   r     s   
	z(StrictFromClauseImpl._implicit_coercionsrd   )rB   r   r   r   r   r   r  r   rb   r   rQ   r   rS  rC   rC   rC   rD   r    s    r  c                   @  s    e Zd ZdZdddddZdS )AnonymizedFromClauseImplrC   FN)flatr   c                K  s   |d u sJ |j |dS )N)r  )_anonymous_fromclause)r   rB   r  r   rb   rC   rC   rD   r   3  s   z'AnonymizedFromClauseImpl._post_coercionr   rC   rC   rC   rD   r  0  s    r  c                   @  r   )DMLTableImplrC   c                 K  s   d|j v r
|j d S |S )N	dml_table)_annotationsr   rC   rC   rD   r   <  s   

zDMLTableImpl._post_coercionNr   rC   rC   rC   rD   r  9  r   r  c                   @  rP  )DMLSelectImplrC   NrB   r   r   r   r   rb   rQ   c                 K  s:   |j rt|tjr|jjr|jS | S | ||| d S rd   )r   r?   r#   r'  rB   r   r)  r   r   rC   rC   rD   r   F  s   
z!DMLSelectImpl._implicit_coercionsrd   r   rS  rC   rC   rC   rD   r  C  rT  r  c                      s"   e Zd ZdZd fdd	Z  ZS )CompoundElementImplrC   Nc                   s>   t |tjr|jrd}nd}nd }t j|f|||d|S )NzFUse the plain select() object without calling .subquery() or .alias().z9To SELECT from any FROM clause, use the .select() method.r  )r?   r   FromClauseRole_is_subqueryr  r   r  r  rC   rD   r   \  s   z'CompoundElementImpl._raise_for_expectedr   r  rC   rC   r  rD   r  Y  s    r  RoleImpl)rN   rG   rO   rG   rP   rG   rQ   rR   )rU   rG   rV   rG   rW   rX   rQ   rY   )r`   ra   rB   r   rb   r   rQ   rG   )
r`   rj   rB   r   ri   rk   rb   r   rQ   rG   )r`   rm   rB   r   rb   r   rQ   rn   )r`   ro   rB   r   rb   r   rQ   rp   )r`   rq   rB   r   rb   r   rQ   rp   )r`   rr   rB   r   rb   r   rQ   rs   )r`   rt   rB   ru   rb   r   rQ   rv   )r`   rw   rB   ru   rb   r   rQ   rx   )r`   ry   rB   r   rb   r   rQ   rz   )r`   r{   rB   r'   rb   r   rQ   r)   )r`   r|   rB   r5   rb   r   rQ   r5   )r`   r}   rB   r6   rb   r   rQ   r6   )r`   r~   rB   r(   rb   r   rQ   r4   )
r`   r~   rB   r6   r   rk   rb   r   rQ   r7   )r`   r   rB   r   rb   r   rQ   r2   )r`   r   rB   r3   rb   r   rQ   r3   )r`   r   rB   r   rb   r   rQ   r   )r`   r   rB   r   r   r   r   r   r   r   r   r   rb   r   rQ   r   )r`   rj   rB   r   rb   r   rQ   rG   )r`   rq   r   r   rQ   r   )rB   r   r   r   r   r   r   r   r   r   rQ   r
   )
__future__r   collections.abcabcrF   r  rn  r   r   r   r   r   r   r   r	   r
   r   r   r   r   r   r   r   r   r   r   r   _typingr   baser   r   	cache_keyr   r   r   r   r   util.typingr   r    r!   r"   r#   r$   r%   r&   r'   r(   dmlr)   r*   r+   r,   r-   r.   r/   r0   r1   r2   r3   r4   r5   r6   r7   r8   SQLRoler9   r;   
StringRoler<   r=   rE   rH   rT   r_   rf   r   r   r   r   r   r   r   r^   r   r   r   r  r  r  r  r  r   r&  r<  r?  rB  rF  rI  rJ  ByOfRolerK  rM  rQ  rU  rW  rX  rZ  r[  r\  r]  ra  rf  rq  rr  rv  ry  rz  r{  r  r  r  r  r  r  r   dirr   r   clsendswithreplaceglobalsr   rc  ee_implintr   rG   floatpy_typerC   rC   rC   rD   <module>   sZ  &		t7	)+X			
)*'%	


