
    h                        S SK r S SKrS SKJr  S SKJr  S SKJr  S SKJ	r	J
r
  S SKJr  S SKJr  S SKJrJrJrJr  S S	KJr  S S
KJrJr  S SKJr  S SKJr  S SKJrJr  S SK J!r!  \"" 5       r#Sr$Sr%Sr&S r'S r( " S S5      r)g)    N)defaultdict)apps)settings)FieldDoesNotExistImproperlyConfigured)setting_changed)connections)	AutoFieldManagerOrderWrtUniqueConstraint)PathInfo)ImmutableList
OrderedSet)cached_property)import_string)camel_case_to_spacesformat_lazy)override zyThe return type of '%s' should never be mutated. If you want to manipulate this list for your own use, make a copy first.)verbose_nameverbose_name_pluraldb_tabledb_table_commentorderingunique_togetherpermissionsget_latest_byorder_with_respect_to	app_labeldb_tablespaceabstractmanagedproxy	swappableauto_createdr   default_permissionsselect_on_savedefault_related_namerequired_db_featuresrequired_db_vendorbase_manager_namedefault_manager_nameindexesconstraintsc                      U (       d  g[        U [        [        45      (       d  [        eU S   n[        U[        [        45      (       d  U 4n [        S U  5       5      $ ! [         a    U s $ f = f)z
option_together can be either a tuple of tuples, or a single
tuple of two strings. Normalize it to a tuple of tuples, so that
calling code can uniformly expect that.
r   r   c              3   8   #    U  H  n[        U5      v   M     g 7fN)tuple).0ots     J/var/www/html/env/lib/python3.13/site-packages/django/db/models/options.py	<genexpr>%normalize_together.<locals>.<genexpr>H   s     92U2YYs   )
isinstancer3   list	TypeError)option_togetherfirst_elements     r6   normalize_togetherr>   9   sn    /E4=99O'*-%77.0O9999  s   A  AA   A/.A/c                 $    [        U[        U -  S9$ )N)warning)r   IMMUTABLE_WARNING)namedatas     r6   make_immutable_fields_listrD   O   s    '84'?@@    c                   @   \ rS rSr1 Skr1 Skr\rS4S jr\	S 5       r
\	S 5       r\	S 5       rS	 rS
 rS rS rS rS5S jrS rS rS rS rS r\S 5       r\S 5       rS r\S 5       r\S 5       r\S 5       r\S 5       r\S 5       r \S 5       r!\S 5       r"\S 5       r#\S 5       r$\S  5       r%\S! 5       r&S" r'S# r(\S$ 5       r)S% r*S& r+S' r,S( r-S) r.\S* 5       r/S6S+ jr0S7S, jr1     S8S- jr2\S. 5       r3\S/ 5       r4\S0 5       r5\S1 5       r6\S2 5       r7S3r8g)9OptionsS   >   fieldsmanagersbase_managermanagers_mapmany_to_manyconcrete_fieldsdefault_manager_forward_fields_maplocal_concrete_fields_non_pk_concrete_field_names_reverse_one_to_one_field_names>   
fields_map_relation_treerelated_objectsNc                 n   0 U l         / U l        / U l        / U l        / U l        S U l        S U l        S U l        S U l        S U l	        SU l
        SU l        / U l        SU l        / U l        / U l        / U l        SU l        SU l        / U l        S U l        X l        S U l        S U l        [0        R2                  U l        / U l        S U l        Xl        S U l        S U l        SU l         SU l!        SU l"        S U l#        S U l$        S U l%        0 U l&        SU l'        / U l(        U RR                  U l*        S U l+        g )N F)addchangedeleteviewT),_get_fields_cachelocal_fieldslocal_many_to_manyprivate_fieldslocal_managersr,   r-   
model_namer   r   r   r   r   _ordering_clashr.   r/   r   r(   r'   r   object_namer    r   r   r   DEFAULT_TABLESPACEr!   r*   r+   metapk
auto_fieldr"   r#   r$   proxy_for_modelconcrete_modelr%   parentsr&   related_fkey_lookupsdefault_appsr   r)   )selfrf   r    s      r6   __init__Options.__init__e   sL   !#"$  !%$(! #'  "$!##F "!%)"%88$&!"&	
  $ #! %'! %%	$(!rE   c                 <    U R                   < SU R                  < 3$ N.)r    rd   rn   s    r6   labelOptions.label   s    ..$*:*:;;rE   c                 <    U R                   < SU R                  < 3$ rr   )r    rb   rt   s    r6   label_lowerOptions.label_lower   s    ..$//::rE   c                 `    U R                   R                  R                  U R                  5      $ r2   )r   app_configsgetr    rt   s    r6   
app_configOptions.app_config   s#     yy$$((88rE   c           	         SSK Jn  SSKJn  Xl        Xl        UR                  U l        U R                  R                  5       U l	        [        U R                  5      U l        0 U l        U R                  (       Ga  U R                  R                  R                  5       nU R                  R                   H  nUR!                  S5      (       d  M  XR	 M     ["         H  nXe;   a5  [%        XUR'                  U5      5        [)        X5      U R                  U'   M=  [+        U R                  U5      (       d  MZ  [%        X[)        U R                  U5      5        [)        X5      U R                  U'   M     [-        U R.                  5      U l        U R0                  (       d@  U R3                  U R4                  5      U l        U R3                  U R6                  5      U l        U R8                  c  [;        SU R                  5      U l        [=        U R>                  =(       a    U R@                  5      U l!        U0 :w  a  [E        SSRG                  U5      -  5      eO[;        SU R                  5      U l        U ?U RH                  (       dR  U RJ                  < SU R                  < 3U l$        U" U RH                  URL                  RO                  5       5      U l$        U RP                  (       a!  [R        RT                  " U RR                  5        g g )Nr   )
connection)truncate_name_z{}sz)'class Meta' got invalid attribute(s): %s,)+	django.dbr   django.db.backends.utilsr   _metamodel__name__rd   lowerrb   r   r   original_attrsrf   __dict__copy
startswithDEFAULT_NAMESsetattrpopgetattrhasattrr>   r   r"   _format_namesr/   r.   r   r   boolr   r   rc   r;   joinr   r    opsmax_name_lengthr%   r   connect)rn   clsrB   r   r   
meta_attrs	attr_names          r6   contribute_to_classOptions.contribute_to_class   sL   (:	
<<**00201A1AB ! 999++002J		** ??3''"( + +	*DZ^^I-FG5<T5MD''	2TYY	22DWTYY	-JK5<T5MD''	2 + $6d6J6J#KD  ==#'#5#5d6F6F#G #11$,,? ''/+6ud>O>O+P( $((T$:T:T#UD  R?#((:BVV   
 (35$:K:K'LD$I }}'+~~tGDM)z~~==?DM >>##D$8$89 rE   c                     U R                   R                  5       U R                  S.n/ nU H9  nUR                  5       nU=R                  U-  sl        UR                  U5        M;     U$ )z4App label/class name interpolation for object names.)r    class)r    r   rb   clonerB   append)rn   objsnamesnew_objsobjs        r6   r   Options._format_names   sX    "nn224tOC))+CHHHOOC   rE   c                    [        U R                  S[        R                  5      nU R                  (       aM  U R                  R                  (       a2  [        U R                  5      nUR                   SUR                   S3nOSnU(       d  [        U S35      e [        U5      n[        U[        5      (       d  [        SU S	U S
35      eU$ ! [         a  nU SU S3n[        U5      UeS nAff = f)Ndefault_auto_fieldrs   z.default_auto_fieldDEFAULT_AUTO_FIELDz must not be empty.z refers to the module 'z' that could not be imported.zPrimary key 'z' referred by z must subclass AutoField.)r   r}   r   r   !_is_default_auto_field_overriddentype
__module____qualname__r   r   ImportError
issubclassr
   
ValueError)rn   pk_class_pathapp_config_classsourcepk_classemsgs          r6   _get_default_pk_classOptions._get_default_pk_class   s   OO ''

 ??tPP#DOO4#../q#0011DF 
 *F&&1D'EFF	3$]3H (I..nVH E& '    	3(1- A# $  's+2	3s   C 
C3C..C3c                 :  ^ U R                   (       a  U R                   m [        U4S jU R                  SS9 5       5      U l         SU l        [        S UR                  R                   5       5      (       d  UR                  S[        5       5        OS U l         U R                  c  U R                  (       a  [        [        U R                  R                  5       5      5      nU R                   Vs/ s H   o3R                   UR                   :X  d  M  UPM"     nnU(       a  US	   nS
Ul        U R%                  U5        g U R'                  5       nU" SS
S
S9nUR                  SU5        g g ! [         a    [	        U R
                  < ST< S35      ef = fs  snf )Nc              3   l   >#    U  H)  nUR                   T:X  d  UR                  T:X  d  M%  Uv   M+     g 7fr2   )rB   attname)r4   fquerys     r6   r7   #Options._prepare.<locals>.<genexpr>  s0      2<vv!))u*< A<s   $4	4Freverse has no field named '')_orderc              3   B   #    U  H  n[        U[        5      v   M     g 7fr2   )r9   r   r4   fields     r6   r7   r   '  s      9Q
5(++9Qs   r   r   TID)r   primary_keyr&   id)r   next_get_fieldsStopIterationr   rd   r   anyr   r^   add_to_classr   rg   rk   itervaluesrB   r   setup_pkr   )rn   r   r   fldalready_createdr   autor   s          @r6   _prepareOptions._prepare  su   %% ..E	-1 2!--e-<2 .* (DM 9>9Q9Q   ""8XZ8)-D&77?|| T$,,"5"5"789
 $(#4#4##4CEJJ8NC#4   # #+A.E$(!e$557TtRVW""4.%  ! '484D4DeL *#s   'E- 3FF-(Fc                 Z    U R                   R                  U5        U R                  5         g r2   )ra   r   _expire_cachern   managers     r6   add_managerOptions.add_managerB  s"    ""7+rE   c                    U(       a  U R                   R                  U5        OvUR                  (       a3  UR                  (       a"  [        R
                  " U R                  U5        O2[        R
                  " U R                  U5        U R                  U5        UR                  (       au  [        UR                  S5      (       aZ  UR                  R                  (       a?   UR                  R                  R                  R                  SS9  U R                  5         g U R                  SS9  g ! [         a     N-f = f)Nr   F)forwardr   )r`   r   is_relationrM   bisectinsortr_   r^   r   r   remote_fieldr   r   r   AttributeError)rn   r   privates      r6   	add_fieldOptions.add_fieldF  s    
 &&u-5#5#5MM$1159MM$++U3MM%  **G44""((""((..<<U<K  u-	 " s   "-D0 0
D=<D=c                 f    U R                   (       d   UR                  (       a  Xl         SUl        g g g )NF)rg   r   	serializern   r   s     r6   r   Options.setup_pkh  s$    ww5,,G#EO -wrE   c                 |    UR                   R                  U l        Xl        UR                   R                  U l        g)zJ
Do the internal setup so that the current model is a proxy for
"target".
N)r   rg   ri   r   )rn   targets     r6   setup_proxyOptions.setup_proxym  s*    
 ,,//%--rE   c                      SU R                   -  $ )Nz<Options for %s>)rd   rt   s    r6   __repr__Options.__repr__v  s    !D$4$444rE   c                     U R                   $ r2   )rx   rt   s    r6   __str__Options.__str__y  s    rE   c                 ^  ^ U R                   (       d"  U R                  (       d  U R                  (       d  g[        T[        5      (       a	  [
        T   mU R                  (       a  U R                  TR                  :H  $ U R                  (       a  [        U4S jU R                   5       5      $ g)z
Return True if the model can/should be migrated on the `connection`.
`connection` can be either a real connection or a connection alias.
Fc              3   R   >#    U  H  n[        TR                  US 5      v   M     g7f)FN)r   features)r4   featr   s     r6   r7   &Options.can_migrate.<locals>.<genexpr>  s*      5D 
++T5995s   $'T)
r$   swappedr#   r9   strr	   r+   vendorr*   all)rn   r   s    `r6   can_migrateOptions.can_migrate|  s    
 ::T\\j#&&$Z0J""**j.?.???$$  55   rE   c                     [        U R                  [        5      (       a  U R                  $ [        S5         [        U R                  5      sSSS5        $ ! , (       d  f       g= f)z%Return the untranslated verbose name.N)r9   r   r   r   rt   s    r6   verbose_name_rawOptions.verbose_name_raw  sB     d''--$$$d^t(() ^^s   A
A$c                    U R                   (       a]  [        [        U R                   S5      nU(       a;   UR                  S5      u  p#U< SUR                  5       < 3U R                  :w  a  U$ g! [         a    Us $ f = f)z
Has this model been swapped out for another? If so, return the model
name of the replacement; otherwise, return None.

For historical reasons, model name lookups using get_model() are
case insensitive, so we make sure we are case insensitive here.
Nrs   )r%   r   r   splitr   r   rx   )rn   swapped_forswapped_labelswapped_objects       r6   r   Options.swapped  s}     >>!(DNNDAK'4?4E4Ec4J1M  -n.B.B.DE''( '& " '
 '&'s   A0 0A?>A?c                J    XR                   :X  a  SU R                  ;   a  U ?g g g )Nr   )r%   r   r   )rn   settingkwargss      r6   r   Options.setting_changed  s%    nn$dmm)C *D$rE   c                    / n[        5       nS U R                  R                  5        5       n[        U5       H  u  pEUR                  R
                   Ht  nUR                  U;   a  M  [        R                  " U5      nU R                  Ul        UR                  UR                  5        UR                  XFR                  U45        Mv     M     [        SS [        U5       5       5      $ )Nc              3   L   #    U  H  n[        US 5      (       d  M  Uv   M     g7f)r   N)r   )r4   bs     r6   r7   #Options.managers.<locals>.<genexpr>  s     D,q70C,s   $	$rJ   c              3   *   #    U  H	  oS    v   M     g7f)   Nr   )r4   ms     r6   r7   r    s     ,+aqT+s   )setr   mro	enumerater   ra   rB   r   rY   r   creation_counterrD   sorted)rn   rJ   seen_managersbasesdepthbaser   s          r6   rJ   Options.managers  s    DDJJNN,D$U+KE::44<<=0))G, $

!!',,/(@(@' JK 5 , *,6(+,
 	
rE   c                 Z    U R                    Vs0 s H  oR                  U_M     sn$ s  snf r2   )rJ   rB   r   s     r6   rL   Options.managers_map  s%    59]]C]'g%]CCCs   (c                    U R                   nU(       dg  U R                  R                  5       SS   HF  n[        US5      (       d  M  UR                  R
                  S:w  a  UR                  R
                  n  O   U(       a   U R                  U   $ [        5       nSUl        U R                  Ul        SUl        U$ ! [         a    [        U R                  < SU< 35      ef = f)N   r   _base_manager has no manager named T)r,   r   r  r   r"  rB   rL   KeyErrorr   rd   r   r&   )rn   r,   parentr   s       r6   rK   Options.base_manager  s     22 **..*12.67++++00OC,2,@,@,E,E)	 / 	(():;; )&

#    (() s   B= ='C$c                    U R                   nU(       d^  U R                  (       dM  U R                  R                  5       SS   H,  n[	        US5      (       d  M  UR
                  R                   n  O   U(       a   U R                  U   $ U R                  (       a  U R                  S   $ g ! [         a    [        U R                  < SU< 35      ef = f)Nr!  r   r#  r   )r-   ra   r   r  r   r   rL   r$  r   rd   rJ   )rn   r-   r%  s      r6   rO   Options.default_manager  s    #88#D,?,?**..*12.67+++1<<+L+L( /
  	(()=>> ====##     ((, s   :B* *'Cc                 d   ^^^ S mS mS m[        SUUU4S jU R                  SS9 5       5      $ )a  
Return a list of all forward fields on the model and its parents,
excluding ManyToManyFields.

Private API intended only to be used by Django itself; get_fields()
combined with filtering of field properties is the public API for
obtaining this field list.
c                 J    U R                   =(       a    U R                  (       + $ r2   r   rM   r   s    r6   is_not_an_m2m_field+Options.fields.<locals>.is_not_an_m2m_field  s    8!..99rE   c                 J    U R                   =(       a    U R                  (       + $ r2   )r   one_to_manyr,  s    r6   is_not_a_generic_relation1Options.fields.<locals>.is_not_a_generic_relation  s    7!--88rE   c                     U R                   =(       aK    U R                  =(       a8    [        U R                  S5      =(       a    U R                  R                  (       + (       + $ )Nr   )r   many_to_oner   r   r   r,  s    r6   is_not_a_generic_foreign_key4Options.fields.<locals>.is_not_a_generic_foreign_key  sF     TMMT 9Rann>R>RS rE   rI   c              3      >#    U  H4  nT" U5      (       d  M  T" U5      (       d  M!  T" U5      (       d  M0  Uv   M6     g 7fr2   r   )r4   r   r5  r1  r-  s     r6   r7   !Options.fields.<locals>.<genexpr>%  s@      8A&q)  .a0  13	 8s   ???	?Fr   rD   r   )rn   r5  r1  r-  s    @@@r6   rI   Options.fields  s?    $	:	9	 *))%)8	
 		
rE   c                 <    [        SS U R                   5       5      $ )z
Return a list of all concrete fields on the model and its parents.

Private API intended only to be used by Django itself; get_fields()
combined with filtering of field properties is the public API for
obtaining this field list.
rN   c              3   J   #    U  H  oR                   (       d  M  Uv   M     g 7fr2   concreter4   r   s     r6   r7   *Options.concrete_fields.<locals>.<genexpr>8  s     E;a**;   #	#)rD   rI   rt   s    r6   rN   Options.concrete_fields.  s      *E4;;E
 	
rE   c                 <    [        SS U R                   5       5      $ )z
Return a list of all concrete fields on the model.

Private API intended only to be used by Django itself; get_fields()
combined with filtering of field properties is the public API for
obtaining this field list.
rQ   c              3   J   #    U  H  oR                   (       d  M  Uv   M     g 7fr2   r=  r?  s     r6   r7   0Options.local_concrete_fields.<locals>.<genexpr>E  s     %Q1BAjjaa1BrA  )rD   r^   rt   s    r6   rQ   Options.local_concrete_fields;  s"     *#%Q1B1B%Q
 	
rE   c                 B    [        SS U R                  SS9 5       5      $ )z
Return a list of all many to many fields on the model and its parents.

Private API intended only to be used by Django itself; get_fields()
combined with filtering of field properties is the public API for
obtaining this list.
rM   c              3   r   #    U  H-  nUR                   (       d  M  UR                  (       d  M)  Uv   M/     g 7fr2   r+  r?  s     r6   r7   'Options.many_to_many.<locals>.<genexpr>S  s,      8A== %&^^ 8s   77	7Fr   r9  rt   s    r6   rM   Options.many_to_manyH  s/     *))%)8
 	
rE   c                 J    U R                  SSSS9n[        SS U 5       5      $ )a?  
Return all related objects pointing to the current model. The related
objects can come from a one-to-one, one-to-many, or many-to-many field
relation type.

Private API intended only to be used by Django itself; get_fields()
combined with filtering of field properties is the public API for
obtaining this field list.
FT)r   r   include_hiddenrV   c              3      #    U  H5  nUR                   (       a  UR                  R                  (       d  M1  Uv   M7     g 7fr2   )hiddenr   rM   )r4   r   s     r6   r7   *Options.related_objects.<locals>.<genexpr>j  s,      -CzzSYY%;%; -s   0?	?)r   rD   )rn   all_related_fieldss     r6   rV   Options.related_objectsZ  s@     "--4 . 
 *-
 	
rE   c                     0 nU R                  SS9nU H   nX1UR                  '    X1UR                  '   M"     U$ ! [         a     M3  f = f)NFr   r   rB   r   r   rn   resrI   r   s       r6   rP   Options._forward_fields_mapq  s[    !!%!0E#

O%*EMM"  
 " s   :
AAc                     0 nU R                  SSS9nU H   nX1UR                  '    X1UR                  '   M"     U$ ! [         a     M3  f = f)NFT)r   rL  rS  rT  s       r6   rT   Options.fields_map  s]    !!%!EE#

O%*EMM"  
 " s   ;
A	A	c                 (    U R                   U   $ ! [         a;    U R                  R                  (       d  [	        U R
                  < SU< S35      e Of = f U R                  U   $ ! [         a    [	        U R
                  < SU< S35      ef = f)zG
Return a field instance given the name of a forward or reverse field.
r   zi'. The app cache isn't ready yet, so if this is an auto-created related field, it won't be available yet.r   )rP   r$  r   models_readyr   rd   rT   )rn   
field_names     r6   	get_fieldOptions.get_field  s    	 ++J77 	 99))' ,0+;+;ZI  *		 ??:.. 	#040@0@*M 	s    AAAA) )(Bc                     U R                   (       d  / $ XR                   ;   a  U/$ U R                    H;  nUR                  R                  U5      nU(       d  M'  UR                  SU5        Us  $    / $ )z
Return a list of parent classes leading to `model` (ordered from
closest to most distant ancestor). This has to handle the case where
`model` is a grandparent or even more distant relation.
r   )rk   r   get_base_chaininsert)rn   r   r%  rU  s       r6   r_  Options.get_base_chain  sb     ||ILL 7NllF,,--e4Cs

1f%
	 #
 	rE   c                     [        U R                  5      nU R                   H1  nUR                  R                   H  nUR	                  U5        M     M3     [        U5      $ )z
Return all the ancestors of this model as a tuple ordered by MRO.
Useful for determining if something is an ancestor, regardless of lineage.
)r   rk   r   all_parentsrY   r3   )rn   resultr%  ancestors       r6   rc  Options.all_parents  sL     DLL)llF"LL44

8$ 5 # V}rE   c                 ,    [        U R                  5      $ )za
Return all the ancestors of this model as a list ordered by MRO.
Backward compatibility method.
)r:   rc  rt   s    r6   get_parent_listOptions.get_parent_list  s    
 D$$%%rE   c                     XR                   ;   a  U R                   U   $ U R                    H?  nUR                  R                  U5      nU(       d  M'  U R                   U   =(       d    Us  $    g)a,  
Return the field on the current model which points to the given
"ancestor". This is possible an indirect link (a pointer to a parent
model, which points, eventually, to the ancestor). Used when
constructing table joins for model inheritance.

Return None if the model isn't an ancestor of this one.
N)rk   r   get_ancestor_link)rn   re  r%  parent_links       r6   rk  Options.get_ancestor_link  sZ     ||#<<))llF ,,88BK{ ||F+:{: #rE   c                 l   U R                   UL a  / $ U R                  n/ nU nU R                  U5       H}  nXRL a  UR                  nM  UR                  U   nUR
                  R                  5       4nUR                  nUR                  [        UR                   R                  UUUSSSS95        M     U$ )z
Return a list of PathInfos containing the path from the current
model to the parent model, or an empty list if parent is not a
parent of the current model.
FTN)	from_optsto_optstarget_fields
join_fieldm2mdirectfiltered_relation)	r   rj   r_  r   rk   r   get_related_fieldr   r   )rn   r%  proxied_modelpathopts	int_modelfinal_fieldtargetss           r6   get_path_to_parentOptions.get_path_to_parent  s     ::I++,,V4I) "ll95&33EEGI "-"3"3"9"9 $&-#.!#*.
 5$ rE   c                 d   U R                   UL a  / $ U R                  nUR                  R                  U5      nUR	                  5         UR                  U5        / n[        USS 5       HB  u  pVX5S-      nUR                  R                  U5      nUR                  UR                  5        MD     U$ )z
Return a list of PathInfos containing the path from the parent
model to the current model, or an empty list if parent is not a
parent of the current model.
Nr!  )
r   rj   r   r_  r   r   r  rk  extendreverse_path_infos)	rn   r%  r   chainrx  ire  childlinks	            r6   get_path_from_parentOptions.get_path_from_parent  s     ::I## **62U$U3BZ0KAa%LE;;00:DKK//0 1 rE   c                    [        [        5      nU R                  R                  SS9nU H  nUR                  nUR
                  (       a  M"  S UR                  SSS9 5       nU H  n[        UR                  R                  [        5      (       a  M.  UR                  R                  R                  R                  R                  R                  nX   R                  U5        M     M     U HH  nUUR                  R                  R                  R                     nXR                  R                  S'   MJ     U R                  R                  S[         5      $ )z
This method is used by each model to find its reverse objects. As this
method is very expensive and is accessed frequently (it looks up every
field in a model, in every app), it is computed on first access and then
is set as a property on every model.
T)include_auto_createdc              3   j   #    U  H)  nUR                   (       d  M  UR                  c  M%  Uv   M+     g 7fr2   )r   related_modelr?  s     r6   r7   <Options._populate_directed_relation_graph.<locals>.<genexpr>(  s,      %OA== %&__ Os   33	3F)r   include_parentsrU   )r   r:   r   
get_modelsr   r"   r   r9   r   r   r   rj   ru   r   r   r|   EMPTY_RELATION_TREE)	rn   related_objects_graph
all_modelsr   ry  fields_with_relationsr   remote_labelrV   s	            r6   !_populate_directed_relation_graph)Options._populate_directed_relation_graph  s"    !,D 1YY))t)D
E;;D }}%))%)O%!
 +!!.."6"6<<#$>>#7#7#=#=#L#L#R#R#X#XL)7>>qA +     E 4**0066O 6EKK  !12   }}  !13FGGrE   c                 "    U R                  5       $ r2   )r  rt   s    r6   rU   Options._relation_tree@  s    5577rE   c                    U(       a/  U R                    H  nX0R                  ;   d  M  [        X5        M!     U(       a@  U R                  (       d/  U R                   H  nX0R                  ;   d  M  [        X5        M!     0 U l        g r2   )FORWARD_PROPERTIESr   delattrr"   REVERSE_PROPERTIESr]   )rn   r   r   	cache_keys       r6   r   Options._expire_cacheD  s`     !44	-D, 5 4==!44	-D, 5 "$rE   c                 6    USL a  [         nU R                  XS9$ )at  
Return a list of fields associated to the model. By default, include
forward and reverse fields, fields derived from inheritance, but not
hidden fields. The returned fields can be changed using the parameters:

- include_parents: include fields derived from inheritance
- include_hidden:  include fields that have a related_name that
                   starts with a "+"
F)r  rL  )PROXY_PARENTSr   )rn   r  rL  s      r6   
get_fieldsOptions.get_fieldsQ  s,     e#+O+   
 	
rE   c           	         USS[         4;  a  [        SU< 35      eXX4U4n U R                  U   $ ! [         a     Of = f/ nUSLa  [	        5       nU R
                   H  n	U	R                  R                  U R                  :w  a  U[         :X  a  M3  U	R                  R                  UUUUSS9 HZ  n
[        U
SS5      (       a  U
R                  U R                  :X  d  M1  X;  d  M8  UR                  U
5        UR                  U
5        M\     M     U(       ae  U R                  (       dT  U R                  nU HB  nU(       d  UR                  R                   (       a  M'  UR                  UR                  5        MD     U(       a1  XpR"                  -  nXpR$                  -  nU(       a  XpR&                  -  n[)        SU5      nXpR                  U'   U$ )aB  
Internal helper function to return fields of the model.
* If forward=True, then fields defined on this model are returned.
* If reverse=True, then relations pointing to this model are returned.
* If include_hidden=True, then fields with is_hidden=True are returned.
* The include_parents argument toggles if fields from parent models
  should be included. It has three values: True, False, and
  PROXY_PARENTS. When set to PROXY_PARENTS, the call will return all
  fields defined for the current model or any of its parents in the
  parent chain to the model's concrete model.
TFz&Invalid argument for include_parents: )r   r   r  rL  topmost_callrl  zget_fields())r  r;   r]   r$  r  rk   r   rj   r   r   r   r   rY   r$   rU   r   rN  r^   r_   r`   rD   )rn   r   r   r  rL  r  r  rI   parent_fieldsr%  r   
all_fieldsr   s                r6   r   Options._get_fieldsa  s   & 4">>>MO  U		 )))44 		  %'  EM,,LL//43F3FF'=8!<<33##$3#1!& 4 C $C>>99(;(;;2c*%))#. '( 4:: ,,J# "););)B)B)BMM%"4"45	 $ '''F---F --- ,NFC -3y)s   2 
??c                     U R                    Vs/ s H>  n[        U[        5      (       d  M  UR                  b  M)  UR                  (       a  M<  UPM@     sn$ s  snf )zw
Return a list of total unique constraints. Useful for determining set
of fields guaranteed to be unique for all rows.
)r/   r9   r   	conditioncontains_expressions)rn   
constraints     r6   total_unique_constraints Options.total_unique_constraints  sZ     #..
.
:'78  ((	 
 #77 .
 	
 
s   AAAAc           
      V   [        5       n[        5       nU R                  R                   Hk  nUUR                  R	                  5        VVs1 s H%  u  pE[        U[        5      (       d  M  XB;  d  M#  UiM'     snn-  nU[        UR                  5      -  nMm     [        U5      $ s  snnf )zAReturn a set of the names of the properties defined on the model.)r  r   __mro__r   itemsr9   property	frozenset)rn   r   seenklassrB   values         r6   _property_namesOptions._property_names  s     uZZ''E#(>>#7#7#9#9KDeX. 373C #9 E
 C''D ( s   B%
+B%
2B%
c                    / nU R                    Hh  nUR                  (       a  M  UR                  UR                  5        UR                  UR                  :w  d  MM  UR                  UR                  5        Mj     [        U5      $ )zG
Return a set of the non-pk concrete field names defined on the model.
)rN   r   r   rB   r   r  )rn   r   r   s      r6   rR   $Options._non_pk_concrete_field_names  sb    
 ))E$$$UZZ(::.LL/	 *
 rE   c                 :    [        S U R                   5       5      $ )zO
Return a set of reverse one to one field names pointing to the current
model.
c              3   ^   #    U  H#  oR                   (       d  M  UR                  v   M%     g 7fr2   )
one_to_onerB   r   s     r6   r7   :Options._reverse_one_to_one_field_names.<locals>.<genexpr>  s       
$85<L<LJEJJ$8s   --)r  rV   rt   s    r6   rS   'Options._reverse_one_to_one_field_names  s$      
$($8$8
 
 	
rE   c                     U R                  SS[        S9 Vs/ s H  n[        USS5      (       d  M  UPM     sn$ s  snf )zg
Private API intended only to be used by Django itself.
Fields to be returned after a database insert.
TF)r   r   r  db_returning)r   r  r   r   s     r6   db_returning_fieldsOptions.db_returning_fields  sR     ))e] * 
 une4	 
 	
 
s   ;;)+r]   rc   r"   r    r   r&   rh   r,   rj   r/   r   r   r!   r-   r'   r)   r   r.   r^   ra   r_   r#   rf   r   rb   rd   r   r   r   rk   r   rg   r`   r$   ri   rl   r*   r+   r(   r%   r   r   r   r2   )F)TT)TF)TTTFT)9r   r   r   __firstlineno__r  r  r   rm   ro   r  ru   rx   r}   r   r   r   r   r   r   r   r   r   r   r   r   r  r   r   rJ   rL   rK   rO   rI   rN   rQ   rM   rV   rP   rT   r\  r_  rc  rh  rk  r}  r  r  rU   r   r  r   r  r  rR   rS   r  __static_attributes__r   rE   r6   rG   rG   S   su    ML7)r < < ; ; 9 9@:D>*/X .D$
.5 $ * *  6 
 
& D D  8 $ $0 '
 '
R 

 

 

 

 
 
" 
 
,    6" 	 	&;(@,&HP 8 8$
$ ]~ 
 
     
  
  
 
 
 
rE   rG   )*r   r   collectionsr   django.appsr   django.confr   django.core.exceptionsr   r   django.core.signalsr   r   r	   django.db.modelsr
   r   r   r   django.db.models.query_utilsr   django.utils.datastructuresr   r   django.utils.functionalr   django.utils.module_loadingr   django.utils.textr   r   django.utils.translationr   objectr  r  rA   r   r>   rD   rG   r   rE   r6   <module>r     sj      #    J / ! K K 1 A 3 5 ? - 0 
<,An
 n
rE   