o
    h!M                     @   s6  d dl Z d dlZd dl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 dlmZ d dlmZ d dlmZmZmZmZmZmZmZmZmZmZmZ d dlZedeZed	eZd
d Zdedee gef fddZ!dde j"e j"dddee ee  f de dedeg ef de#de j$fddZ%G dd deZ&dS )    N)ArgumentDefaultsHelpFormatterArgumentParserArgumentTypeError)copy)Enum)isclassPath)AnyCallableDictIterableListLiteralNewTypeOptionalTupleUnionget_type_hints	DataClassDataClassTypec                 C   s>   t | tr| S |  dv rdS |  dv rdS td|  d)N)yestruety1T)nofalsefn0FzTruthy value expected: got zJ but expected one of yes/no, true/false, t/f, y/n, 1/0 (case insensitive).)
isinstanceboollowerr   )v r%   O/var/www/html/ai/venv/lib/python3.10/site-packages/transformers/hf_argparser.pystring_to_bool"   s   

r'   choicesreturnc                    s   dd | D   fddS )aN  
    Creates a mapping function from each choices string representation to the actual value. Used to support multiple
    value types for a single argument.

    Args:
        choices (list): List of choices.

    Returns:
        Callable[[str], Any]: Mapping function from string representation to actual value for each choice.
    c                 S   s   i | ]}t ||qS r%   )str).0choicer%   r%   r&   
<dictcomp>:   s    z-make_choice_type_function.<locals>.<dictcomp>c                    s     | | S )N)get)argstr_to_choicer%   r&   <lambda>;   s    z+make_choice_type_function.<locals>.<lambda>r%   )r(   r%   r0   r&   make_choice_type_function/   s   r3   )aliaseshelpdefaultdefault_factorymetadatar4   r5   r6   r7   r8   c                 K   sD   |du ri }| dur| |d< |dur||d< t jd|||d|S )a  Argument helper enabling a concise syntax to create dataclass fields for parsing with `HfArgumentParser`.

    Example comparing the use of `HfArg` and `dataclasses.field`:
    ```
    @dataclass
    class Args:
        regular_arg: str = dataclasses.field(default="Huggingface", metadata={"aliases": ["--example", "-e"], "help": "This syntax could be better!"})
        hf_arg: str = HfArg(default="Huggingface", aliases=["--example", "-e"], help="What a nice syntax!")
    ```

    Args:
        aliases (Union[str, List[str]], optional):
            Single string or list of strings of aliases to pass on to argparse, e.g. `aliases=["--example", "-e"]`.
            Defaults to None.
        help (str, optional): Help string to pass on to argparse that can be displayed with --help. Defaults to None.
        default (Any, optional):
            Default value for the argument. If not default or default_factory is specified, the argument is required.
            Defaults to dataclasses.MISSING.
        default_factory (Callable[[], Any], optional):
            The default_factory is a 0-argument function called to initialize a field's value. It is useful to provide
            default values for mutable types, e.g. lists: `default_factory=list`. Mutually exclusive with `default=`.
            Defaults to dataclasses.MISSING.
        metadata (dict, optional): Further metadata to pass on to `dataclasses.field`. Defaults to None.

    Returns:
        Field: A `dataclasses.Field` with the desired properties.
    Nr4   r5   )r8   r6   r7   r%   )dataclassesfield)r4   r5   r6   r7   r8   kwargsr%   r%   r&   HfArg>   s   $r<   c                	       s   e Zd ZU dZee ed< deeee f f fddZe	de
dejfddZd	efd
dZ					ddeedf fddZddeeef dedeedf fddZddededeedf fddZddededeedf fddZ  ZS )HfArgumentParsera  
    This subclass of `argparse.ArgumentParser` uses type hints on dataclasses to generate arguments.

    The class is designed to play well with the native argparse. In particular, you can add more (non-dataclass backed)
    arguments to the parser after initialization and you'll get the output back after parsing as an additional
    namespace. Optional: To create sub argument groups use the `_argument_group_name` attribute in the dataclass.
    dataclass_typesc                    sV   d|vrt |d< t jdi | t|r|g}t|| _| jD ]}| | q!dS )a%  
        Args:
            dataclass_types:
                Dataclass type, or list of dataclass types for which we will "fill" instances with the parsed args.
            kwargs (`Dict[str, Any]`, *optional*):
                Passed to `argparse.ArgumentParser()` in the regular way.
        formatter_classNr%   )r   super__init__r9   is_dataclasslistr>   _add_dataclass_arguments)selfr>   r;   dtype	__class__r%   r&   rA   x   s   	


zHfArgumentParser.__init__parserr:   c                 C   sh  d|j  }|j }t|jtrtd|dg }t|tr#|g}t|jd|j}|t	u s:t
tdrt|tjrt|jjvrYt|jjdksPtd |jjvrYtd|j  dtd |jjvr|jjd	 tkro|jjd
 n|jjd	 |_t|jd|j}n$t|jjvrtd |jjd	 r|jjd
 n|jjd	 |_t|jd|j}i }|tu st|jtrt|jtr|tu r|jj|d< n
dd |jD |d< t|d |d< |jtjur|j|d< nd|d< n|jtu s|jtt kr$t|}t|d< |jtu s|jd ur#|jtjur#|jtju rdn|j}||d< d|d< d|d< nUt|rUt|trU|jjd
 |d< d|d< |jtjurI| |d< n0|jtju rTd|d< n$|j|d< |jtjurg|j|d< n|jtjuru| |d< nd|d< | j|g|R i | |jdu r|jtu s|jtt krd|d< | jd|j  fd|j d| d S d S d S )Nz--zpUnresolved type detected, which should have been done with the help of `typing.get_type_hints` method by defaultr4   
__origin__	UnionType   zOnly `Union[X, NoneType]` (i.e., `Optional[X]`) is allowed for `Union` because the argument parser only supports one type per argument. Problem encountered in field 'z'.   r   r(   c                 S   s   g | ]}|j qS r%   )value)r+   xr%   r%   r&   
<listcomp>   s    z;HfArgumentParser._parse_dataclass_field.<locals>.<listcomp>typer6   TrequiredF?nargsconst+z--no_store_false)actiondest)namer8   r   r!   rQ   r*   RuntimeErrorpopgetattrr   hasattrtypesrK   __args__len
ValueErrorr"   r   
issubclassr   r3   r6   r9   MISSINGr   r'   r   rC   r7   add_argument)rI   r:   
field_namer;   r4   origin_typebool_kwargsr6   r%   r%   r&   _parse_dataclass_field   s|   

 *( 
&
(&z'HfArgumentParser._parse_dataclass_fieldrF   c              
   C   s   t |dr| |j}n| }zt|}W nC ty#   td| d tyW } z)tjd d dk rRdt	|v rRd
tt	tjd d }td| d	| d
| d }~ww t|D ]}|jscq]||j |_| || q]d S )N_argument_group_namezType resolution failed for z. Try declaring the class in global scope or removing line of `from __future__ import annotations` which opts in Postponed Evaluation of Annotations (PEP 563)rL   )   
   z!unsupported operand type(s) for |.rk   z on Python a6  . Try removing line of `from __future__ import annotations` which opts in union types as `X | Y` (PEP 604) via Postponed Evaluation of Annotations (PEP 563). To support Python versions that lower than 3.10, you need to use `typing.Union[X, Y]` instead of `X | Y` and `typing.Optional[X]` instead of `X | None`.)r^   add_argument_grouprj   r   	NameErrorr[   	TypeErrorsysversion_infor*   joinmapr9   fieldsinitrZ   rQ   ri   )rE   rF   rI   
type_hintsexpython_versionr:   r%   r%   r&   rD      s4   

z)HfArgumentParser._add_dataclass_argumentsNFTr)   .c                    s  |s|s|r{t tjr{g }|r|t| n|r+t tjr+|ttjd d |rWt }|j|tdd |j	|d\}}t
||dd}	|	rW|dd	 |	D  g }
|D ]}| ri|
|  7 }
q[|durr|
| n|
tjd
d  }| j	|d\}}g }| jD ]/}dd t|D   fddt
| D } D ]}t|| q|di |}|| qt |jdkr|| |rg ||R S |rtd| g |R S )a'  
        Parse command-line args into instances of the specified dataclass types.

        This relies on argparse's `ArgumentParser.parse_known_args`. See the doc at:
        docs.python.org/3.7/library/argparse.html#argparse.ArgumentParser.parse_args

        Args:
            args:
                List of strings to parse. The default is taken from sys.argv. (same as argparse.ArgumentParser)
            return_remaining_strings:
                If true, also return a list of remaining argument strings.
            look_for_args_file:
                If true, will look for a ".args" file with the same base name as the entry point script for this
                process, and will append its potential content to the command line args.
            args_filename:
                If not None, will uses this file instead of the ".args" file specified in the previous argument.
            args_file_flag:
                If not None, will look for a file in the command-line args specified with this flag. The flag can be
                specified multiple times and precedence is determined by the order (last one wins).

        Returns:
            Tuple consisting of:

                - the dataclass instances in the same order as they were passed to the initializer.abspath
                - if applicable, an additional namespace for more (non-dataclass backed) arguments added to the parser
                  after initialization.
                - The potential list of remaining argument strings. (same as argparse.ArgumentParser.parse_known_args)
        r   z.argsappend)rQ   rX   )args-Nc                 S   s   g | ]}t |qS r%   r   )r+   pr%   r%   r&   rP   A  s    z@HfArgumentParser.parse_args_into_dataclasses.<locals>.<listcomp>rM   c                 S      h | ]}|j r|jqS r%   rv   rZ   r+   r   r%   r%   r&   	<setcomp>N      z?HfArgumentParser.parse_args_into_dataclasses.<locals>.<setcomp>c                       i | ]\}}| v r||qS r%   r%   r+   kr$   keysr%   r&   r-   O      z@HfArgumentParser.parse_args_into_dataclasses.<locals>.<dictcomp>z?Some specified arguments are not used by the HfArgumentParser: r%   )ra   rq   argvrz   r	   with_suffixr   re   r*   parse_known_argsvarsr.   lstripextendexists	read_textsplitr>   r9   ru   itemsdelattr__dict__rb   )rE   r{   return_remaining_stringslook_for_args_fileargs_filenameargs_file_flag
args_filesargs_file_parsercfgcmd_args_file_paths	file_args	args_file	namespaceremaining_argsoutputsrF   inputsr   objr%   r   r&   parse_args_into_dataclasses	  sF   %"


z,HfArgumentParser.parse_args_into_dataclassesr{   allow_extra_keysc                    s   t | }g }| jD ]*}dd t|D   fdd| D }||  |di |}|| q|sC|rCtdt	| t
|S )a<  
        Alternative helper method that does not use `argparse` at all, instead uses a dict and populating the dataclass
        types.

        Args:
            args (`dict`):
                dict containing config values
            allow_extra_keys (`bool`, *optional*, defaults to `False`):
                Defaults to False. If False, will raise an exception if the dict contains keys that are not parsed.

        Returns:
            Tuple consisting of:

                - the dataclass instances in the same order as they were passed to the initializer.
        c                 S   r~   r%   r   r   r%   r%   r&   r   r  r   z.HfArgumentParser.parse_dict.<locals>.<setcomp>c                    r   r%   r%   r   r   r%   r&   r-   s  r   z/HfArgumentParser.parse_dict.<locals>.<dictcomp>z0Some keys are not used by the HfArgumentParser: Nr%   )setr   r>   r9   ru   r   difference_updaterz   rb   sortedtuple)rE   r{   r   unused_keysr   rF   r   r   r%   r   r&   
parse_dict_  s   
zHfArgumentParser.parse_dict	json_filec                 C   sT   t t|dd}t| }W d   n1 sw   Y  | j||d}t|S )at  
        Alternative helper method that does not use `argparse` at all, instead loading a json file and populating the
        dataclass types.

        Args:
            json_file (`str` or `os.PathLike`):
                File name of the json file to parse
            allow_extra_keys (`bool`, *optional*, defaults to `False`):
                Defaults to False. If False, will raise an exception if the json file contains keys that are not
                parsed.

        Returns:
            Tuple consisting of:

                - the dataclass instances in the same order as they were passed to the initializer.
        zutf-8)encodingNr   )openr	   jsonloadsreadr   r   )rE   r   r   open_json_filedatar   r%   r%   r&   parse_json_file{  s
   z HfArgumentParser.parse_json_file	yaml_filec                 C   s$   | j tt| |d}t|S )at  
        Alternative helper method that does not use `argparse` at all, instead loading a yaml file and populating the
        dataclass types.

        Args:
            yaml_file (`str` or `os.PathLike`):
                File name of the yaml file to parse
            allow_extra_keys (`bool`, *optional*, defaults to `False`):
                Defaults to False. If False, will raise an exception if the json file contains keys that are not
                parsed.

        Returns:
            Tuple consisting of:

                - the dataclass instances in the same order as they were passed to the initializer.
        r   )r   yaml	safe_loadr	   r   r   )rE   r   r   r   r%   r%   r&   parse_yaml_file  s   z HfArgumentParser.parse_yaml_file)NFTNN)F)__name__
__module____qualname____doc__r   r   __annotations__r   rA   staticmethodr   r9   Fieldri   rD   r   r   r   r   r*   r
   r"   r   r   r   __classcell__r%   r%   rG   r&   r=   m   s$   
 \$

(V (r=   )'r9   r   rq   r_   argparser   r   r   r   enumr   inspectr   pathlibr	   typingr
   r   r   r   r   r   r   r   r   r   r   r   r   r   r'   rC   r*   r3   rd   dictr   r<   r=   r%   r%   r%   r&   <module>   sD   4



/