o
    h$*                     @   s   d Z ddlZddlZddlZddlZddlZddl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mZ ddlmZmZ eeZG dd	 d	ejZG d
d deZG dd dejZG dd deZdS )zBase option parser setup    N)suppress)AnyDictIteratorListTuple)UNKNOWN_ERROR)ConfigurationConfigurationError)redact_auth_from_url	strtoboolc                	       s   e Zd ZdZdededdf fddZdejdefd	d
Z		d!dejdededefddZ
dedefddZdedefddZdedefddZdedefddZdededefdd Z  ZS )"PrettyHelpFormatterz4A prettier/less verbose help formatter for optparse.argskwargsreturnNc                    s:   d|d< d|d< t  d d |d< t j|i | d S )N   max_help_position   indent_incrementr      width)shutilget_terminal_sizesuper__init__)selfr   r   	__class__ T/var/www/html/olx_land/venv/lib/python3.10/site-packages/pip/_internal/cli/parser.pyr      s   zPrettyHelpFormatter.__init__optionc                 C   s
   |  |S N)_format_option_strings)r   r    r   r   r   format_option_strings   s   
z)PrettyHelpFormatter.format_option_strings <{}>, mvarfmtoptsepc                 C   s   g }|j r||j d  |jr||jd  t|dkr$|d| | rA|jdus/J |jp6|j }||	|  d
|S )z
        Return a comma-separated list of option strings and metavars.

        :param option:  tuple of (short opt, long opt), e.g: ('-f', '--format')
        :param mvarfmt: metavar format string
        :param optsep:  separator
        r   r   N )_short_optsappend
_long_optsleninserttakes_valuedestmetavarlowerformatjoin)r   r    r&   r'   optsr0   r   r   r   r"      s   

z*PrettyHelpFormatter._format_option_stringsheadingc                 C   s   |dkrdS |d S )NOptionsr(   :
r   )r   r5   r   r   r   format_heading9   s   z"PrettyHelpFormatter.format_headingusagec                 C   s   d | t|d}|S )zz
        Ensure there is only one newline between usage and the first heading
        if there is no description.
        z
Usage: {}
  )r2   indent_linestextwrapdedent)r   r9   msgr   r   r   format_usage>   s   z PrettyHelpFormatter.format_usagedescriptionc                 C   sV   |r)t | jdrd}nd}|d}| }| t|d}| d| d}|S dS )NmainCommandsDescription
r:   r7   r(   )hasattrparserlstriprstripr;   r<   r=   )r   r@   labelr   r   r   format_descriptionF   s   
z&PrettyHelpFormatter.format_descriptionepilogc                 C   s   |r|S dS )Nr(   r   )r   rK   r   r   r   format_epilogX   s   z!PrettyHelpFormatter.format_epilogtextindentc                    s"    fdd| dD }d|S )Nc                    s   g | ]} | qS r   r   ).0linerN   r   r   
<listcomp>`   s    z4PrettyHelpFormatter.indent_lines.<locals>.<listcomp>rD   )splitr3   )r   rM   rN   	new_linesr   rQ   r   r;   _   s   
z PrettyHelpFormatter.indent_lines)r$   r%   )__name__
__module____qualname____doc__r   r   optparseOptionstrr#   r"   r8   r?   rJ   rL   r;   __classcell__r   r   r   r   r      s&    
r   c                       s,   e Zd ZdZdejdef fddZ  ZS )UpdatingDefaultsHelpFormatterzCustom help formatter for use in ConfigOptionParser.

    This is updates the defaults before expanding them, allowing
    them to show up correctly in the help listing.

    Also redact auth from url type options
    r    r   c                    s   d }| j d ur&t| j tsJ | j | j j |jd usJ | j j|j}t |}|rO|j	dkrOt|t
r;|g}t|tsBg }|D ]
}||t|}qD|S )NURL)rF   
isinstanceConfigOptionParser_update_defaultsdefaultsr/   getr   expand_defaultr0   r[   listreplacer   )r   r    default_values	help_textvalr   r   r   rd   m   s   


z,UpdatingDefaultsHelpFormatter.expand_default)	rU   rV   rW   rX   rY   rZ   r[   rd   r\   r   r   r   r   r]   d   s     r]   c                   @   s@   e Zd ZdedededejfddZede	ej
 fddZd	S )
CustomOptionParseridxr   r   r   c                 O   s,   | j |i |}| j  | j|| |S )z*Insert an OptionGroup at a given position.)add_option_groupoption_groupspopr-   )r   rk   r   r   groupr   r   r   insert_option_group   s   
z&CustomOptionParser.insert_option_groupc                 C   s*   | j dd }| jD ]}||j  q
|S )z<Get a list of all options, including those in option groups.N)option_listrm   extend)r   resir   r   r   option_list_all   s   
z"CustomOptionParser.option_list_allN)rU   rV   rW   intr   rY   OptionGrouprp   propertyr   rZ   ru   r   r   r   r   rj      s    
rj   c                       s   e Zd ZdZdddededededd	f
 fd
dZdej	dededefddZ
deeeef  fddZdeeef deeef fddZdejfddZdedd	fddZ  ZS )r`   zsCustom option parser which updates its defaults by checking the
    configuration files and environmental variablesF)isolatedr   namery   r   r   Nc                   s0   || _ t|| _| j sJ t j|i | d S r!   )rz   r	   configr   r   )r   rz   ry   r   r   r   r   r   r      s   

zConfigOptionParser.__init__r    keyri   c              
   C   sP   z| ||W S  tjy' } ztd|  td W Y d }~d S d }~ww )Nz(An error occurred during configuration:    )check_valuerY   OptionValueErrorprintsysexit)r   r    r|   ri   excr   r   r   check_default   s   z ConfigOptionParser.check_defaultc                 c   s    d| j dg}dd |D }| j D ]"\}}|s td| q|dd\}}||v r5|| ||f q|D ]}|| D ]	\}}||fV  q>q8d S )Nglobalz:env:c                 S   s   i | ]}|g qS r   r   )rO   rz   r   r   r   
<dictcomp>   s    zGConfigOptionParser._get_ordered_configuration_items.<locals>.<dictcomp>z7Ignoring configuration key '%s' as it's value is empty..r   )rz   r{   itemsloggerdebugrS   r*   )r   override_ordersection_itemssection_keyri   sectionr|   r   r   r    _get_ordered_configuration_items   s*   z3ConfigOptionParser._get_ordered_configuration_itemsrb   c              
      s  t j_t } D ]\ }d  du rqjdus%J jdv rCzt	|}W n t
yB   d|  Y nw jdkrtt
 t	|}W d   n1 s[w   Y  tt
 t|}W d   n1 ssw   Y  t|tr|dk rd|  nRjdkr| } fd	d
|D }n=jdkrֈjdusJ |j  }||}jpd}jpi }j||g|R i | n |}||j< q|D ]
 tj | < qd_|S )zUpdates the given defaults with values from the config files and
        the environ. Does a little special handling for certain types of
        options (lists).z--N)
store_truestore_falsezm{} is not a valid value for {} option, please specify a boolean value like yes/no, true/false or 1/0 instead.countr   z{} is not a valid value for {} option, please instead specify either a non-negative integer or a boolean value like yes/no or false/true which is equivalent to 1/0.r*   c                    s   g | ]	}  |qS r   )r   )rO   vr|   r    r   r   r   rR      s    z7ConfigOptionParser._update_defaults.<locals>.<listcomp>callbackr   )rY   Valuesrb   valuessetr   
get_optionr/   actionr   
ValueErrorerrorr2   r   rv   r_   rS   r   addget_opt_stringconvert_valuecallback_argscallback_kwargsr   getattr)r   rb   	late_evalri   opt_strr   r   r   r   r   ra      s\   









 z#ConfigOptionParser._update_defaultsc              
   C   s   | j s	t| jS z| j  W n ty* } z| tt	| W Y d}~nd}~ww | 
| j }|  D ]!}|jdus@J ||j}t|t	rX| }|||||j< q7t|S )zOverriding to make updating the defaults after instantiation of
        the option parser possible, _update_defaults() does the dirty work.N)process_default_valuesrY   r   rb   r{   loadr
   r   r   r[   ra   copy_get_all_optionsr/   rc   r_   r   r~   )r   errrb   r    defaultr   r   r   r   get_default_values  s"   

z%ConfigOptionParser.get_default_valuesr>   c                 C   s"   |  tj | t| d d S )NrD   )print_usager   stderrr   r   )r   r>   r   r   r   r   "  s   zConfigOptionParser.error)rU   rV   rW   rX   r   r[   boolr   rY   rZ   r   r   r   r   r   ra   r   r   r   r\   r   r   r   r   r`      s&    "@r`   )rX   loggingrY   r   r   r<   
contextlibr   typingr   r   r   r   r   pip._internal.cli.status_codesr   pip._internal.configurationr	   r
   pip._internal.utils.miscr   r   	getLoggerrU   r   IndentedHelpFormatterr   r]   OptionParserrj   r`   r   r   r   r   <module>   s     
R 