U
    g                     @   s^   d Z ddlZddlmZ ddlmZmZmZmZ dddd	gZ	d
d Z
edfddZdd	 ZdS )z
Commonly useful converters.
    N   )_AnnotationExtractor)NOTHING	ConverterFactorypipedefault_if_noneoptionalr   to_boolc                    s   t  tr fdd}n fdd}t }| }|rHtj| |jd< | }|rdtj| |jd< t  tr|t|dddS |S )a_  
    A converter that allows an attribute to be optional. An optional attribute
    is one which can be set to `None`.

    Type annotations will be inferred from the wrapped converter's, if it has
    any.

    Args:
        converter (typing.Callable):
            the converter that is used for non-`None` values.

    .. versionadded:: 17.1.0
    c                    s   | d krd S  | ||S N )valinstfield	converterr   3/tmp/pip-unpacked-wheel-4g8m5gbg/attr/converters.pyoptional_converter&   s    z$optional.<locals>.optional_converterc                    s   | d krd S  | S r   r   r   r   r   r   r   -   s    r   returnT)
takes_selfZtakes_field)
isinstancer   r   Zget_first_param_typetypingOptional__annotations__Zget_return_type)r   r   Zxtrtrtr   r   r   r	      s    

c                    s    t kr|dkrd}t| t k	r8|dk	r8d}t||dk	rHt| t trr jrdd}t| fdd}n fdd}|S )a  
    A converter that allows to replace `None` values by *default* or the result
    of *factory*.

    Args:
        default:
            Value to be used if `None` is passed. Passing an instance of
            `attrs.Factory` is supported, however the ``takes_self`` option is
            *not*.

        factory (typing.Callable):
            A callable that takes no parameters whose result is used if `None`
            is passed.

    Raises:
        TypeError: If **neither** *default* or *factory* is passed.

        TypeError: If **both** *default* and *factory* are passed.

        ValueError:
            If an instance of `attrs.Factory` is passed with
            ``takes_self=True``.

    .. versionadded:: 18.2.0
    Nz(Must pass either `default` or `factory`.z5Must pass either `default` or `factory` but not both.z1`takes_self` is not supported by default_if_none.c                    s   | d k	r| S    S r   )factoryr   defaultr   r   default_if_none_converterl   s    z2default_if_none.<locals>.default_if_none_converterc                    s   | d k	r| S  S r   r   r   r   r   r   r    t   s    )r   	TypeErrorr   r   r   
ValueError)r   r   msgr    r   r   r   r   B   s    
c                 C   s@   t | tr|  } | dkrdS | dkr*dS d| }t|dS )a  
    Convert "boolean" strings (for example, from environment variables) to real
    booleans.

    Values mapping to `True`:

    - ``True``
    - ``"true"`` / ``"t"``
    - ``"yes"`` / ``"y"``
    - ``"on"``
    - ``"1"``
    - ``1``

    Values mapping to `False`:

    - ``False``
    - ``"false"`` / ``"f"``
    - ``"no"`` / ``"n"``
    - ``"off"``
    - ``"0"``
    - ``0``

    Raises:
        ValueError: For any other value.

    .. versionadded:: 21.3.0
    )Ttruer   yesyon1r   T)Ffalsefnonoff0r   FzCannot convert value to bool: N)r   strlowerr"   )r   r#   r   r   r   r
   }   s    

)__doc__r   _compatr   _maker   r   r   r   __all__r	   r   r
   r   r   r   r   <module>   s   -;