U
    ccnb                     @   s  d 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 ddlmZ ddl	m
Z
mZmZmZmZmZmZmZmZmZmZ ddlmZmZ ddlmZmZ dd	lmZmZ dd
lmZ ddl m!Z! ddl"m#Z# e
rddl$m%Z% ddl&m'Z' ee(ej)f Z*ededef f Z+ede+f Z,eded dZ-d5e*e.dddZ/de*ddddZ0d6de*ee* e1ed ddd Z2e-e(d!d"d#Z3ed e.d$d%d&Z4d7de,ed' d(d)d*Z5e(e(e6d+d,d-Z7G d.d/ d/ee- Z8G d0d1 d1e8d2 Z9G d3d4 d4e8d Z:dS )8ze
Load setuptools configuration from ``setup.cfg`` files.

**API will be made private in the future**
    N)defaultdict)partialwraps)TYPE_CHECKINGCallableAnyDictGenericIterableListOptionalTupleTypeVarUnion)DistutilsOptionErrorDistutilsFileError)RequirementInvalidRequirement)VersionInvalidVersion)SpecifierSet)SetuptoolsDeprecationWarning   )expandDistribution)DistributionMetadatastrTarget)r   r   )boundF)filepathreturnc                 C   s8   ddl m} | }|r| ng }t|| ||}t|S )a,  Read given configuration file and returns options from it as a dict.

    :param str|unicode filepath: Path to configuration file
        to get options from.

    :param bool find_others: Whether to search for other configuration files
        which could be on in various places.

    :param bool ignore_option_errors: Whether to silently ignore
        options, values of which could not be resolved (e.g. due to exceptions
        in directives such as file:, attr:, etc.).
        If False exceptions are propagated as expected.

    :rtype: dict
    r   r   )setuptools.distr   find_config_files_applyconfiguration_to_dict)r!   Zfind_othersignore_option_errorsr   dist	filenameshandlers r+   T/var/www/html/project/venv/lib/python3.8/site-packages/setuptools/config/setupcfg.pyread_configuration(   s
    r-   r   )r(   r!   r"   c                 C   s   t | | |   | S )z`Apply the configuration from a ``setup.cfg`` file into an existing
    distribution object.
    )r%   _finalize_requires)r(   r!   r+   r+   r,   apply_configurationD   s    
r/   r+   )ConfigHandler.)r(   r!   other_filesr'   r"   c              	   C   s   ddl m} tj|}tj|s0td| t }ttj	| ||f}z*|j
| |d t| | j|d}|   W 5 t| X |S )zHRead configuration from ``filepath`` and applies to the ``dist`` object.r   )_Distributionz%Configuration file %s does not exist.)r)   )r'   )r#   r2   ospathabspathisfiler   getcwdchdirdirnameparse_config_filesparse_configurationcommand_options_finalize_license_files)r(   r!   r1   r'   r2   Zcurrent_directoryr)   r*   r+   r+   r,   r%   M   s"    
  r%   )
target_objkeyc                 C   s.   dj f t }tt| |}t| ||}| S )z
    Given a target object and option key, get that option from
    the target object, either through a get_{key} method or
    from an attribute directly.
    z	get_{key})formatlocals	functoolsr   getattr)r>   r?   Zgetter_nameZby_attributegetterr+   r+   r,   _get_optionj   s    rE   )r*   r"   c                 C   s<   t t}| D ]*}|jD ]}t|j|}|||j |< qq|S )zReturns configuration data gathered by given handlers as a dict.

    :param list[ConfigHandler] handlers: Handlers list,
        usually from parse_configuration()

    :rtype: dict
    )r   dictset_optionsrE   r>   section_prefix)r*   Zconfig_dicthandleroptionvaluer+   r+   r,   r&   v   s    
r&   )ConfigMetadataHandlerConfigOptionsHandler)distributionr<   r"   c              	   C   sb   t | J}t| |||}|  | js0|j| _t| j|||| j| j}|  W 5 Q R X ||fS )a  Performs additional parsing of configuration options
    for a distribution.

    Returns a list of used option handlers.

    :param Distribution distribution:
    :param dict command_options:
    :param bool ignore_option_errors: Whether to silently ignore
        options, values of which could not be resolved (e.g. due to exceptions
        in directives such as file:, attr:, etc.).
        If False exceptions are propagated as expected.
    :rtype: list
    )r   EnsurePackagesDiscoveredrM   parsepackage_dirrL   metadatasrc_root)rN   r<   r'   ensure_discoveredoptionsmetar+   r+   r,   r;      s(    r;   )label
orig_valueparsedc              	   C   sp   d|kst |dkrdS ttD d|}t|}|jdk	rbd|  d|d  d}t|t	 W 5 Q R X dS )	am  Because users sometimes misinterpret this configuration:

    [options.extras_require]
    foo = bar;python_version<"4"

    It looks like one requirement with an environment marker
    but because there is no newline, it's parsed as two requirements
    with a semicolon as separator.

    Therefore, if:
        * input string does not contain a newline AND
        * parsed result contains two requirements AND
        * parsing of the two parts from the result ("<first>;<second>")
        leads in a valid Requirement with a valid marker
    a UserWarning is shown to inform the user about the possible problem.
    
   N;z#One of the parsed requirements in `z*` looks like a valid environment marker: 'r   z}'
Make sure that the config is correct and check https://setuptools.pypa.io/en/latest/userguide/declarative_config.html#opt-2)
len
contextlibsuppressr   joinr   markerwarningswarnUserWarning)rW   rX   rY   Zoriginal_requirements_strreqmsgr+   r+   r,   %_warn_accidental_env_marker_misconfig   s    

rg   c                   @   s   e Zd ZU dZeed< i Zeeef ed< ee	e
jdddZedd Zd	d
 Zed&ddZedd Zedd Zedd ZeedddZedddZedd Zedd Zed'ddZd d! Zd"d# Zd$d% ZdS )(r0   z1Handles metadata supplied in configuration files.rH   aliases)r>   rU   rT   c           	      C   sd   i }| j }| D ].\}}||s&q||dd}|||< q|| _|| _|| _g | _|| _	d S )N .)
rH   items
startswithreplacestripr'   r>   sectionsrG   rT   )	selfr>   rU   r'   rT   ro   rH   section_namesection_optionsr+   r+   r,   __init__   s    

zConfigHandler.__init__c                 C   s   t d| jj dS ).Metadata item name to parser function mapping.z!%s must provide .parsers propertyN)NotImplementedError	__class____name__rp   r+   r+   r,   parsers   s    
zConfigHandler.parsersc           	      C   s   t  }| j}| j||}t|||}||kr6t||r>d S d}| j|}|rz||}W n  tk
r~   d}| jsz Y nX |rd S t|d| d }|d krt	||| n|| | j
| d S )NFTzset_%s)tupler>   rh   getrC   KeyErrorry   	Exceptionr'   setattrrG   append)	rp   Zoption_namerK   unknownr>   Zcurrent_valueZskip_optionparsersetterr+   r+   r,   __setitem__  s0    zConfigHandler.__setitem__,c                 C   s8   t |tr|S d|kr | }n
||}dd |D S )zRepresents value as a list.

        Value is split either by separator (defaults to comma) or by lines.

        :param value:
        :param separator: List items separator character.
        :rtype: list
        rZ   c                 S   s   g | ]}|  r|  qS r+   rn   ).0chunkr+   r+   r,   
<listcomp>:  s      z-ConfigHandler._parse_list.<locals>.<listcomp>)
isinstancelist
splitlinessplit)clsrK   	separatorr+   r+   r,   _parse_list(  s    



zConfigHandler._parse_listc                 C   sP   d}i }|  |D ]8}||\}}}||kr:td| | || < q|S )zPRepresents value as a dict.

        :param value:
        :rtype: dict
        =z(Unable to parse option value to dict: %s)r   	partitionr   rn   )r   rK   r   resultliner?   sepvalr+   r+   r,   _parse_dict<  s    zConfigHandler._parse_dictc                 C   s   |  }|dkS )zQRepresents value as boolean.

        :param value:
        :rtype: bool
        )1trueyes)lowerr   rK   r+   r+   r,   _parse_boolO  s    zConfigHandler._parse_boolc                    s    fdd}|S )zReturns a parser function to make sure field inputs
        are not files.

        Parses a value after getting the key so error messages are
        more informative.

        :param key:
        :rtype: callable
        c                    s    d}|  |rtd | S )Nfile:zCOnly strings are accepted for the {0} field, files are not accepted)rl   
ValueErrorr@   )rK   Zexclude_directiver?   r+   r,   r   e  s    
z3ConfigHandler._exclude_files_parser.<locals>.parserr+   )r   r?   r   r+   r   r,   _exclude_files_parserY  s    	z#ConfigHandler._exclude_files_parserroot_dirc                 C   sP   d}t |ts|S ||s |S |t|d }dd |dD }t||S )aO  Represents value as a string, allowing including text
        from nearest files using `file:` directive.

        Directive is sandboxed and won't reach anything outside
        directory with setup.py.

        Examples:
            file: README.rst, CHANGELOG.md, src/file.txt

        :param str value:
        :rtype: str
        r   Nc                 s   s   | ]}|  V  qd S Nr   )r   r4   r+   r+   r,   	<genexpr>  s     z,ConfigHandler._parse_file.<locals>.<genexpr>r   )r   r   rl   r]   r   r   Z
read_files)r   rK   r   Zinclude_directivespecZ	filepathsr+   r+   r,   _parse_filep  s    

zConfigHandler._parse_filec                 C   s:   d}| |s|S ||d}|| jj t|||S )zRepresents value as a module attribute.

        Examples:
            attr: package.attr
            attr: package.module.attr

        :param str value:
        :rtype: str
        zattr:ri   )rl   rm   updaterT   rQ   r   Z	read_attr)rp   rK   rQ   r   Zattr_directiveZ	attr_descr+   r+   r,   _parse_attr  s    

zConfigHandler._parse_attrc                    s    fdd}|S )zReturns parser function to represents value as a list.

        Parses a value applying given methods one after another.

        :param parse_methods:
        :rtype: callable
        c                    s   | } D ]}||}q|S r   r+   )rK   rY   methodparse_methodsr+   r,   rP     s    
z1ConfigHandler._get_parser_compound.<locals>.parser+   )r   r   rP   r+   r   r,   _get_parser_compound  s    
z"ConfigHandler._get_parser_compoundc                 C   s,   i }|  D ]\}\}}|||||< q|S )a  Parses section options into a dictionary.

        Applies a given parser to each option in a section.

        :param dict section_options:
        :param callable values_parser: function with 2 args corresponding to key, value
        :rtype: dict
        )rk   )r   rr   values_parserrK   r?   _r   r+   r+   r,   _parse_section_to_dict_with_key  s    
z-ConfigHandler._parse_section_to_dict_with_keyNc                    s$    r fddndd }|  ||S )a   Parses section options into a dictionary.

        Optionally applies a given parser to each value.

        :param dict section_options:
        :param callable values_parser: function with 1 arg corresponding to option value
        :rtype: dict
        c                    s    |S r   r+   r   vr   r+   r,   <lambda>      z6ConfigHandler._parse_section_to_dict.<locals>.<lambda>c                 S   s   |S r   r+   r   r+   r+   r,   r     r   r   )r   rr   r   r   r+   r   r,   _parse_section_to_dict  s    
z$ConfigHandler._parse_section_to_dictc              
   C   s8   |  D ]*\}\}}tt || |< W 5 Q R X qdS )zQParses configuration file section.

        :param dict section_options:
        N)rk   r^   r_   r|   )rp   rr   namer   rK   r+   r+   r,   parse_section  s    zConfigHandler.parse_sectionc                 C   sb   | j  D ]R\}}d}|r"d| }t| d| ddd}|dkrTtd| j|f || q
dS )zTParses configuration file items from one
        or more related sections.

        ri   z_%szparse_section%srj   __Nz0Unsupported distribution option section: [%s.%s])ro   rk   rC   rm   r   rH   )rp   rq   rr   Zmethod_postfixZsection_parser_methodr+   r+   r,   rP     s     zConfigHandler.parsec                    s   t   fdd}|S )zthis function will wrap around parameters that are deprecated

        :param msg: deprecation message
        :param warning_class: class of warning exception to be raised
        :param func: function to be wrapped around
        c                     s   t   | |S r   )rb   rc   )argskwargsfuncrf   warning_classr+   r,   config_handler  s    z@ConfigHandler._deprecated_config_handler.<locals>.config_handlerr   )rp   r   rf   r   r   r+   r   r,   _deprecated_config_handler  s    z(ConfigHandler._deprecated_config_handler)r   )N)rw   
__module____qualname____doc__r   __annotations__rh   r	   r   AllCommandOptionsr   rO   rs   propertyry   r   classmethodr   r   r   r   _Pathr   r   r   r   r   r   rP   r   r+   r+   r+   r,   r0      s<   
	
&

	



r0   c                       sd   e Zd ZdZdddddZdZdejfd	ee	e
jee ed
 fddZedd Zdd Z  ZS )rL   rR   urldescriptionclassifiers	platforms)Z	home_pagesummary
classifierplatformFNr   )r>   rU   r'   rT   rQ   r   c                    s"   t  |||| || _|| _d S r   )superrs   rQ   r   )rp   r>   rU   r'   rT   rQ   r   rv   r+   r,   rs     s    	zConfigMetadataHandler.__init__c                 C   sh   | j }t| j| jd}| j}| j}|||| |dt|| |||d| |ddt|||| j	|dS )rt   r   z[The requires parameter is deprecated, please use install_requires for runtime dependencies.licenselicense_filezDThe license_file parameter is deprecated, use license_files instead.)r   keywordsprovidesrequires	obsoletesr   r   r   license_filesr   long_descriptionversionproject_urls)
r   r   r   r   r   r   r   r   r   _parse_version)rp   
parse_list
parse_file
parse_dictZexclude_files_parserr+   r+   r,   ry      s4    
zConfigMetadataHandler.parsersc                 C   sr   |  || j}||krZ| }zt| W n* tk
rT   d}t|jf t Y nX |S t	| 
|| j| jS )zSParses `version` option value.

        :param value:
        :rtype: str

        zCVersion loaded from {value} does not comply with PEP 440: {version})r   r   rn   r   r   r   r@   rA   r   r   r   rQ   )rp   rK   r   tmplr+   r+   r,   r   B  s    z$ConfigMetadataHandler._parse_version)rw   r   r   rH   rh   Zstrict_moder3   curdirr   boolr   rO   r   rF   r   rs   r   ry   r   __classcell__r+   r+   r   r,   rL     s(   
!rL   r   c                       s   e Zd ZdZdeeejd fddZe	dd Z
dd	 Zeed
ddZedd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd  Z  ZS )!rM   rU   r   )r>   rU   r'   rT   c                    s$   t  |||| |j| _i | _d S r   )r   rs   rS   r   rQ   )rp   r>   rU   r'   rT   r   r+   r,   rs   a  s    zConfigOptionsHandler.__init__c                 C   s   | j |ddS )Nr\   )r   )r   r   r+   r+   r,   _parse_list_semicolonl  s    z*ConfigOptionsHandler._parse_list_semicolonc                 C   s   | j || jdS )Nr   )r   r   )rp   rK   r+   r+   r,   _parse_file_in_rootp  s    z(ConfigOptionsHandler._parse_file_in_root)rW   rK   c                 C   s*   |  | |}t||| dd |D S )Nc                 S   s   g | ]}| d s|qS )#)rl   )r   r   r+   r+   r,   r   y  s     
 zAConfigOptionsHandler._parse_requirements_list.<locals>.<listcomp>)r   r   rg   )rp   rW   rK   rY   r+   r+   r,   _parse_requirements_lists  s    z-ConfigOptionsHandler._parse_requirements_listc                 C   sV   | j }| j}| j}| j}||||||| |dtt| jd| j| j| j	| j
|t|dS )rt   zeThe namespace_packages parameter is deprecated, consider using implicit namespaces instead (PEP 420).install_requires)Zzip_safeZinclude_package_datarQ   scriptsZeager_resourcesdependency_linksZnamespace_packagesr   setup_requiresZtests_requirepackagesentry_points
py_modulespython_requirescmdclass)r   r   r   _parse_cmdclassr   r   r   r   r   _parse_packagesr   r   )rp   r   Z
parse_boolr   Zparse_cmdclassr+   r+   r,   ry   {  s6     zConfigOptionsHandler.parsersc                 C   s   | j j}t| ||| jS r   )rT   rQ   r   r   r   r   )rp   rK   rQ   r+   r+   r,   r     s    z$ConfigOptionsHandler._parse_cmdclassc                 C   s^   ddg}|  }||kr"| |S | | jdi }|j||d k| j| jd tj	f |S )zTParses `packages` option value.

        :param value:
        :rtype: list
        zfind:zfind_namespace:zpackages.findr   )Z
namespacesr   Zfill_package_dir)
rn   r   parse_section_packages__findro   r{   r   r   rQ   r   find_packages)rp   rK   Zfind_directivesZtrimmed_valuefind_kwargsr+   r+   r,   r     s    

z$ConfigOptionsHandler._parse_packagesc                    sT   |  || j}dddg t fdd| D }|d}|dk	rP|d |d< |S )zParses `packages.find` configuration file section.

        To be used in conjunction with _parse_packages().

        :param dict section_options:
        whereincludeexcludec                    s$   g | ]\}}| kr|r||fqS r+   r+   )r   kr   Z
valid_keysr+   r,   r     s       zEConfigOptionsHandler.parse_section_packages__find.<locals>.<listcomp>Nr   )r   r   rF   rk   r{   )rp   rr   Zsection_datar   r   r+   r   r,   r     s    

z1ConfigOptionsHandler.parse_section_packages__findc                 C   s   |  || j}|| d< dS )z`Parses `entry_points` configuration file section.

        :param dict section_options:
        r   N)r   r   rp   rr   rY   r+   r+   r,   parse_section_entry_points  s    z/ConfigOptionsHandler.parse_section_entry_pointsc                 C   s   |  || j}t|S r   )r   r   r   Zcanonic_package_data)rp   rr   package_datar+   r+   r,   _parse_package_data  s    z(ConfigOptionsHandler._parse_package_datac                 C   s   |  || d< dS )z`Parses `package_data` configuration file section.

        :param dict section_options:
        r   Nr   rp   rr   r+   r+   r,   parse_section_package_data  s    z/ConfigOptionsHandler.parse_section_package_datac                 C   s   |  || d< dS )zhParses `exclude_package_data` configuration file section.

        :param dict section_options:
        Zexclude_package_dataNr   r   r+   r+   r,   "parse_section_exclude_package_data  s    z7ConfigOptionsHandler.parse_section_exclude_package_datac                    s      | fdd}| d< dS )zbParses `extras_require` configuration file section.

        :param dict section_options:
        c                    s     d|  d|S )Nzextras_require[])r   )r   r   rx   r+   r,   r     r   zCConfigOptionsHandler.parse_section_extras_require.<locals>.<lambda>extras_requireNr   r   r+   rx   r,   parse_section_extras_require  s
    
z1ConfigOptionsHandler.parse_section_extras_requirec                 C   s$   |  || j}t|| j| d< dS )z^Parses `data_files` configuration file section.

        :param dict section_options:
        
data_filesN)r   r   r   Zcanonic_data_filesr   r   r+   r+   r,   parse_section_data_files  s    z-ConfigOptionsHandler.parse_section_data_files)rw   r   r   rH   r   r   r   rO   rs   r   r   r   r   r   r   ry   r   r   r   r   r   r  r  r  r  r   r+   r+   r   r,   rM   ]  s*   

 rM   )FF)r+   F)F);r   r3   r^   rB   rb   collectionsr   r   r   typingr   r   r   r	   r
   r   r   r   r   r   r   distutils.errorsr   r   Z(setuptools.extern.packaging.requirementsr   r   Z#setuptools.extern.packaging.versionr   r   Z&setuptools.extern.packaging.specifiersr   Zsetuptools._deprecation_warningr   ri   r   r#   r   distutils.distr   r   PathLiker   ZSingleCommandOptionsr   r   rF   r-   r/   r   r%   rE   r&   r;   r   rg   r0   rL   rM   r+   r+   r+   r,   <module>   sf   4      +!  0[