o
    0j                     @   sL  d dl Z d dlZd dlmZ d dlmZmZ d dl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 d dlmZmZmZmZmZ dd	lmZ dd
lmZ ddlmZm Z m!Z! e "e#Z$ee%j&d d Z'ee%j&d d Z(e)dZ*G dd dZ+G dd de+Z,G dd de+Z-G dd de+Z.de/ded fddZ0de/eB de1dB fddZ2de/eB d e1ddfd!d"Z3dd#ddddd$d%e/d&e/d'e/d(e/d)e/d*ed+e/d,e/d-e/dB d.e4d/e/dB d0e/dB d1e/dB d2e/dB de1fd3d4Z5e!dd#ddddd#dd5d6e/d7e1d8e/dB d9e4d:e/dB d;e/dB d<e/dB d=e/dB d>e4d?e/dB de/fd@dAZ6dS )B    N)Path)AnyLiteral)hf_hub_download)upload_file)CardDataDatasetCardData
EvalResultModelCardDataSpaceCardDataeval_results_to_model_indexmodel_index_to_eval_results)HfHubHTTPErrorget_sessionhf_raise_for_statusis_jinja_available	yaml_dump   )	constants)EntryNotFoundError)SoftTemporaryDirectoryloggingvalidate_hf_hub_argsZ	templateszmodelcard_template.mdzdatasetcard_template.mdz1^(\s*---[\r\n]+)([\S\s]*?)([\r\n]+---(\r\n|\n|$))c                   @   s*  e Zd ZeZeZdZd$dede	fddZ
edd Zejdefd	dZd
d ZdeeB fddZe			d%deeB dedB dedB de	fddZd&dedB fddZ							d'dededB dedB dedB dedB dedB de	dB dedB fddZe		d(ded edB d!edB fd"d#ZdS ))RepoCardmodelFcontentignore_metadata_errorsc                 C   s   || _ || _dS )a  Initialize a RepoCard from string content. The content should be a
        Markdown file with a YAML block at the beginning and a Markdown body.

        Args:
            content (`str`): The content of the Markdown file.

        Example:
            ```python
            >>> from huggingface_hub.repocard import RepoCard
            >>> text = '''
            ... ---
            ... language: en
            ... license: mit
            ... ---
            ...
            ... # My repo
            ... '''
            >>> card = RepoCard(text)
            >>> card.data.to_dict()
            {'language': 'en', 'license': 'mit'}
            >>> card.text
            '\n# My repo\n'

            ```
        > [!TIP]
        > Raises the following error:
        >
        >     - [`ValueError`](https://docs.python.org/3/library/exceptions.html#ValueError)
        >       when the content of the repo card metadata is not a dictionary.
        N)r   r   )selfr   r    r   Y/var/www/html/Deteccion_Ine/venv/lib/python3.10/site-packages/huggingface_hub/repocard.py__init__*   s   "
zRepoCard.__init__c                 C   s:   t | jpd}d| | jj|| jd | d| | j S )zLThe content of the RepoCard, including the YAML block and the Markdown body.
---)
line_breakZoriginal_order)_detect_line_ending_contentdatato_yaml_original_ordertext)r   r#   r   r   r   r   O   s   ,zRepoCard.contentc                 C   s   || _ t|}|r-|d}|| d | _t|}|du r#i }t|t	s,t
dn
td i }|| _| jdi |d| ji| _t| | _dS )z Set the content of the RepoCard.   N)repo card metadata block should be a dictzBRepo card metadata block was not found. Setting CardData to empty.r   r   )r%   REGEX_YAML_BLOCKsearchgroupendr)   yaml	safe_load
isinstancedict
ValueErrorloggerwarningcard_data_classr   r&   listkeysr(   )r   r   match
yaml_blockZ	data_dictr   r   r   r   U   s    




c                 C   s   | j S N)r   )r   r   r   r   __str__p   s   zRepoCard.__str__filepathc                 C   s\   t |}|jjddd t|dddd}|t|  W d   dS 1 s'w   Y  dS )a{  Save a RepoCard to a file.

        Args:
            filepath (`Union[Path, str]`): Filepath to the markdown file to save.

        Example:
            ```python
            >>> from huggingface_hub.repocard import RepoCard
            >>> card = RepoCard("---\nlanguage: en\n---\n# This is a test repo card")
            >>> card.save("/tmp/test.md")

            ```
        T)parentsexist_okw utf-8modenewlineencodingN)r   parentmkdiropenwritestr)r   r>   fr   r   r   saves   s
   "zRepoCard.saveNrepo_id_or_path	repo_typetokenc                 C   s   t | rt |}nt|trt t|tj|p| j|d}ntd| d|j	dddd}| |
 |dW  d	   S 1 sBw   Y  d	S )
a  Initialize a RepoCard from a Hugging Face Hub repo's README.md or a local filepath.

        Args:
            repo_id_or_path (`Union[str, Path]`):
                The repo ID associated with a Hugging Face Hub repo or a local filepath.
            repo_type (`str`, *optional*):
                The type of Hugging Face repo to push to. Defaults to None, which will use "model". Other options
                are "dataset" and "space". Not used when loading from a local filepath. If this is called from a child
                class, the default value will be the child class's `repo_type`.
            token (`str`, *optional*):
                Authentication token, obtained with `huggingface_hub.HfApi.login` method. Will default to the stored token.
            ignore_metadata_errors (`str`):
                If True, errors while parsing the metadata section will be ignored. Some information might be lost during
                the process. Use it at your own risk.

        Returns:
            [`huggingface_hub.repocard.RepoCard`]: The RepoCard (or subclass) initialized from the repo's
                README.md file or filepath.

        Example:
            ```python
            >>> from huggingface_hub.repocard import RepoCard
            >>> card = RepoCard.load("nateraw/food")
            >>> assert card.data.tags == ["generated_from_trainer", "image-classification", "pytorch"]

            ```
        )rP   rQ   z.Cannot load RepoCard: path not found on disk (z).rrB   rC   rD   )r   N)r   is_filer2   rL   r   r   REPOCARD_NAMErP   r4   rJ   read)clsrO   rP   rQ   r   Z	card_pathrM   r   r   r   load   s   $

	$zRepoCard.loadc              
   C   sr   |p| j }|t| d}ddi}zt jd||d}t| W dS  ty8 } z|jdkr2t|j|d}~ww )a  Validates card against Hugging Face Hub's card validation logic.
        Using this function requires access to the internet, so it is only called
        internally by [`huggingface_hub.repocard.RepoCard.push_to_hub`].

        Args:
            repo_type (`str`, *optional*, defaults to "model"):
                The type of Hugging Face repo to push to. Options are "model", "dataset", and "space".
                If this function is called from a child class, the default will be the child class's `repo_type`.

        > [!TIP]
        > Raises the following errors:
        >
        >     - [`ValueError`](https://docs.python.org/3/library/exceptions.html#ValueError)
        >       if the card fails validation checks.
        >     - [`HTTPError`](https://requests.readthedocs.io/en/latest/api/#requests.HTTPError)
        >       if the request to the Hub API fails for any other reason.
        )ZrepoTyper   Acceptz
text/plainz(https://huggingface.co/api/validate-yaml)jsonheadersi  N)	rP   rL   r   postr   r   status_coder4   r)   )r   rP   bodyrZ   responseexcr   r   r   validate   s   


zRepoCard.validaterepo_idcommit_messagecommit_descriptionrevision	create_prparent_commitc	                 C   s   |p| j }| j|d t *}	t|	tj }
|
jt| dd tt|
tj||||||||d
}W d   |S 1 s;w   Y  |S )aB  Push a RepoCard to a Hugging Face Hub repo.

        Args:
            repo_id (`str`):
                The repo ID of the Hugging Face Hub repo to push to. Example: "nateraw/food".
            token (`str`, *optional*):
                Authentication token, obtained with `huggingface_hub.HfApi.login` method. Will default to
                the stored token.
            repo_type (`str`, *optional*, defaults to "model"):
                The type of Hugging Face repo to push to. Options are "model", "dataset", and "space". If this
                function is called by a child class, it will default to the child class's `repo_type`.
            commit_message (`str`, *optional*):
                The summary / title / first line of the generated commit.
            commit_description (`str`, *optional*)
                The description of the generated commit.
            revision (`str`, *optional*):
                The git revision to commit from. Defaults to the head of the `"main"` branch.
            create_pr (`bool`, *optional*):
                Whether or not to create a Pull Request with this commit. Defaults to `False`.
            parent_commit (`str`, *optional*):
                The OID / SHA of the parent commit, as a hexadecimal string. Shorthands (7 first characters) are also supported.
                If specified and `create_pr` is `False`, the commit will fail if `revision` does not point to `parent_commit`.
                If specified and `create_pr` is `True`, the pull request will be created from `parent_commit`.
                Specifying `parent_commit` ensures the repo has not changed before committing the changes, and can be
                especially useful if the repo is updated / committed too concurrently.
        Returns:
            `str`: URL of the commit which updated the card metadata.
        )rP   rC   )rG   )
Zpath_or_fileobjZpath_in_repora   rQ   rP   rb   rc   re   rd   rf   N)	rP   r`   r   r   r   rT   
write_textrL   r   )r   ra   rQ   rP   rb   rc   rd   re   rf   ZtmpdirZtmp_pathurlr   r   r   push_to_hub   s*   
)
zRepoCard.push_to_hub	card_datatemplate_pathtemplate_strc           	      K   s   t  rddl}ntd|  }|| |dur!t| }|du r,t| j }|	|}|j
dd| i|}| |S )a'  Initialize a RepoCard from a template. By default, it uses the default template.

        Templates are Jinja2 templates that can be customized by passing keyword arguments.

        Args:
            card_data (`huggingface_hub.CardData`):
                A huggingface_hub.CardData instance containing the metadata you want to include in the YAML
                header of the repo card on the Hugging Face Hub.
            template_path (`str`, *optional*):
                A path to a markdown file with optional Jinja template variables that can be filled
                in with `template_kwargs`. Defaults to the default template.

        Returns:
            [`huggingface_hub.repocard.RepoCard`]: A RepoCard instance with the specified card data and content from the
            template.
        r   NzjUsing RepoCard.from_template requires Jinja2 to be installed. Please install it with `pip install Jinja2`.rj   r   )r   jinja2ImportErrorto_dictcopyupdater   	read_textdefault_template_pathTemplaterenderr'   )	rV   rj   rk   rl   template_kwargsrm   kwargstemplater   r   r   r   from_template!  s   


zRepoCard.from_template)F)NNFr<   )NNNNNNNNN)__name__
__module____qualname__r   r7   TEMPLATE_MODELCARD_PATHrs   rP   rL   boolr    propertyr   setterr=   r   rN   classmethodrW   r`   ri   ry   r   r   r   r   r   %   sv    %
5(	
?r   c                	       H   e Zd ZeZeZdZe		ddede	dB de	dB f fddZ
  ZS )		ModelCardr   Nrj   rk   rl   c                       t  j|||fi |S )a
  Initialize a ModelCard from a template. By default, it uses the default template, which can be found here:
        https://github.com/huggingface/huggingface_hub/blob/main/src/huggingface_hub/templates/modelcard_template.md

        Templates are Jinja2 templates that can be customized by passing keyword arguments.

        Args:
            card_data (`huggingface_hub.ModelCardData`):
                A huggingface_hub.ModelCardData instance containing the metadata you want to include in the YAML
                header of the model card on the Hugging Face Hub.
            template_path (`str`, *optional*):
                A path to a markdown file with optional Jinja template variables that can be filled
                in with `template_kwargs`. Defaults to the default template.

        Returns:
            [`huggingface_hub.ModelCard`]: A ModelCard instance with the specified card data and content from the
            template.

        Example:
            ```python
            >>> from huggingface_hub import ModelCard, ModelCardData, EvalResult

            >>> # Using the Default Template
            >>> card_data = ModelCardData(
            ...     language='en',
            ...     license='mit',
            ...     library_name='timm',
            ...     tags=['image-classification', 'resnet'],
            ...     datasets=['beans'],
            ...     metrics=['accuracy'],
            ... )
            >>> card = ModelCard.from_template(
            ...     card_data,
            ...     model_description='This model does x + y...'
            ... )

            >>> # Including Evaluation Results
            >>> card_data = ModelCardData(
            ...     language='en',
            ...     tags=['image-classification', 'resnet'],
            ...     eval_results=[
            ...         EvalResult(
            ...             task_type='image-classification',
            ...             dataset_type='beans',
            ...             dataset_name='Beans',
            ...             metric_type='accuracy',
            ...             metric_value=0.9,
            ...         ),
            ...     ],
            ...     model_name='my-cool-model',
            ... )
            >>> card = ModelCard.from_template(card_data)

            >>> # Using a Custom Template
            >>> card_data = ModelCardData(
            ...     language='en',
            ...     tags=['image-classification', 'resnet']
            ... )
            >>> card = ModelCard.from_template(
            ...     card_data=card_data,
            ...     template_path='./src/huggingface_hub/templates/modelcard_template.md',
            ...     custom_template_var='custom value',  # will be replaced in template if it exists
            ... )

            ```
        superry   rV   rj   rk   rl   rv   	__class__r   r   ry   R  s   IzModelCard.from_templaterz   )r{   r|   r}   r
   r7   r~   rs   rP   r   rL   ry   __classcell__r   r   r   r   r   M      r   c                	       r   )	DatasetCarddatasetNrj   rk   rl   c                    r   )a  Initialize a DatasetCard from a template. By default, it uses the default template, which can be found here:
        https://github.com/huggingface/huggingface_hub/blob/main/src/huggingface_hub/templates/datasetcard_template.md

        Templates are Jinja2 templates that can be customized by passing keyword arguments.

        Args:
            card_data (`huggingface_hub.DatasetCardData`):
                A huggingface_hub.DatasetCardData instance containing the metadata you want to include in the YAML
                header of the dataset card on the Hugging Face Hub.
            template_path (`str`, *optional*):
                A path to a markdown file with optional Jinja template variables that can be filled
                in with `template_kwargs`. Defaults to the default template.

        Returns:
            [`huggingface_hub.DatasetCard`]: A DatasetCard instance with the specified card data and content from the
            template.

        Example:
            ```python
            >>> from huggingface_hub import DatasetCard, DatasetCardData

            >>> # Using the Default Template
            >>> card_data = DatasetCardData(
            ...     language='en',
            ...     license='mit',
            ...     annotations_creators='crowdsourced',
            ...     task_categories=['text-classification'],
            ...     task_ids=['sentiment-classification', 'text-scoring'],
            ...     multilinguality='monolingual',
            ...     pretty_name='My Text Classification Dataset',
            ... )
            >>> card = DatasetCard.from_template(
            ...     card_data,
            ...     pretty_name=card_data.pretty_name,
            ... )

            >>> # Using a Custom Template
            >>> card_data = DatasetCardData(
            ...     language='en',
            ...     license='mit',
            ... )
            >>> card = DatasetCard.from_template(
            ...     card_data=card_data,
            ...     template_path='./src/huggingface_hub/templates/datasetcard_template.md',
            ...     custom_template_var='custom value',  # will be replaced in template if it exists
            ... )

            ```
        r   r   r   r   r   ry     s   9zDatasetCard.from_templaterz   )r{   r|   r}   r   r7   TEMPLATE_DATASETCARD_PATHrs   rP   r   rL   ry   r   r   r   r   r   r     r   r   c                   @   s   e Zd ZeZeZdZdS )	SpaceCardspaceN)r{   r|   r}   r   r7   r~   rs   rP   r   r   r   r   r     s    r   r   return)r!   
Nc                 C   sR   |  d}|  d}|  d}|| dkrdS ||kr!||kr!dS ||kr'dS dS )zDetect the line ending of a string. Used by RepoCard to avoid making huge diff on newlines.

    Uses same implementation as in Hub server, keep it in sync.

    Returns:
        str: The detected line ending of the string.
    r   r!   r   r   N)count)r   crlfZcrlfr   r   r   r$     s   


r$   
local_pathc                 C   sP   t |  }t|}|r&|d}t|}|d u s t|tr"|S t	dd S )Nr*   r+   )
r   rr   r,   r-   r.   r0   r1   r2   r3   r4   )r   r   r:   r;   r&   r   r   r   metadata_load  s   


r   r&   c                 C   s&  d}d}t j| r:t| ddd!}| }t|jtr"|jd }n	t|jtr+|j}W d   n1 s5w   Y  t| ddddG}t	|d|d	}t
|}|rl|d|  d
| | d
|  || d  }nd
| | d
| | }|| |  W d   dS 1 sw   Y  dS )a&  
    Save the metadata dict in the upper YAML part Trying to preserve newlines as
    in the existing file. Docs about open() with newline="" parameter:
    https://docs.python.org/3/library/functions.html?highlight=open#open Does
    not work with "^M" linebreaks, which are replaced by 

    r!   rB   utf8)rF   rG   r   NrA   F)	sort_keysr#   r"   )ospathexistsrJ   rU   r2   newlinestuplerL   r   r,   r-   startr/   rK   close)r   r&   r#   r   ZreadmeZ	data_yamlr:   outputr   r   r   metadata_save  s(   
6

"r   F)metrics_configmetrics_verifieddataset_configdataset_splitdataset_revisionmetrics_verification_tokenmodel_pretty_nametask_pretty_nametask_idmetrics_pretty_name
metrics_idmetrics_valuedataset_pretty_name
dataset_idr   r   r   r   r   r   c                 C   s0   dt | t|||||||||	||
||dgdiS )u  
    Creates a metadata dict with the result from a model evaluated on a dataset.

    Args:
        model_pretty_name (`str`):
            The name of the model in natural language.
        task_pretty_name (`str`):
            The name of a task in natural language.
        task_id (`str`):
            Example: automatic-speech-recognition. A task id.
        metrics_pretty_name (`str`):
            A name for the metric in natural language. Example: Test WER.
        metrics_id (`str`):
            Example: wer. A metric id from https://hf.co/metrics.
        metrics_value (`Any`):
            The value from the metric. Example: 20.0 or "20.0 ± 1.2".
        dataset_pretty_name (`str`):
            The name of the dataset in natural language.
        dataset_id (`str`):
            Example: common_voice. A dataset id from https://hf.co/datasets.
        metrics_config (`str`, *optional*):
            The name of the metric configuration used in `load_metric()`.
            Example: bleurt-large-512 in `load_metric("bleurt", "bleurt-large-512")`.
        metrics_verified (`bool`, *optional*, defaults to `False`):
            Indicates whether the metrics originate from Hugging Face's [evaluation service](https://huggingface.co/spaces/autoevaluate/model-evaluator) or not. Automatically computed by Hugging Face, do not set.
        dataset_config (`str`, *optional*):
            Example: fr. The name of the dataset configuration used in `load_dataset()`.
        dataset_split (`str`, *optional*):
            Example: test. The name of the dataset split used in `load_dataset()`.
        dataset_revision (`str`, *optional*):
            Example: 5503434ddd753f426f4b38109466949a1217c2bb. The name of the dataset dataset revision
            used in `load_dataset()`.
        metrics_verification_token (`bool`, *optional*):
            A JSON Web Token that is used to verify whether the metrics originate from Hugging Face's [evaluation service](https://huggingface.co/spaces/autoevaluate/model-evaluator) or not.

    Returns:
        `dict`: a metadata dict with the result from a model evaluated on a dataset.

    Example:
        ```python
        >>> from huggingface_hub import metadata_eval_result
        >>> results = metadata_eval_result(
        ...         model_pretty_name="RoBERTa fine-tuned on ReactionGIF",
        ...         task_pretty_name="Text Classification",
        ...         task_id="text-classification",
        ...         metrics_pretty_name="Accuracy",
        ...         metrics_id="accuracy",
        ...         metrics_value=0.2662102282047272,
        ...         dataset_pretty_name="ReactionJPEG",
        ...         dataset_id="julien-c/reactionjpeg",
        ...         dataset_config="default",
        ...         dataset_split="test",
        ... )
        >>> results == {
        ...     'model-index': [
        ...         {
        ...             'name': 'RoBERTa fine-tuned on ReactionGIF',
        ...             'results': [
        ...                 {
        ...                     'task': {
        ...                         'type': 'text-classification',
        ...                         'name': 'Text Classification'
        ...                     },
        ...                     'dataset': {
        ...                         'name': 'ReactionJPEG',
        ...                         'type': 'julien-c/reactionjpeg',
        ...                         'config': 'default',
        ...                         'split': 'test'
        ...                     },
        ...                     'metrics': [
        ...                         {
        ...                             'type': 'accuracy',
        ...                             'value': 0.2662102282047272,
        ...                             'name': 'Accuracy',
        ...                             'verified': False
        ...                         }
        ...                     ]
        ...                 }
        ...             ]
        ...         }
        ...     ]
        ... }
        True

        ```
    model-index)Z	task_nameZ	task_typemetric_namemetric_typemetric_valueZdataset_nameZdataset_typeZmetric_configverifiedverify_tokenr   r   r   )
model_nameeval_results)r   r	   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   metadata_eval_result'  s(   ir   )rP   	overwriterQ   rb   rc   rd   re   rf   ra   metadatarP   r   rQ   rb   rc   rd   re   rf   c             
   C   s  |dur|nd}|du s|dkrt }
n|dkrt}
n|dkr!t}
ntd| z
|
j| ||d}W n tyI   |dkrAtd|
t }Y nw | D ]\}}|d	krd
|d vrft	|d| |d d
< t
|\}}|jjdu r{||j_||j_qN|jj}|D ]9}d}|D ])}||r||kr|std|j d|j dd}|j|_|jdu r|j|_q|s|jj| qqN|j|dur|s|j||krtd| d||j|< qN|j| |||||||	dS )a  
    Updates the metadata in the README.md of a repository on the Hugging Face Hub.
    If the README.md file doesn't exist yet, a new one is created with metadata and
    the default ModelCard or DatasetCard template. For `space` repo, an error is thrown
    as a Space cannot exist without a `README.md` file.

    Args:
        repo_id (`str`):
            The name of the repository.
        metadata (`dict`):
            A dictionary containing the metadata to be updated.
        repo_type (`str`, *optional*):
            Set to `"dataset"` or `"space"` if updating to a dataset or space,
            `None` or `"model"` if updating to a model. Default is `None`.
        overwrite (`bool`, *optional*, defaults to `False`):
            If set to `True` an existing field can be overwritten, otherwise
            attempting to overwrite an existing field will cause an error.
        token (`str`, *optional*):
            The Hugging Face authentication token.
        commit_message (`str`, *optional*):
            The summary / title / first line of the generated commit. Defaults to
            `f"Update metadata with huggingface_hub"`
        commit_description (`str` *optional*)
            The description of the generated commit
        revision (`str`, *optional*):
            The git revision to commit from. Defaults to the head of the
            `"main"` branch.
        create_pr (`boolean`, *optional*):
            Whether or not to create a Pull Request from `revision` with that commit.
            Defaults to `False`.
        parent_commit (`str`, *optional*):
            The OID / SHA of the parent commit, as a hexadecimal string. Shorthands (7 first characters) are also supported.
            If specified and `create_pr` is `False`, the commit will fail if `revision` does not point to `parent_commit`.
            If specified and `create_pr` is `True`, the pull request will be created from `parent_commit`.
            Specifying `parent_commit` ensures the repo has not changed before committing the changes, and can be
            especially useful if the repo is updated / committed too concurrently.
    Returns:
        `str`: URL of the commit which updated the card metadata.

    Example:
        ```python
        >>> from huggingface_hub import metadata_update
        >>> metadata = {'model-index': [{'name': 'RoBERTa fine-tuned on ReactionGIF',
        ...             'results': [{'dataset': {'name': 'ReactionGIF',
        ...                                      'type': 'julien-c/reactiongif'},
        ...                           'metrics': [{'name': 'Recall',
        ...                                        'type': 'recall',
        ...                                        'value': 0.7762102282047272}],
        ...                          'task': {'name': 'Text Classification',
        ...                                   'type': 'text-classification'}}]}]}
        >>> url = metadata_update("hf-internal-testing/reactiongif-roberta-card", metadata)

        ```
    Nz$Update metadata with huggingface_hubr   r   r   zUnknown repo_type: )rQ   rP   zJCannot update metadata on a Space that doesn't contain a `README.md` file.r   namer   r   Fz6You passed a new value for the existing metric 'name: z, type: z6'. Set `overwrite=True` to overwrite existing metrics.Tz9You passed a new value for the existing meta data field 'z7'. Set `overwrite=True` to overwrite existing metadata.)rQ   rP   rb   rc   re   rd   rf   )r   r   r   r4   rW   r   ry   r   itemsgetattrr   r&   r   r   Zis_equal_except_valuer   r   r   r   r   appendgetri   )ra   r   rP   r   rQ   rb   rc   rd   re   rf   Z
card_classZcardkeyvaluer   Znew_resultsZexisting_resultsZ
new_resultZresult_foundZexisting_resultr   r   r   metadata_update  sx   D


$
r   )7r   repathlibr   typingr   r   r0   Zhuggingface_hub.file_downloadr   Zhuggingface_hub.hf_apir   Zhuggingface_hub.repocard_datar   r   r	   r
   r   r   r   Zhuggingface_hub.utilsr   r   r   r   r   rB   r   errorsr   utilsr   r   r   Z
get_loggerr{   r5   __file__rH   r~   r   compiler,   r   r   r   r   rL   r$   r3   r   r   r   r   r   r   r   r   r   <module>   s    $	

  *QA*	

 	
