Mini Shell
B
��;H T� @ s� d Z ddlZddlZddlZddlmZ yddlZW n ek
rL dZY nX ddlT ddl m
Z
mZ ddlm
Z
mZmZ ddlmZ ddlmZ e�d �Zd
d� ZG dd
� d
�ZG dd� d�Zdd� ZdS )z}distutils.dist
Provides the Distribution class, which represents the module distribution
being built/installed/distributed.
� N)�message_from_file)�*)�FancyGetopt�translate_longopt)�
check_environ� strtobool�
rfc822_escape)�log)�DEBUGz^[a-zA-Z]([a-zA-Z0-9_]*)$c C sL t | t�rn<t | t�sHt| �j}d|� d|� d�}t�tj|� t| �} | S )Nz
Warning: 'z' should be a list, got type '�')�
isinstance�str�list�type�__name__r ZWARN)�valueZ fieldname�typename�msg� r �3/opt/alt/python37/lib64/python3.7/distutils/dist.py�_ensure_list s
r c @ sp e Zd ZdZdddddgZdZdd d
ddd
dddddddddddddddgZdd� eD �Zdd iZdad"d#�Z d$d%� Z
dbd'd(�Zd)d*� Zdcd+d,�Z
d-d.� Zd/d0� Zd1d2� Zd3d4� Zd5d5g fd6d7�Zd8d9� Zd:d;� Zd<d=� Zd>d?� Zd@dA� ZdBdC� ZdddDdE�ZdedFdG�ZdfdIdJ�ZejfdKdL�ZdMdN� ZdOdP� Z dQdR� Z!dSdT� Z"dUdV� Z#dWdX� Z$dYdZ� Z%d[d\� Z&d]d^� Z'd_d`� Z(d!S )g�Distributiona� The core of the Distutils. Most of the work hiding behind 'setup'
is really done within a Distribution instance, which farms the work out
to the Distutils commands specified on the command line.
Setup scripts will almost never instantiate Distribution directly,
unless the 'setup()' function is totally inadequate to their needs.
However, it is conceivable that a setup script might wish to subclass
Distribution for some specialized purpose, and then pass the subclass
to 'setup()' as the 'distclass' keyword argument. If so, it is
necessary to respect the expectations that 'setup' has of Distribution.
See the code for 'setup()', in core.py, for details.
)�verbose�vzrun verbosely (default)� )�quiet�qz!run quietly (turns verbosity off))zdry-run�nzdon't actually do anything)�help�hzshow detailed help message)zno-user-cfgNz-ignore pydistutils.cfg in your home directoryz�Common commands: (see '--help-commands' for more)
setup.py build will build the package underneath 'build/'
setup.py install will install the package
)z
help-commandsNzlist all available commands)�nameNzprint package name)�version�Vzprint package version)�fullnameNzprint <package name>-<version>)�authorNzprint the author's name)zauthor-emailNz print the author's email address)�
maintainerNzprint the maintainer's name)zmaintainer-emailNz$print the maintainer's email address)�contactNz7print the maintainer's name if known, else the author's)z
contact-emailNz@print the maintainer's email address if known, else the author's)�urlNzprint the URL for this package)�licenseNz print the license of the package)�licenceNzalias for --license)�descriptionNzprint the package description)zlong-descriptionNz"print the long package description)� platformsNzprint the list of platforms)�classifiersNzprint the list of classifiers)�keywordsNzprint the list of keywords)�providesNz+print the list of packages/modules provided)�requiresNz+print the list of packages/modules required)� obsoletesNz0print the list of packages/modules made obsoletec C s g | ]}t |d ��qS )r )r )�.0�xr r r �
<listcomp>� s zDistribution.<listcomp>r r Nc C sl d| _ d| _d| _x| jD ]}t| |d� qW t� | _x,| jjD ] }d| }t| |t| j|�� q@W i | _ d| _
d| _d| _i | _
g | _d| _i | _d| _d| _d| _d| _d| _d| _d| _d| _d| _d| _d| _i | _i | _|�r|�d�}|dk �rH|d= xD|�� D ]8\}}| � |�}x"|�� D ]\} }
d|
f|| <