a
    Šxdµ  ã                   @   sL   d dl mZ d dlmZ ddd„ZeddƒZddd	„Zddd„Zdd„ ZdS )é    )Ú
namedtuple)ÚRECURSIVE_RELATIONSHIP_CONSTANTNc                 C   sz   t | tƒrj| tkr2|du s"|du r*tdƒ‚||fS d| v rNt|  ¡  dd¡ƒS |du r^tdƒ‚||  ¡ fS | jj| jj	fS )z¾
    Turn a model class or model reference string and return a model tuple.

    app_label and model_name are used to resolve the scope of recursive and
    unscoped model relationship.
    NzMapp_label and model_name must be provided to resolve recursive relationships.Ú.é   zCapp_label must be provided to resolve unscoped model relationships.)
Ú
isinstanceÚstrr   Ú	TypeErrorÚtupleÚlowerÚsplitZ_metaÚ	app_labelÚ
model_name)Úmodelr   r   © r   ú]/var/www/html/Ranjet/env/lib/python3.9/site-packages/django/db/migrations/operations/utils.pyÚresolve_relation   s    
ÿÿr   ÚFieldReferencez
to throughc                 C   sÎ   |j }|sdS d}d}t|jg| ¢R Ž |krnt|ddƒ}|du sf|du sfd|v r^|du sf|jsf||v rn||f}t|ddƒ}	|	r¸t|	g| ¢R Ž |kr¸|j}
|du s°|
du s°||
v r¸||
f}|sÄ|sÄdS t||ƒS )at  
    Return either False or a FieldReference if `field` references provided
    context.

    False positives can be returned if `reference_field_name` is provided
    without `reference_field` because of the introspection limitation it
    incurs. This should not be an issue when this function is used to determine
    whether or not an optimization can take place.
    FNÚ	to_fieldsÚthrough)Úremote_fieldr   r   ÚgetattrZprimary_keyÚthrough_fieldsr   )Úmodel_tupleÚfieldZreference_model_tupleZreference_field_nameZreference_fieldr   Zreferences_toZreferences_throughr   r   r   r   r   r   Úfield_references#   sB    ÿýûûûù	ÿýûr   r   c                 c   sR   | j  ¡ D ]B\}}|j ¡ D ].\}}t|||g|¢R Ž }|r||||fV  qq
dS )zÍ
    Generator of (model_state, name, field, reference) referencing
    provided context.

    If field_tuple is provided only references to this particular field of
    model_tuple will be generated.
    N)ÚmodelsÚitemsÚfieldsr   )Ústater   Úfield_tupleZstate_model_tupleZmodel_stateÚnamer   Ú	referencer   r   r   Úget_referencesT   s
    r"   c                 C   s   t t| ||ƒdƒduS )z?Return whether `field_tuple` is referenced by any state models.N)Únextr"   )r   r   r   r   r   r   Úfield_is_referencedc   s    r$   )NN)NN)r   )	Úcollectionsr   Zdjango.db.models.fields.relatedr   r   r   r   r"   r$   r   r   r   r   Ú<module>   s   

  û
1
