
    h                     P    d dl mZ d dlmZ d
dZ edd      Z	 	 d
dZddZd	 Zy)    )
namedtuple)RECURSIVE_RELATIONSHIP_CONSTANTNc                 J   t        | t              rh| t        k(  r||t        d      ||fS d| v r)t	        | j                         j                  dd            S |t        d      || j                         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.
    zMapp_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split_meta	app_label
model_name)modelr   r   s      h/var/www/html/ranktracker/api/venv/lib/python3.12/site-packages/django/db/migrations/operations/utils.pyresolve_relationr      s     %33 J$6/  j((%<,,S!455!  %++-'';;  %++"8"888    FieldReferencez
to throughc                 >   |j                   }|syd}d}t        |j                  g|  |k(  r+t        |dd      }||d|v r||j                  s||v r||f}t        |dd      }	|	r't        |	g|  |k(  r|j
                  }
||
||
v r||
f}|s|sy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   getattrprimary_keythrough_fieldsr   )model_tuplefieldreference_model_tuplereference_field_namereference_fieldr   references_toreferences_throughr   r   r   s              r   field_referencesr$   #   s      %%LM**9[9=RRE;5	 (YO$;?Z?Z I-)95MlIt4G#G:k:>SS%44 (" N2".!?/-);<<r   c              #      K   | j                   j                         D ]@  \  }}|j                  j                         D ]  \  }}t        |||g| }|s||||f   B yw)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_tuplestate_model_tuplemodel_statenamer   	references           r   get_referencesr/   T   ss      +0,,*<*<*> :&;&--335 	:KD%():E;]Q\]I!4	99	::s   AA!A!c                 4    t        t        | ||      d      duS )z?Return whether `field_tuple` is referenced by any state models.N)nextr/   )r)   r   r*   s      r   field_is_referencedr2   c   s    uk;?FdRRr   )NN) )	collectionsr   django.db.models.fields.relatedr   r   r   r$   r/   r2   r3   r   r   <module>r6      s8    " K94 ,l; .=b:Sr   