o
    #Âif%  ã                   @   s†   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gZed	ƒZed
ƒZ	G dd„ dee ƒZ
G dd„ dƒZdS )é    )ÚAny)Úcast)ÚDict)ÚGeneric)ÚTypeVar)ÚUnionÚStashÚStashKeyÚTÚDc                   @   s   e Zd ZdZdZdS )r	   zï``StashKey`` is an object used as a key to a :class:`Stash`.

    A ``StashKey`` is associated with the type ``T`` of the value of the key.

    A ``StashKey`` is unique and cannot conflict with another key.

    .. versionadded:: 7.0
    © N)Ú__name__Ú
__module__Ú__qualname__Ú__doc__Ú	__slots__r   r   r   úF/var/www/html/corbot_env/lib/python3.10/site-packages/_pytest/stash.pyr	      s    	c                   @   sÄ   e Zd ZdZdZddd„Zdee deddfd	d
„Zdee defdd„Z	dee de
deee
f fdd„Zdee dedefdd„Zdee ddfdd„Zdee defdd„Zdefdd„ZdS )r   aJ  ``Stash`` is a type-safe heterogeneous mutable mapping that
    allows keys and value types to be defined separately from
    where it (the ``Stash``) is created.

    Usually you will be given an object which has a ``Stash``, for example
    :class:`~pytest.Config` or a :class:`~_pytest.nodes.Node`:

    .. code-block:: python

        stash: Stash = some_object.stash

    If a module or plugin wants to store data in this ``Stash``, it creates
    :class:`StashKey`\s for its keys (at the module level):

    .. code-block:: python

        # At the top-level of the module
        some_str_key = StashKey[str]()
        some_bool_key = StashKey[bool]()

    To store information:

    .. code-block:: python

        # Value type must match the key.
        stash[some_str_key] = "value"
        stash[some_bool_key] = True

    To retrieve the information:

    .. code-block:: python

        # The static type of some_str is str.
        some_str = stash[some_str_key]
        # The static type of some_bool is bool.
        some_bool = stash[some_bool_key]

    .. versionadded:: 7.0
    ©Ú_storageÚreturnNc                 C   s
   i | _ d S )Nr   ©Úselfr   r   r   Ú__init__H   s   
zStash.__init__ÚkeyÚvaluec                 C   s   || j |< dS )zSet a value for key.Nr   )r   r   r   r   r   r   Ú__setitem__K   s   zStash.__setitem__c                 C   s   t t| j| ƒS )zZGet the value for key.

        Raises ``KeyError`` if the key wasn't set before.
        )r   r
   r   ©r   r   r   r   r   Ú__getitem__O   s   zStash.__getitem__Údefaultc                 C   s"   z| | W S  t y   | Y S w )zNGet the value for key, or return default if the key wasn't set
        before.©ÚKeyError©r   r   r   r   r   r   ÚgetV   s
   
ÿz	Stash.getc                 C   s*   z| | W S  t y   || |< | Y S w )zmReturn the value of key if already set, otherwise set the value
        of key to default and return default.r   r!   r   r   r   Ú
setdefault^   s   
þzStash.setdefaultc                 C   s   | j |= dS )z]Delete the value for key.

        Raises ``KeyError`` if the key wasn't set before.
        Nr   r   r   r   r   Ú__delitem__g   s   zStash.__delitem__c                 C   s
   || j v S )zReturn whether key was set.r   r   r   r   r   Ú__contains__n   ó   
zStash.__contains__c                 C   s
   t | jƒS )z)Return how many items exist in the stash.)Úlenr   r   r   r   r   Ú__len__r   r&   zStash.__len__)r   N)r   r   r   r   r   r   r	   r
   r   r   r   r   r"   r#   r$   Úboolr%   Úintr(   r   r   r   r   r      s    (
"	N)Útypingr   r   r   r   r   r   Ú__all__r
   r   r	   r   r   r   r   r   Ú<module>   s    