o
    e
                     @   sH   d Z ddlmZmZmZ eej  pe Zde	defddZ
dS )z:Contains utilities to handle datetimes in Huggingface Hub.    )datetime	timedeltatimezonedate_stringreturnc              
   C   sN   zt | d}|t7 }|tjW S  ty& } z	td|  d|d}~ww )a  
    Parses a date_string returned from the server to a datetime object.

    This parser is a weak-parser is the sense that it handles only a single format of
    date_string. It is expected that the server format will never change. The
    implementation depends only on the standard lib to avoid an external dependency
    (python-dateutil). See full discussion about this decision on PR:
    https://github.com/huggingface/huggingface_hub/pull/999.

    Example:
        ```py
        > parse_datetime('2022-08-19T07:19:38.123Z')
        datetime.datetime(2022, 8, 19, 7, 19, 38, 123000, tzinfo=timezone.utc)
        ```

    Args:
        date_string (`str`):
            A string representing a datetime returned by the Hub server.
            String is expected to follow '%Y-%m-%dT%H:%M:%S.%fZ' pattern.

    Returns:
        A python datetime object.

    Raises:
        :class:`ValueError`:
            If `date_string` cannot be parsed.
    z%Y-%m-%dT%H:%M:%S.%fZzCannot parse 'zS' as a datetime. Date string is expected to follow '%Y-%m-%dT%H:%M:%S.%fZ' pattern.N)r   strptime
UTC_OFFSET
astimezoner   utc
ValueError)r   dte r   OD:\Projects\ConvertPro\env\Lib\site-packages\huggingface_hub/utils/_datetime.pyparse_datetime   s   
r   N)__doc__r   r   r   nowr
   r	   	utcoffsetr   strr   r   r   r   r   <module>   s   