o
    Ti                     @   s^   d Z ddlmZ ddlmZmZ G dd deZG dd dZG dd	 d	Z	G d
d dZ
dS )z]
Useful auxiliary data structures for query construction. Not useful outside
the SQL domain.
    )FullResultSet)INNERLOUTERc                   @   s   e Zd ZdZdd ZdS )	MultiJoinz
    Used by join construction code to indicate the point at which a
    multi-valued join was attempted (if the caller wants to treat that
    exceptionally).
    c                 C      || _ || _d S N)levelZnames_with_path)selfZ	names_posZpath_with_names r
   c/var/www/html/evchargy.com/venv/lib/python3.10/site-packages/django/db/models/sql/datastructures.py__init__   s   
zMultiJoin.__init__N)__name__
__module____qualname____doc__r   r
   r
   r
   r   r   	   s    r   c                   @   s   e Zd ZdS )EmptyN)r   r   r   r
   r
   r
   r   r      s    r   c                   @   s`   e Zd ZdZ	dddZdd Zdd Zed	d
 Zdd Z	dd Z
dd Zdd Zdd ZdS )Joina  
    Used by sql.Query and sql.SQLCompiler to generate JOIN clauses into the
    FROM entry. For example, the SQL generated could be
        LEFT OUTER JOIN "sometable" T1
        ON ("othertable"."sometable_id" = "sometable"."id")

    This class is primarily used in Query.alias_map. All entries in alias_map
    must be Join compatible by providing the following attributes and methods:
        - table_name (string)
        - table_alias (possible alias for the table, can be None)
        - join_type (can be None for those entries that aren't joined from
          anything)
        - parent_alias (which table is this join's parent, can be None similarly
          to join_type)
        - as_sql()
        - relabeled_clone()
    Nc                 C   s8   || _ || _|| _|| _| | _|| _|| _|| _d S r   )	
table_nameparent_aliastable_alias	join_typeZget_joining_columns	join_cols
join_fieldnullablefiltered_relation)r	   r   r   r   r   r   r   r   r
   r
   r   r   -   s   

zJoin.__init__c              	   C   s8  g }g }|j }|jj}| jD ]\}}|d|| j|||| j||f  q| j| j| j}	|	rF|	|	\}
}|d|
  |
| | jriz
|	| j\}
}W n	 ty\   Y nw |d|
  |
| |szt| jd| j}td|j d|}| j| jkrdnd| j }d| j|| j||f }||fS )	z
        Generate the full
           LEFT OUTER JOIN sometable ON sometable.somecol = othertable.othercol, params
        clause for this join.
        z%s.%s = %s.%sz(%s)fieldzaJoin generated an empty ON clause. %s did not yield either joining columns or extra restrictions.z AND   %sz%s %s%s ON (%s))quote_name_unless_aliasopsZ
quote_namer   appendr   r   r   Zget_extra_restrictioncompileextendr   r   getattr
ValueError	__class__joinr   r   )r	   compiler
connectionZjoin_conditionsparamsqnZqn2Zlhs_colZrhs_colZ
extra_condZ	extra_sqlZextra_paramsZdeclared_fieldZon_clause_sql	alias_strsqlr
   r
   r   as_sqlG   s\   


zJoin.as_sqlc              	      sr     | j| j}  | j| j}| jd ur'| j } fdd| jjD |_nd }| j| j||| j| j	| j
|dS )Nc                    s   g | ]}  ||qS r
   )get).0p
change_mapr
   r   
<listcomp>   s    z(Join.relabeled_clone.<locals>.<listcomp>)r   )r.   r   r   r   clonepathr%   r   r   r   r   )r	   r2   Znew_parent_aliasZnew_table_aliasr   r
   r1   r   relabeled_clone   s"   



zJoin.relabeled_clonec                 C   s   | j | j| j| j| jfS r   )r%   r   r   r   r   r	   r
   r
   r   identity   s   zJoin.identityc                 C      t |tstS | j|jkS r   )
isinstancer   NotImplementedr8   r	   otherr
   r
   r   __eq__      
zJoin.__eq__c                 C   
   t | jS r   hashr8   r7   r
   r
   r   __hash__      
zJoin.__hash__c                 C   s   | j d d |j d d kS )Nr8   r<   r
   r
   r   equals   s   zJoin.equalsc                 C      |  i }t|_|S r   )r6   r   r   r	   newr
   r
   r   demote      
zJoin.demotec                 C   rH   r   )r6   r   r   rI   r
   r
   r   promote   rL   zJoin.promoter   )r   r   r   r   r   r-   r6   propertyr8   r>   rC   rG   rK   rM   r
   r
   r
   r   r      s    
;
	r   c                   @   sX   e Zd ZdZdZdZdZdd Zdd Zdd Z	e
d	d
 Zdd Zdd Zdd ZdS )	BaseTablez
    The BaseTable class is used for base table references in FROM clause. For
    example, the SQL "foo" in
        SELECT * FROM "foo" WHERE somecond
    could be generated by this class.
    Nc                 C   r   r   )r   r   )r	   r   aliasr
   r
   r   r      s   
zBaseTable.__init__c                 C   s2   | j | jkrdnd| j  }|| j}|| g fS )Nr   r   )r   r   r   )r	   r'   r(   r+   Zbase_sqlr
   r
   r   r-      s   zBaseTable.as_sqlc                 C   s   |  | j|| j| jS r   )r%   r   r.   r   )r	   r2   r
   r
   r   r6      s   zBaseTable.relabeled_clonec                 C   s   | j | j| jfS r   )r%   r   r   r7   r
   r
   r   r8      s   zBaseTable.identityc                 C   r9   r   )r:   rO   r;   r8   r<   r
   r
   r   r>      r?   zBaseTable.__eq__c                 C   r@   r   rA   r7   r
   r
   r   rC      rD   zBaseTable.__hash__c                 C   s   | j |j kS r   rF   r<   r
   r
   r   rG      s   zBaseTable.equals)r   r   r   r   r   r   r   r   r-   r6   rN   r8   r>   rC   rG   r
   r
   r
   r   rO      s    
rO   N)r   Zdjango.core.exceptionsr   Zdjango.db.models.sql.constantsr   r   	Exceptionr   r   r   rO   r
   r
   r
   r   <module>   s     