o
    h                     @   s|   d Z ddlmZ ddlmZmZ ddlmZ ddlm	Z	 ddl
mZ ddlmZ eeZG d	d
 d
ZG dd de	ZdS )a  Contains command to update or delete files in a repository using the CLI.

Usage:
    # delete all
    huggingface-cli repo-files <repo_id> delete "*"

    # delete single file
    huggingface-cli repo-files <repo_id> delete file.txt

    # delete single folder
    huggingface-cli repo-files <repo_id> delete folder/

    # delete multiple
    huggingface-cli repo-files <repo_id> delete file.txt folder/ file2.txt

    # delete multiple patterns
    huggingface-cli repo-files <repo_id> delete file.txt "*.json" "folder/*.parquet"

    # delete from different revision / repo-type
    huggingface-cli repo-files <repo_id> delete file.txt --revision=refs/pr/1 --repo-type=dataset
    )_SubParsersAction)ListOptional)logging)BaseHuggingfaceCLICommand)HfApi   )show_deprecation_warningc                   @   s    e Zd ZdddZdddZdS )DeleteFilesSubCommandreturnNc                 C   sZ   || _ |j| _|j| _|j| _t|jdd| _|j| _|j| _|j	| _	|j
| _
|j| _d S )Nzhuggingface-cli)tokenlibrary_name)argsrepo_id	repo_typerevisionr   r   apipatternscommit_messagecommit_description	create_pr)selfr    r   `/var/www/Befach/backend/venv/lib/python3.10/site-packages/huggingface_hub/commands/repo_files.py__init__3   s   zDeleteFilesSubCommand.__init__c              	   C   sV   t dd t  | jj| j| j| j| j| j	| j
| jd}td| d t  d S )Nzhuggingface-cli repo-fileszhf repo-files)delete_patternsr   r   r   r   r   r   z+Files correctly deleted from repo. Commit: .)r	   r   set_verbosity_infor   delete_filesr   r   r   r   r   r   r   printset_verbosity_warning)r   urlr   r   r   run?   s   
	zDeleteFilesSubCommand.run)r   N)__name__
__module____qualname__r   r"   r   r   r   r   r
   2   s    
r
   c                   @   s   e Zd ZedefddZdS )RepoFilesCommandparserc                 C   s   | j ddd}|jdtdd |jddd	}|j d
dd}|jdd d |jddtdd |jdg dddd |jdtdd |jdtdd |jdtdd |jddd d! |jd"td#d |jtd d S )$Nz
repo-filesz!Manage files in a repo on the Hub)helpr   z9The ID of the repo to manage (e.g. `username/repo-name`).)typer(   z$Action to execute against the files.T)r(   requireddeletez#Delete files from a repo on the Hubc                 S   s   t | S )N)r
   )r   r   r   r   <lambda>_   s    z6RepoFilesCommand.register_subcommand.<locals>.<lambda>)funcr   +z'Glob patterns to match files to delete.)nargsr)   r(   z--repo-type)modeldatasetspacer0   z/Type of the repo to upload to (e.g. `dataset`).)choicesdefaultr(   z
--revisionzAn optional Git revision to push to. It can be a branch name or a PR reference. If revision does not exist and `--create-pr` is not set, a branch will be automatically created.z--commit-messagez9The summary / title / first line of the generated commit.z--commit-descriptionz(The description of the generated commit.z--create-pr
store_truez7Whether to create a new Pull Request for these changes.)actionr(   z--tokenzIA User Access Token generated from https://huggingface.co/settings/tokens)
add_parseradd_argumentstradd_subparsersset_defaultsr&   )r'   repo_files_parserrepo_files_subparsersdelete_subparserr   r   r   register_subcommandQ   sZ   	z$RepoFilesCommand.register_subcommandN)r#   r$   r%   staticmethodr   r?   r   r   r   r   r&   P   s    r&   N)__doc__argparser   typingr   r   huggingface_hubr   huggingface_hub.commandsr   huggingface_hub.hf_apir   
_cli_utilsr	   
get_loggerr#   loggerr
   r&   r   r   r   r   <module>   s   
