
 Xʅ                 @   s  d  d l  m Z d  d l Z d  d l Z d  d l m Z d  d l m Z 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 m Z d  d l m Z m Z d  d l  m! Z! m" Z" m# Z# d  d l$ m% Z% d  d l& m' Z' d  d l( m) Z) m* Z* e+   Z, e+   Z- e.   Z/ d Z0 d4 Z1 d. d/   Z2 d0 d1   Z3 e" Gd2 d3   d3 e+   Z4 d S)5    )unicode_literalsN)bisect)OrderedDictdefaultdict)chain)apps)settings)FieldDoesNotExist)connections)Manager)	AutoField)OrderWrt)six)ImmutableList
OrderedSet)RemovedInDjango20Warningwarn_about_renamed_method)
force_textpython_2_unicode_compatible
smart_text)cached_property)camel_case_to_spaces)overridestring_concatzyThe 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orderingunique_togetherpermissionsget_latest_byorder_with_respect_to	app_labeldb_tablespaceabstractmanagedproxy	swappableauto_createdindex_togetherr   default_permissionsselect_on_savedefault_related_namerequired_db_featuresrequired_db_vendorbase_manager_namedefault_manager_namemanager_inheritance_from_futurec             C   s   yv |  s f  St  |  t t f  s+ t  n  t t |    } t  | t t f  s^ |  f }  n  t d d   |  D  SWn t k
 r |  SYn Xd S)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.
    c             s   s   |  ] } t  |  Vq d  S)N)tuple).0Zot r4   F/home/ubuntu/projects/ifolica/build/django/django/db/models/options.py	<genexpr>A   s    z%normalize_together.<locals>.<genexpr>N)
isinstancer2   list	TypeErrornextiter)Zoption_togetherZfirst_elementr4   r4   r5   normalize_together2   s    	r<   c             C   s   t  | d t |  S)Nwarning)r   IMMUTABLE_WARNING)namedatar4   r4   r5   make_immutable_fields_listH   s    rA   c            	   @   s  e  Z d  Z d d d d d d d d d	 h	 Z d
 d d h Z e Z d d d  Z e d d    Z	 e d d    Z
 e d d    Z e d d    Z d d   Z d d   Z d d   Z d e d d   Z d! d"   Z d# d$   Z d% d&   Z d' d(   Z d) d*   Z e d+ d,    Z e d- d.    Z e d/ d0    Z e d1 d2    Z e d3 d4    Z e d5 d6    Z e d7 d8    Z e d9 d:    Z e e  d  d; d< e!  d= d>     Z" e d? d@    Z# e dA dB    Z$ e dC dD    Z% e dE dF    Z& e dG dH    Z' dI dJ   Z( dK dL   Z) dM dN   Z* dO dP   Z+ dQ dR   Z, e dS dT    Z- dU dU dV dW  Z. dU d dX dY  Z/ dU dU dU d d dZ d[  Z0 d S)\Optionsfieldsmany_to_manyconcrete_fieldslocal_concrete_fields_forward_fields_mapmanagersmanagers_mapbase_managerdefault_managerrelated_objects
fields_map_relation_treeNc             C   s~  i  |  _  g  |  _ g  |  _ g  |  _ d |  _ g  |  _ d  |  _ d  |  _ d  |  _ d  |  _	 d  |  _
 d |  _ g  |  _ d |  _ g  |  _ g  |  _ d |  _ d |  _ g  |  _ d  |  _ | |  _ d  |  _ d  |  _ t j |  _ g  |  _ d  |  _ | |  _ d  |  _ d |  _ d  |  _ d |  _  d |  _! d |  _" d  |  _# d  |  _$ d  |  _% t&   |  _' d |  _( g  |  _) |  j* |  _+ d  |  _, d  S)NF addchangedeleteT)zaddrQ   zdelete)-_get_fields_cachelocal_fieldslocal_many_to_manyprivate_fieldsr1   local_managersr/   r0   
model_namer   r   r   r   _ordering_clashr   r)   r+   r*   r   object_namer"   r    r!   r   ZDEFAULT_TABLESPACEr#   r-   r.   metapkZhas_auto_fieldZ
auto_fieldr$   r%   r&   proxy_for_modelconcrete_modelr'   r   parentsr(   Zrelated_fkey_lookupsdefault_appsr   r,   )selfr[   r"   r4   r4   r5   __init__W   sR    																																					zOptions.__init__c             C   s   d |  j  |  j f S)Nz%s.%s)r"   rZ   )ra   r4   r4   r5   label   s    zOptions.labelc             C   s   d |  j  |  j f S)Nz%s.%s)r"   rX   )ra   r4   r4   r5   label_lower   s    zOptions.label_lowerc             C   s   |  j  j j |  j  S)N)r   Zapp_configsgetr"   )ra   r4   r4   r5   
app_config   s    zOptions.app_configc             C   s   |  j  d  k	 S)N)rf   )ra   r4   r4   r5   	installed   s    zOptions.installedc             C   sE  d d l  m } d d l m } |  | _ | |  _ | j |  _ |  j j   |  _	 t
 |  j  |  _ i  |  _ |  j r|  j j j   } x- |  j j D] } | j d  r | | =q q Wx t D] } | | k rt |  | | j |   t |  |  |  j | <q t |  j |  r t |  | t |  j |   t |  |  |  j | <q q Wt |  j  |  _ t |  j  |  _ |  j d  k rt |  j d  |  _ n  t |  j o|  j  |  _ | i  k rt d d j  | j!      qn t |  j d  |  _ |  ` |  j" sAd |  j# |  j	 f |  _" | |  j" | j$ j%    |  _" n  d  S)	Nr   )
connection)truncate_name_sz)'class Meta' got invalid attribute(s): %s,z%s_%s)&	django.dbrh   Zdjango.db.backends.utilsri   _metamodel__name__rZ   lowerrX   r   r   Zoriginal_attrsr[   __dict__copy
startswithDEFAULT_NAMESsetattrpopgetattrhasattrr<   r   r)   r   r   boolr   r!   rY   r9   joinkeysr   r"   opsZmax_name_length)ra   clsr?   rh   ri   Z
meta_attrs	attr_namer4   r4   r5   contribute_to_class   s@    				%	zOptions.contribute_to_classc                s  |  j  r |  j   y2 t  f d d   |  j d d  D  |  _  Wn+ t k
 rq t d |  j  f   Yn Xd |  _ t d d   | j j	 D  s | j
 d t    q n	 d  |  _  |  j d  k r|  j rWt t j |  j       f d d	   |  j	 D } | r| d
   n  d   _ |  j      j j st j d   t  qqt d d d d d d  } | j
 d |  n  d  S)Nc             3   s3   |  ]) } | j    k s' | j   k r | Vq d  S)N)r?   attname)r3   f)queryr4   r5   r6      s    z#Options._prepare.<locals>.<genexpr>reverseFz%s has no field named %r_orderc             s   s   |  ] } t  | t  Vq d  S)N)r7   r   )r3   fieldr4   r4   r5   r6      s    c                s(   g  |  ] } | j    j  k r |  q Sr4   )r?   )r3   Zfld)r   r4   r5   
<listcomp>   s   	 z$Options._prepare.<locals>.<listcomp>r   Tz=Add parent_link=True to %s as an implicit link is deprecated.r   ZIDprimary_keyr(   id)r   )r!   r:   _get_fieldsStopIterationr	   rZ   r   anyrn   rT   Zadd_to_classr   r\   r_   r   
itervaluesr   setup_pkremote_fieldparent_linkwarningswarnr   r   )ra   ro   Zalready_createdZautor4   )r   r   r5   _prepare   s2    		/				zOptions._preparec             C   s   |  j  j |  |  j   d  S)N)rW   append_expire_cache)ra   managerr4   r4   r5   add_manager  s    zOptions.add_managerFc             C   s  | t  k	 r+ t j d t d d | } n  | rD |  j j |  n` | j rx | j rx |  j j	 t
 |  j |  |  n, |  j j	 t
 |  j |  |  |  j |  | j r
t | j d  r
| j j r
y | j j j j d d  Wn t k
 r Yn X|  j   n |  j d d  d  S)NzLThe `virtual` argument of Options.add_field() has been renamed to `private`.
stacklevel   ro   forwardFr   )NOT_PROVIDEDr   r   r   rV   r   is_relationrD   rU   insertr   rT   r   ry   r   ro   rn   r   AttributeError)ra   r   ZprivateZvirtualr4   r4   r5   	add_field  s$    	"
'zOptions.add_fieldc             C   s,   |  j  r( | j r( | |  _  d | _ n  d  S)NF)r\   r   	serialize)ra   r   r4   r4   r5   r   )  s    	zOptions.setup_pkc             C   s+   | j  j |  _ | |  _ | j  j |  _ d S)zd
        Does the internal setup so that the current model is a proxy for
        "target".
        N)rn   r\   r]   r   )ra   targetr4   r4   r5   setup_proxy.  s    	zOptions.setup_proxyc             C   s   d |  j  S)Nz<Options for %s>)rZ   )ra   r4   r4   r5   __repr__7  s    zOptions.__repr__c             C   s    d t  |  j  t  |  j  f S)Nz%s.%s)r   r"   rX   )ra   r4   r4   r5   __str__:  s    zOptions.__str__c                s   |  j  s |  j s |  j r  d St   t j  r? t     n  |  j rX |  j   j k S|  j	 r t
   f d d   |  j	 D  Sd S)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   s$   |  ] } t    j | d   Vq d S)FN)rx   features)r3   Zfeat)rh   r4   r5   r6   I  s   z&Options.can_migrate.<locals>.<genexpr>T)r&   swappedr%   r7   r   string_typesr
   r.   vendorr-   all)ra   rh   r4   )rh   r5   can_migrate=  s    		zOptions.can_migratec          	   C   s$   t  d   t |  j  SWd QXd S)z
        There are a few places where the untranslated verbose name is needed
        (so that we get the same value regardless of currently active
        locale).
        N)r   r   r   )ra   r4   r4   r5   verbose_name_rawM  s    zOptions.verbose_name_rawc             C   s   |  j  r t t |  j  d  } | r y | j d  \ } } Wn t k
 rU | SYn Xd | | j   f |  j k r| | Sq n  d S)a!  
        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.
        N.z%s.%s)r'   rx   r   split
ValueErrorrq   rd   )ra   Zswapped_forZswapped_labelZswapped_objectr4   r4   r5   r   W  s    			
zOptions.swappedc             C   s   g  } t    } d d   |  j j   D } x t |  D] \ } } xv | j j D]h } | j | k rl qQ n  t j |  } |  j | _ | j | j  | j	 | | j
 | f  | | _ qQ Wq8 Wt d d d   t |  D  S)Nc             s   s$   |  ] } t  | d   r | Vq d S)rn   N)ry   )r3   br4   r4   r5   r6   t  s    z#Options.managers.<locals>.<genexpr>rH   c             s   s   |  ] } | d  Vq d S)r   Nr4   )r3   mr4   r4   r5   r6     s    )setro   mro	enumeratern   rW   r?   rs   rP   r   Zcreation_counterZ_originating_modelrA   sorted)ra   rH   Zseen_managersbasesdepthbaser   r4   r4   r5   rH   p  s    	zOptions.managersc             C   s   d d   |  j  D S)Nc             S   s   i  |  ] } | | j   q Sr4   )r?   )r3   r   r4   r4   r5   
<dictcomp>  s   	 z(Options.managers_map.<locals>.<dictcomp>)rH   )ra   r4   r4   r5   rI     s    zOptions.managers_mapc             C   s  |  j  } | sj xX |  j j   d d   D]: } t | d  r) | j j d k r_ | j j } n  Pq) q) Wn  | r y |  j | SWq t k
 r t d |  j	 | f   Yq Xn  x t
 |  j j j    D] \ } } t | d d  r t | d d  s!t j d j |  j j j  t d	  n  | d
 k r9|  j } n |   } d | _ |  j | _ | Sq Wt   } d | _ |  j | _ d | _ | S)N   rn   _base_managerz%s has no manager named %rZuse_for_related_fieldsFZ*silence_use_for_related_fields_deprecationzQuse_for_related_fields is deprecated, instead set Meta.base_manager_name on '{}'.r   r   T)r/   ro   r   ry   r   r?   rI   KeyErrorr   rZ   r   rK   	__class__rx   r   r   formatrn   rc   r   r   r(   )ra   r/   parentiZbase_manager_classr   r4   r4   r5   rJ     sB    	 %					zOptions.base_managerc             C   s   |  j  } | r` |  j r` xC |  j j   d d   D]% } t | d  r4 | j j  } Pq4 q4 Wn  | r y |  j | SWq t k
 r t d |  j	 | f   Yq Xn  |  j
 r |  j
 d Sd  S)Nr   rn   z%s has no manager named %rr   )r0   rW   ro   r   ry   rn   rI   r   r   rZ   rH   )ra   r0   r   r4   r4   r5   rK     s     	 	zOptions.default_managerc                sV   d d    d d    d d     t  d     f d d	   |  j d
 d  D  S)a2  
        Returns 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             S   s   |  j  o |  j S)N)r   rD   )r   r4   r4   r5   is_not_an_m2m_field  s    z+Options.fields.<locals>.is_not_an_m2m_fieldc             S   s   |  j  o |  j S)N)r   Zone_to_many)r   r4   r4   r5   is_not_a_generic_relation  s    z1Options.fields.<locals>.is_not_a_generic_relationc             S   s0   |  j  o. |  j o. t |  j d  o- |  j j S)Nro   )r   Zmany_to_onery   r   ro   )r   r4   r4   r5   is_not_a_generic_foreign_key  s    z4Options.fields.<locals>.is_not_a_generic_foreign_keyrC   c             3   s9   |  ]/ }  |  r  |  r   |  r | Vq d  S)Nr4   )r3   r   )r   r   r   r4   r5   r6     s    z!Options.fields.<locals>.<genexpr>r   F)rA   r   )ra   r4   )r   r   r   r5   rC     s    zOptions.fieldsc             C   s   t  d d d   |  j D  S)a  
        Returns 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.
        rE   c             s   s   |  ] } | j  r | Vq d  S)N)concrete)r3   r   r4   r4   r5   r6     s    z*Options.concrete_fields.<locals>.<genexpr>)rA   rC   )ra   r4   r4   r5   rE     s    	zOptions.concrete_fieldsvirtual_fieldsrV   c             C   s   |  j  S)N)rV   )ra   r4   r4   r5   r     s    zOptions.virtual_fieldsc             C   s   t  d d d   |  j D  S)z
        Returns 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.
        rF   c             s   s   |  ] } | j  r | Vq d  S)N)r   )r3   r   r4   r4   r5   r6     s    z0Options.local_concrete_fields.<locals>.<genexpr>)rA   rT   )ra   r4   r4   r5   rF   
  s    	zOptions.local_concrete_fieldsc             C   s&   t  d d d   |  j d d  D  S)a  
        Returns 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.
        rD   c             s   s'   |  ] } | j  r | j r | Vq d  S)N)r   rD   )r3   r   r4   r4   r5   r6   "  s    z'Options.many_to_many.<locals>.<genexpr>r   F)rA   r   )ra   r4   r4   r5   rD     s    	zOptions.many_to_manyc             C   s8   |  j  d d d d d d  } t d d d   | D  S)	ax  
        Returns 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.
        r   Fr   Tinclude_hiddenrL   c             s   s+   |  ]! } | j  s | j j r | Vq d  S)N)hiddenr   rD   )r3   objr4   r4   r5   r6   3  s    z*Options.related_objects.<locals>.<genexpr>)r   rA   )ra   Zall_related_fieldsr4   r4   r5   rL   %  s    zOptions.related_objectsc             C   s`   i  } |  j  d d  } xA | D]9 } | | | j <y | | | j <Wq t k
 rW Yq Xq W| S)Nr   F)r   r?   r   r   )ra   resrC   r   r4   r4   r5   rG   6  s    	zOptions._forward_fields_mapc             C   sf   i  } |  j  d d d d  } xA | D]9 } | | | j <y | | | j <Wq% t k
 r] Yq% Xq% W| S)Nr   Fr   T)r   r?   r   r   )ra   r   rC   r   r4   r4   r5   rM   E  s    	zOptions.fields_mapc             C   s   y |  j  | SWn: t k
 rK |  j j sG t d |  j | f   n  Yn Xy |  j | SWn+ t k
 r t d |  j | f   Yn Xd S)zW
        Return a field instance given the name of a forward or reverse field.
        z%s has no field named %r. The app cache isn't ready yet, so if this is an auto-created related field, it won't be available yet.z%s has no field named %rN)rG   r   r   Zmodels_readyr	   rZ   rM   )ra   
field_namer4   r4   r5   	get_fieldT  s    zOptions.get_fieldc             C   sg   |  j  s g  S| |  j  k r# | g Sx= |  j  D]2 } | j j |  } | r- | j d |  | Sq- Wg  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   )r_   rn   get_base_chainr   )ra   ro   r   r   r4   r4   r5   r   m  s    	zOptions.get_base_chainc             C   sT   t  |  j  } x8 |  j D]- } x$ | j j   D] } | j |  q/ Wq Wt |  S)z
        Returns all the ancestors of this model as a list ordered by MRO.
        Useful for determining if something is an ancestor, regardless of lineage.
        )r   r_   rn   get_parent_listrP   r8   )ra   resultr   ancestorr4   r4   r5   r   ~  s
    zOptions.get_parent_listc             C   s[   | |  j  k r |  j  | Sx: |  j  D]/ } | j j |  } | r$ |  j  | pR | Sq$ Wd S)a^  
        Returns 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.

        Returns None if the model isn't an ancestor of this one.
        N)r_   rn   get_ancestor_link)ra   r   r   r   r4   r4   r5   r     s    	zOptions.get_ancestor_linkc             C   s  t  t  } |  j j d d  } x | D] } | j } | j rF q( n  d d   | j d d d d  D } xI | D]A } t | j j	 t
 j  sr | | j j	 j j j j |  qr qr Wq( Wx1 | D]) } | | j j j } | | j j d <q W|  j j d t  S)	a%  
        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.
        Zinclude_auto_createdTc             s   s-   |  ]# } | j  r | j d  k	 r | Vq d  S)N)r   Zrelated_model)r3   r   r4   r4   r5   r6     s    z<Options._populate_directed_relation_graph.<locals>.<genexpr>r   Finclude_parentsrN   )r   r8   r   Z
get_modelsrn   r$   r   r7   r   ro   r   r   r^   r   rr   re   EMPTY_RELATION_TREE)ra   Zrelated_objects_graphZ
all_modelsro   optsZfields_with_relationsr   rL   r4   r4   r5   !_populate_directed_relation_graph  s    		%+z)Options._populate_directed_relation_graphc             C   s
   |  j    S)N)r   )ra   r4   r4   r5   rN     s    zOptions._relation_treeTc             C   s   | r< x3 |  j  D]% } | |  j k r t |  |  q q Wn  | r |  j r x3 |  j D]% } | |  j k rV t |  |  qV qV Wn  i  |  _ d  S)N)FORWARD_PROPERTIESrr   delattrr$   REVERSE_PROPERTIESrS   )ra   r   r   	cache_keyr4   r4   r5   r     s    zOptions._expire_cachec             C   s+   | d k r t  } n  |  j d | d |  S)a  
        Returns a list of fields associated to the model. By default, includes
        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 "+"
        Fr   r   )PROXY_PARENTSr   )ra   r   r   r4   r4   r5   
get_fields  s    
	zOptions.get_fieldsc             C   s4  | d d t  f k r+ t d | f   n  d } | d k rO t   } d } n  | j |  j  | | | | | f } y |  j | SWn t k
 r Yn Xg  } | d k	 rix |  j D] }	 |	 | k r q n  |	 j j	 |  j	 k r | t  k r q n  xl |	 j j
 d | d | d | d | d	 |  D]= }
 t |
 d
 d  rQ|
 j |  j	 k rQq!n  | j |
  q!Wq Wn  | r|  j r|  j } x7 | D], } | s| j j r| j | j  qqWn  | r| j d d   t |  j |  j  D  | r| j d d   |  j D  qn  t d |  } | |  j | <| S)a  
        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: %sNr   r   r   r   seen_modelsr   c             s   s   |  ] } | Vq d  S)Nr4   )r3   r   r4   r4   r5   r6   %  s    z&Options._get_fields.<locals>.<genexpr>c             s   s   |  ] } | Vq d  S)Nr4   )r3   r   r4   r4   r5   r6   .  s    zget_fields())r   r9   r   rP   ro   rS   r   r_   rn   r^   r   rx   r   r&   rN   r   r   extendr   rT   rU   rV   rA   )ra   r   r   r   r   r   Ztopmost_callr   rC   r   r   Z
all_fieldsr   r4   r4   r5   r     sP    		$	#zOptions._get_fields)1rp   
__module____qualname__r   r   r   r`   rb   propertyrc   rd   rf   rg   r   r   r   r   r   r   r   r   r   r   r   r   r   rH   rI   rJ   rK   rC   rE   r   r   r   rF   rD   rL   rG   rM   r   r   r   r   r   rN   r   r   r   r4   r4   r4   r5   rB   L   s\   	97)$	
/"	$rB   )zverbose_namezverbose_name_pluralzdb_tablezorderingzunique_togetherzpermissionszget_latest_byzorder_with_respect_toz	app_labelzdb_tablespacezabstractzmanagedzproxyz	swappablezauto_createdzindex_togetherzappszdefault_permissionszselect_on_savezdefault_related_namezrequired_db_featureszrequired_db_vendorzbase_manager_namezdefault_manager_namezmanager_inheritance_from_future)5
__future__r   rs   r   r   collectionsr   r   	itertoolsr   Zdjango.appsr   Zdjango.confr   Zdjango.core.exceptionsr	   rm   r
   Zdjango.db.modelsr   Zdjango.db.models.fieldsr   Zdjango.db.models.fields.proxyr   Zdjango.utilsr   Zdjango.utils.datastructuresr   r   Zdjango.utils.deprecationr   r   Zdjango.utils.encodingr   r   r   Zdjango.utils.functionalr   Zdjango.utils.textr   Zdjango.utils.translationr   r   objectr   r   r2   r   r>   ru   r<   rA   rB   r4   r4   r4   r5   <module>   sD   			      