
    j	                         d Z ddlmZ ddlmZmZ ddlmZmZ ddlm	Z	  ede
eeed          Ze	ddd	d
edeeedf         deeedf         fd            ZdS )zBetween.    )datetime)TypeVarUnion   )AbsMaxAbsMin)	validatorPossibleValueTypesN)min_valmax_valvaluer   r   c                   | dS |t                      }|t                      }	 ||k    rt          d          n"# t          $ r}t          d          |d}~ww xY w|| cxk    o|k    nc S )a-  Validate that a number is between minimum and/or maximum value.

    This will work with any comparable type, such as floats, decimals and dates
    not just integers. This validator is originally based on [WTForms-NumberRange-Validator][1].

    [1]: https://github.com/wtforms/wtforms/blob/master/src/wtforms/validators.py#L166-L220

    Examples:
        >>> from datetime import datetime
        >>> between(5, min_val=2)
        True
        >>> between(13.2, min_val=13, max_val=14)
        True
        >>> between(500, max_val=400)
        ValidationError(func=between, args={'value': 500, 'max_val': 400})
        >>> between(
        ...     datetime(2000, 11, 11),
        ...     min_val=datetime(1999, 11, 11)
        ... )
        True

    Args:
        value:
            Value which is to be compared.
        min_val:
            The minimum required value of the number.
            If not provided, minimum value will not be checked.
        max_val:
            The maximum value of the number.
            If not provided, maximum value will not be checked.

    Returns:
        (Literal[True]): If `value` is in between the given conditions.
        (ValidationError): If `value` is not in between the given conditions.

    Raises:
        (ValueError): If `min_val` is greater than `max_val`.
        (TypeError): If there's a type mismatch during comparison.

    Note:
        - `PossibleValueTypes` = `TypeVar("PossibleValueTypes", int, float, str, datetime)`
        - If neither `min_val` nor `max_val` is provided, result will always be `True`.
    NFz*`min_val` cannot be greater than `max_val`zComparison type mismatch)r   r   
ValueError	TypeError)r   r   r   errs       U/var/www/html/Carbon-Document/venv/lib/python3.11/site-packages/validators/between.pybetweenr      s    f }u((((=WIJJJ  = = =233<= e&&&&w&&&&&s   < 
AAA)__doc__r   typingr   r   	_extremesr   r   utilsr	   intfloatstrr
   r        r   <module>r      s           ! ! ! ! ! ! ! ! & % % % % % % %      W13sHdSS  
 8<7;@' @' @'@' %vt34	@'
 %vt34@' @' @' @' @' @'r   