U
    ={f                     @  s   d Z ddlmZ ddlZddlmZmZmZ ddlm	Z	 ddl
mZ dZejf ejG d	d
 d
Zejf ejG dd dZejf ejG dd dZdS )z!Support for alias configurations.    )annotationsN)AnyCallableLiteral)PydanticUndefined   )_internal_dataclass)AliasGenerator	AliasPathAliasChoicesc                   @  sJ   e Zd ZU dZded< dddddd	Zd
dddZdddddZdS )r
   zUsage docs: https://docs.pydantic.dev/2.7/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]pathstrz	str | intNone)	first_argargsreturnc                 G  s   |gt | | _d S N)listr   )selfr   r    r   O/var/www/html/Darija-Ai-API/env/lib/python3.8/site-packages/pydantic/aliases.py__init__   s    zAliasPath.__init__zlist[str | int]r   c                 C  s   | j S )zvConverts arguments to a list of string or integer aliases.

        Returns:
            The list of aliases.
        )r   )r   r   r   r   convert_to_aliases   s    zAliasPath.convert_to_aliasesdictr   )dr   c                 C  sV   |}| j D ]F}t|tr t  S z|| }W q
 tttfk
rN   t Y   S X q
|S )zSearches a dictionary for the path specified by the alias.

        Returns:
            The value at the specified path, or `PydanticUndefined` if the path is not found.
        )r   
isinstancer   r   KeyError
IndexError	TypeError)r   r   vkr   r   r   search_dict_for_path%   s    

zAliasPath.search_dict_for_pathN)__name__
__module____qualname____doc____annotations__r   r   r"   r   r   r   r   r
      s
   
r
   c                   @  s:   e Zd ZU dZded< ddddddZd	d
ddZdS )r   zUsage docs: https://docs.pydantic.dev/2.7/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]choiceszstr | AliasPathr   )first_choicer(   r   c                 G  s   |gt | | _d S r   )r   r(   )r   r)   r(   r   r   r   r   C   s    zAliasChoices.__init__zlist[list[str | int]]r   c                 C  s:   g }| j D ]*}t|tr(||  q
||g q
|S )zConverts arguments to a list of lists containing string or integer aliases.

        Returns:
            The list of aliases.
        )r(   r   r
   appendr   )r   aliasescr   r   r   r   F   s    

zAliasChoices.convert_to_aliasesN)r#   r$   r%   r&   r'   r   r   r   r   r   r   r   7   s   
r   c                   @  sZ   e Zd ZU dZdZded< dZded< dZded< dd	d
ddddZd
ddddZ	dS )r	   a  Usage docs: https://docs.pydantic.dev/2.7/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_aliasz=Literal[('alias', 'validation_alias', 'serialization_alias')]z<tuple[type[str] | type[AliasPath] | type[AliasChoices], ...]r   z%str | AliasPath | AliasChoices | None)
alias_kindallowed_types
field_namer   c                 C  sH   d}t | | }rD||}|rDt||sDtd| d| d| d|S )zGenerate 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   r   )r   r0   r1   r2   r-   Zalias_generatorr   r   r   _generate_aliase   s    zAliasGenerator._generate_aliaszDtuple[str | None, str | AliasPath | AliasChoices | None, str | None])r2   r   c                 C  s>   |  dtf|}|  dtttf|}|  dtf|}|||fS )zGenerate `alias`, `validation_alias`, and `serialization_alias` for a field.

        Returns:
            A tuple of three aliases - validation, alias, and serialization.
        r-   r.   r/   )r5   r   r   r
   )r   r2   r-   r.   r/   r   r   r   generate_aliasesy   s    zAliasGenerator.generate_aliases)
r#   r$   r%   r&   r-   r'   r.   r/   r5   r6   r   r   r   r   r	   U   s   

r	   )r&   
__future__r   dataclassestypingr   r   r   Zpydantic_corer   	_internalr   __all__	dataclassZ
slots_truer
   r   r	   r   r   r   r   <module>   s   (