U
    P^B                     @   s   d dl mZ d dlZd dlZd dl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 d dlmZ d d	lmZ d d
lmZ erd dlmZmZ d dlmZ eeZdd Zdd Zdd ZG dd deZ dS )    )absolute_importN)
cmdoptions)Command)make_target_python)SUCCESS)
indent_log)get_pip_version)MYPY_CHECK_RUNNING)
format_tag)AnyList)Valuesc                 C   s   t d| | d S )Nz{}: {})loggerinfoformat)namevalue r   =/tmp/pip-install-220asx0h/pip/pip/_internal/commands/debug.py
show_value   s    r   c               	   C   sF   t d ttdr"tj} | j}nd}t  td| W 5 Q R X d S )Nzsys.implementation:implementation r   )r   r   hasattrsysr   r   r   r   )r   implementation_namer   r   r   show_sys_implementation   s    

r   c           	   	   C   s   d}t | }| }| }d}|r.d|}dt||}t| | jdk rpt||krpd}|d | }nd}t 8 |D ]}tt	| q|rdj|d	}t| W 5 Q R X d S )
N
   r   z (target: {})zCompatible tags: {}{}   TFz?...
[First {tag_limit} tags shown. Pass --verbose to show all.])	tag_limit)
r   Zget_tagsZformat_givenr   lenr   r   verboser   r
   )	optionsr   Ztarget_pythontagsZformatted_targetsuffixmsgZtags_limitedtagr   r   r   	show_tags,   s,    

r&   c                       s0   e Zd ZdZdZdZ fddZdd Z  ZS )DebugCommandz$
    Display debug information.
    z
      %prog <options>Tc                    s4   t t| j|| | j}t| | jd| d S )Nr   )superr'   __init__cmd_optsr   Zadd_target_python_optionsparserinsert_option_group)selfargskwr*   	__class__r   r   r)   W   s    
zDebugCommand.__init__c                 C   sv   t d tdt  tdtj tdtj tdt  tdt  tdt	
  tdtj t  t| tS )	NzThis command is only meant for debugging. Do not use this with automation for parsing and getting these details, since the output and options of this command may change without notice.zpip versionzsys.versionzsys.executablezsys.getdefaultencodingzsys.getfilesystemencodingzlocale.getpreferredencodingzsys.platform)r   warningr   r   r   version
executablegetdefaultencodinggetfilesystemencodinglocalegetpreferredencodingplatformr   r&   r   )r-   r!   r.   r   r   r   run^   s      zDebugCommand.run)	__name__
__module____qualname____doc__usageignore_require_venvr)   r:   __classcell__r   r   r0   r   r'   N   s
   r'   )!
__future__r   r7   loggingr   Zpip._internal.clir   pip._internal.cli.base_commandr   Zpip._internal.cli.cmdoptionsr   pip._internal.cli.status_codesr   pip._internal.utils.loggingr   pip._internal.utils.miscr   pip._internal.utils.typingr	   pip._internal.wheelr
   typingr   r   optparser   	getLoggerr;   r   r   r   r&   r'   r   r   r   r   <module>   s&   
"