Ë
    ¹…`iB  ã                  ó2  — d Z ddlmZ ddlZddlmZmZ ddlmZ dZ	 ej                  di ej                  ¤Ž G d„ d	«      «       Z ej                  di ej                  ¤Ž G d
„ d«      «       Z ej                  di ej                  ¤Ž G d„ d«      «       Zy)z!Support for alias configurations.é    )ÚannotationsN)ÚCallableÚLiteralé   )Ú_internal_dataclass)ÚAliasGeneratorÚ	AliasPathÚAliasChoicesc                  ó,   — e Zd ZU dZded<   dd„Zdd„Zy)	r	   zíUsage docs: https://docs.pydantic.dev/2.6/concepts/alias#aliaspath-and-aliaschoices

    A data class used by `validation_alias` as a convenience to create aliases.

    Attributes:
        path: A list of string or integer aliases.
    zlist[int | str]Úpathc                ó,   — |gt        |«      z   | _        y ©N)Úlistr   )ÚselfÚ	first_argÚargss      úU/var/www/html/ts-aiml.yecor.com/venv/lib/python3.12/site-packages/pydantic/aliases.pyÚ__init__zAliasPath.__init__   s   € ØK¤$ t£*Ñ,ˆ	ó    c                ó   — | j                   S )zvConverts arguments to a list of string or integer aliases.

        Returns:
            The list of aliases.
        )r   )r   s    r   Úconvert_to_aliaseszAliasPath.convert_to_aliases   s   € ð y‰yÐr   N)r   Ústrr   z	str | intÚreturnÚNone)r   zlist[str | int]©Ú__name__Ú
__module__Ú__qualname__Ú__doc__Ú__annotations__r   r   © r   r   r	   r	      s   … ñð Óó-ôr   r	   c                  ó,   — e Zd ZU dZded<   dd„Zdd„Zy)	r
   zöUsage docs: https://docs.pydantic.dev/2.6/concepts/alias#aliaspath-and-aliaschoices

    A data class used by `validation_alias` as a convenience to create aliases.

    Attributes:
        choices: A list containing a string or `AliasPath`.
    zlist[str | AliasPath]Úchoicesc                ó,   — |gt        |«      z   | _        y r   )r   r#   )r   Úfirst_choicer#   s      r   r   zAliasChoices.__init__0   s   € Ø$~¬¨W«Ñ5ˆr   c                ó°   — g }| j                   D ]D  }t        |t        «      r |j                  |j	                  «       «       Œ3|j                  |g«       ŒF |S )z‡Converts arguments to a list of lists containing string or integer aliases.

        Returns:
            The list of aliases.
        )r#   Ú
isinstancer	   Úappendr   )r   ÚaliasesÚcs      r   r   zAliasChoices.convert_to_aliases3   sP   € ð *,ˆØ—‘ò 	$ˆAÜ˜!œYÔ'Ø—‘˜q×3Ñ3Ó5Õ6à—‘ ˜sÕ#ð		$ð
 ˆr   N)r%   ústr | AliasPathr#   r+   r   r   )r   zlist[list[str | int]]r   r!   r   r   r
   r
   $   s   … ñð #Ó"ó6ôr   r
   c                  ó\   — e Zd ZU dZdZded<   dZded<   dZded<   	 	 	 	 	 	 	 	 d
d„Zdd	„Z	y)r   aÛ  Usage docs: https://docs.pydantic.dev/2.6/concepts/alias#using-an-aliasgenerator

    A data class used by `alias_generator` as a convenience to create various aliases.

    Attributes:
        alias: A callable that takes a field name and returns an alias for it.
        validation_alias: A callable that takes a field name and returns a validation alias for it.
        serialization_alias: A callable that takes a field name and returns a serialization alias for it.
    NzCallable[[str], str] | NoneÚaliasz6Callable[[str], str | AliasPath | AliasChoices] | NoneÚvalidation_aliasÚserialization_aliasc           	     ó|   — d}t        | |«      x}r+ ||«      }|r!t        ||«      st        d|› d|› d|› d«      ‚|S )z·Generate an alias of the specified kind. Returns None if the alias generator is None.

        Raises:
            TypeError: If the alias generator produces an invalid type.
        Nz	Invalid `z	` type. `z!` generator must produce one of `ú`)Úgetattrr'   Ú	TypeError)r   Ú
alias_kindÚallowed_typesÚ
field_namer-   Úalias_generators         r   Ú_generate_aliaszAliasGenerator._generate_aliasR   sa   € ð ˆÜ% d¨JÓ7Ð7ˆ?Ð7Ù# JÓ/ˆEÙœZ¨¨}Ô=ÜØ 
˜|¨9°Z°LÐ@aÐboÐapÐpqÐróð ð ˆr   c                ó°   — | j                  dt        f|«      }| j                  dt        t        t        f|«      }| j                  dt        f|«      }|||fS )z´Generate `alias`, `validation_alias`, and `serialization_alias` for a field.

        Returns:
            A tuple of three aliases - validation, alias, and serialization.
        r-   r.   r/   )r8   r   r
   r	   )r   r6   r-   r.   r/   s        r   Úgenerate_aliaseszAliasGenerator.generate_aliasesf   sa   € ð ×$Ñ$ W¬s¨f°jÓAˆØ×/Ñ/Ð0BÄSÌ,ÔXaÐDbÐdnÓoÐØ"×2Ñ2Ð3HÌ3È&ÐR\Ó]ÐàÐ&Ð(;Ð;Ð;r   )r4   z;Literal['alias', 'validation_alias', 'serialization_alias']r5   z<tuple[type[str] | type[AliasPath] | type[AliasChoices], ...]r6   r   r   z%str | AliasPath | AliasChoices | None)r6   r   r   zDtuple[str | None, str | AliasPath | AliasChoices | None, str | None])
r   r   r   r   r-   r    r.   r/   r8   r:   r!   r   r   r   r   B   s]   … ñð *.€EÐ&Ó-ØOSÐÐLÓSØ7;ÐÐ4Ó;ðàOðð Tðð ð	ð
 
/óô(
<r   r   r!   )r   Ú
__future__r   ÚdataclassesÚtypingr   r   Ú	_internalr   Ú__all__Ú	dataclassÚ
slots_truer	   r
   r   r!   r   r   ú<module>rB      s©   ðÙ 'Ý "ã ß $å *à
9€ð €×ÑÑ8Ð,×7Ñ7Ñ8÷ð ó 9ðð. €×ÑÑ8Ð,×7Ñ7Ñ8÷ð ó 9ðð: €×ÑÑ8Ð,×7Ñ7Ñ8÷-<ð -<ó 9ñ-<r   