o
    JAfWc                     @   s0  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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 m!Z! ddl"m#Z# ddl$m%Z% ddl&m'Z' e
r~d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 Z0eded dZ1	d<de.de2fddZ3ddde.ddfddZ4		d=ddde.dee. d e5ded! f
d"d#Z6d$e1d%e,fd&d'Z7d(ed! de2fd)d*Z8	d>d+dd,e0ded- fd.d/Z9d0e,d1e,d2e:fd3d4Z;G d5d6 d6ee1 Z<G d7d8 d8e<d9 Z=G d:d; d;e<d Z>dS )?ze
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SetTupleTypeVarUnion)DistutilsOptionErrorDistutilsFileError)RequirementInvalidRequirement)default_environment)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#   find_othersignore_option_errorsr   dist	filenameshandlers r.   \/usr/lib/python3.10/site-packages/setuptools-67.5.1-py3.10.egg/setuptools/config/setupcfg.pyread_configuration5   s
   r0   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_configurationO   s   
r2   r.   other_filesr*   )ConfigHandler.c              	   C   s   ddl m} tj|}tj|std| t }ttj	| g ||}z|j
| |d t| | j|d}|   W t| |S t| w )zHRead configuration from ``filepath`` and applies to the ``dist`` object.r   )_Distributionz%Configuration file %s does not exist.)r,   )r*   )r%   r5   ospathabspathisfiler   getcwdchdirdirnameparse_config_filesparse_configurationcommand_options_finalize_license_files)r+   r#   r3   r*   r5   current_directoryr,   r-   r.   r.   r/   r'   X   s    

r'   
target_objkeyc                 C   s2   dj di 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}Nr.   )formatlocals	functoolsr   getattr)rB   rC   getter_nameby_attributegetterr.   r.   r/   _get_optionv   s   rK   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_optionsrK   rB   section_prefix)r-   config_dicthandleroptionvaluer.   r.   r/   r(      s   
r(   distributionr?   )ConfigMetadataHandlerConfigOptionsHandlerc                 C   s   t | 6}t| |||}|  | js|j| _t| j|||| j| j}|  | j	|j|j W d   ||fS 1 s>w   Y  ||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
    N)
r   EnsurePackagesDiscoveredrU   parsepackage_dirrT   metadatasrc_root_referenced_filesupdate)rS   r?   r*   ensure_discoveredoptionsmetar.   r.   r/   r>      s4   
r>   label
orig_valueparsedc              
      s   d|v s
t  dkrdS t  }d|  d d  d}zt d }|j|v r0t| W dS W dS  tyU } zt fdd	|D rJt||W Y d}~dS d}~ww )
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.
    
   Nz#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-2c                 3   s    | ]
} d   |V  qdS )r   N
startswith).0markerrb   r.   r/   	<genexpr>   s    z8_warn_accidental_env_marker_misconfig.<locals>.<genexpr>)	len
marker_envkeysr   namewarningswarnr   any)r`   ra   rb   markersmsgreqexr.   ri   r/   %_warn_accidental_env_marker_misconfig   s$   


rv   c                   @   s   e Zd ZU dZeed< 	 i Zeeef ed< 	 dede	de
jfddZede	f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defddZdef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 ),r4   z1Handles metadata supplied in configuration files.rN   aliasesrB   r^   r]   c                 C   s4   || _ || _t| || _g | _|| _t | _d S N)	r*   rB   rL   _section_optionssectionsrM   r]   setr[   selfrB   r^   r*   r]   r.   r.   r/   __init__   s   zConfigHandler.__init__c                 c   s@    |  D ]\}}|| j\}}}|rq|d|fV  qd S )N.)items	partitionrN   lstrip)clsr^   	full_namerR   preseprn   r.   r.   r/   ry     s   zConfigHandler._section_optionsc                 C   s   t d| jj ).Metadata item name to parser function mapping.z!%s must provide .parsers property)NotImplementedError	__class____name__r}   r.   r.   r/   parsers  s   
zConfigHandler.parsersc              	   C   s   | j }| j||}zt||}W n ty   t|w |r!d S z| j|dd |}W n tf| j y<   Y d S w t	
|j|}t|d| |}|| | j| d S )Nc                 S   s   | S rx   r.   )xr.   r.   r/   <lambda>'      z+ConfigHandler.__setitem__.<locals>.<lambda>zset_%s)rB   rw   getrG   AttributeErrorKeyErrorr   	Exceptionr*   rF   r   __setattr__rM   append)r}   option_namerR   rB   current_valuerb   simple_settersetterr.   r.   r/   __setitem__  s$   zConfigHandler.__setitem__,c                 C   s8   t |tr|S d|v 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
        rc   c                 S   s   g | ]
}|  r|  qS r.   strip)rg   chunkr.   r.   r/   
<listcomp>C  s    z-ConfigHandler._parse_list.<locals>.<listcomp>)
isinstancelist
splitlinessplit)r   rR   	separatorr.   r.   r/   _parse_list1  s   



zConfigHandler._parse_listc                 C   sP   d}i }|  |D ]}||\}}}||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   r   r   r   )r   rR   r   resultlinerC   r   valr.   r.   r/   _parse_dictE  s   zConfigHandler._parse_dictc                 C   s   |  }|dv S )zQRepresents value as boolean.

        :param value:
        :rtype: bool
        )1trueyes)lowerr   rR   r.   r.   r/   _parse_boolX  s   zConfigHandler._parse_boolc                        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)rf   
ValueErrorrD   )rR   exclude_directiverC   r.   r/   parsern  s   
z3ConfigHandler._exclude_files_parser.<locals>.parserr.   )r   rC   r   r.   r   r/   _exclude_files_parserb  s   	z#ConfigHandler._exclude_files_parserroot_dirc                 C   s\   d}t |ts	|S ||s|S |t|d }dd |dD }| j| 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   g | ]}|  qS r.   r   )rg   r7   r.   r.   r/   r         z-ConfigHandler._parse_file.<locals>.<listcomp>r   )	r   r    rf   rk   r   r[   r\   r   
read_files)r}   rR   r   include_directivespec	filepathsr.   r.   r/   _parse_filey  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: )rf   replacer\   r]   rX   r   	read_attr)r}   rR   rX   r   attr_directive	attr_descr.   r.   r/   _parse_attr  s   

zConfigHandler._parse_attrc                    r   )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 rx   r.   )rR   rb   methodparse_methodsr.   r/   rW     s   
z1ConfigHandler._get_parser_compound.<locals>.parser.   )r   r   rW   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
        )r   )r   section_optionsvalues_parserrR   rC   _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 rx   r.   r   vr   r.   r/   r     s    z6ConfigHandler._parse_section_to_dict.<locals>.<lambda>c                 S   s   |S rx   r.   r   r.   r.   r/   r     r   r   )r   r   r   r   r.   r   r/   _parse_section_to_dict  s   
z$ConfigHandler._parse_section_to_dictc              	   C   sL   |  D ]\}\}}tt || |< W d   n1 sw   Y  qdS )zQParses configuration file section.

        :param dict section_options:
        N)r   
contextlibsuppressr   )r}   r   rn   r   rR   r.   r.   r/   parse_section  s   
zConfigHandler.parse_sectionc                 C   sb   | j  D ])\}}d}|rd| }t| d| ddd}|du r*td| j|f || qdS )zTParses configuration file items from one
        or more related sections.

        r   z_%szparse_section%sr   __Nz0Unsupported distribution option section: [%s.%s])rz   r   rG   r   r   rN   )r}   section_namer   method_postfixsection_parser_methodr.   r.   r/   rW     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   | i |S rx   )ro   rp   )argskwargsfuncrs   warning_classr.   r/   config_handler  s   z@ConfigHandler._deprecated_config_handler.<locals>.config_handlerr   )r}   r   rs   r   r   r.   r   r/   _deprecated_config_handler  s   z(ConfigHandler._deprecated_config_handler)r   rx   )r   
__module____qualname____doc__r    __annotations__rw   r	   r!   AllCommandOptionsr   rV   r~   classmethodry   propertyr   r   r   r   r   r   _Pathr   r   r   r   r   r   rW   r   r.   r.   r.   r/   r4      sJ   
 



	



r4   c                       sp   e Zd ZdZdddddZdZ	 dejfd	d
dede	de
jdee def fddZedd Zdd Z  ZS )rT   rY   urldescriptionclassifiers	platforms)	home_pagesummary
classifierplatformFNrB   r   r^   r*   r]   rX   r   c                    s"   t  |||| || _|| _d S rx   )superr~   rX   r   )r}   rB   r^   r*   r]   rX   r   r   r.   r/   r~     s   	
zConfigMetadataHandler.__init__c                 C   sh   | j }t| j| jd}| j}| j}|||| |dt|| |||d| |ddt|||| j	|dS )r   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)r}   
parse_list
parse_file
parse_dictexclude_files_parserr.   r.   r/   r   '  s4   
zConfigMetadataHandler.parsersc                 C   sn   |  || j}||kr+| }zt| W |S  ty*   d}t|jdi t w t	| 
|| j| jS )zSParses `version` option value.

        :param value:
        :rtype: str

        zCVersion loaded from {value} does not comply with PEP 440: {version}Nr.   )r   r   r   r   r   r   rD   rE   r   r   r   rX   )r}   rR   r   tmplr.   r.   r/   r   I  s   
	z$ConfigMetadataHandler._parse_version)r   r   r   rN   rw   strict_moder6   curdirr   boolr   rV   r   rL   r   r~   r   r   r   __classcell__r.   r.   r   r/   rT   
  s6    
!rT   r   c                       s   e Zd ZdZdddededejf fddZe	dd	 Z
d
d Zdedef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 )$rU   r^   rB   r   r*   r]   c                    s$   t  |||| |j| _i | _d S rx   )r   r~   rZ   r   rX   r|   r   r.   r/   r~   g  s   
zConfigOptionsHandler.__init__c                 C   s   | j |ddS )N;)r   )r   r   r.   r.   r/   _parse_list_semicolonr  s   z*ConfigOptionsHandler._parse_list_semicolonc                 C   s   | j || jdS )Nr   )r   r   )r}   rR   r.   r.   r/   _parse_file_in_rootv  s   z(ConfigOptionsHandler._parse_file_in_rootr`   rR   c                 C   s*   |  | |}t||| dd |D S )Nc                 S   s   g | ]	}| d s|qS )#re   )rg   r   r.   r.   r/   r     s    zAConfigOptionsHandler._parse_requirements_list.<locals>.<listcomp>)r  r	  rv   )r}   r`   rR   rb   r.   r.   r/   _parse_requirements_listy  s   z-ConfigOptionsHandler._parse_requirements_listc                 C   sV   | j }| j}| j}| j}||||||| |dtt| jd| j| j| j	| j
|t|dS )r   zeThe namespace_packages parameter is deprecated, consider using implicit namespaces instead (PEP 420).install_requires)zip_safeinclude_package_datarX   scriptseager_resourcesdependency_linksnamespace_packagesr  setup_requirestests_requirepackagesentry_points
py_modulespython_requirescmdclass)r   r   r   _parse_cmdclassr   r   r   r  r  _parse_packagesr	  r   )r}   r   
parse_boolr   parse_cmdclassr.   r.   r/   r     s4   zConfigOptionsHandler.parsersc                 C   s   | j j}t| ||| jS rx   )r]   rX   r   r  r   r   )r}   rR   rX   r.   r.   r/   r    s   z$ConfigOptionsHandler._parse_cmdclassc                 C   sb   ddg}|  }||vr| |S | | jdi }|j||d k| j| jd tj	di |S )zTParses `packages` option value.

        :param value:
        :rtype: list
        zfind:zfind_namespace:zpackages.findr   )
namespacesr   fill_package_dirNr.   )
r   r   parse_section_packages__findrz   r   r\   r   rX   r   find_packages)r}   rR   find_directivestrimmed_valuefind_kwargsr.   r.   r/   r    s   

z$ConfigOptionsHandler._parse_packagesc                    sR   |  || j}g d t fdd| D }|d}|dur'|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 | ]\}}| v r|r||fqS r.   r.   )rg   kr   
valid_keysr.   r/   r     s   $ zEConfigOptionsHandler.parse_section_packages__find.<locals>.<listcomp>r%  Nr   )r   r   rL   r   r   )r}   r   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   r}   r   rb   r.   r.   r/   parse_section_entry_points  s   z/ConfigOptionsHandler.parse_section_entry_pointsc                 C   s   |  || j}t|S rx   )r   r   r   canonic_package_data)r}   r   package_datar.   r.   r/   _parse_package_data  s   
z(ConfigOptionsHandler._parse_package_datac                 C      |  || d< dS )z`Parses `package_data` configuration file section.

        :param dict section_options:
        r/  Nr0  r}   r   r.   r.   r/   parse_section_package_data     z/ConfigOptionsHandler.parse_section_package_datac                 C   r1  )zhParses `exclude_package_data` configuration file section.

        :param dict section_options:
        exclude_package_dataNr2  r3  r.   r.   r/   "parse_section_exclude_package_data  r5  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   r   r.   r/   r     r   zCConfigOptionsHandler.parse_section_extras_require.<locals>.<lambda>extras_requireNr   r,  r.   r   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   canonic_data_filesr   r,  r.   r.   r/   parse_section_data_files  s   z-ConfigOptionsHandler.parse_section_data_files)r   r   r   rN   r   r  r   rV   r~   r   r  r	  r    r  r   r   r  r  r   r-  r0  r4  r7  r:  r=  r  r.   r.   r   r/   rU   d  s4    

 rU   )FF)r.   F)F)?r   r6   r   rF   ro   collectionsr   r   r   typingr   r   r   r	   r
   r   r   r   r   r   r   r   distutils.errorsr   r   (setuptools.extern.packaging.requirementsr   r   Z#setuptools.extern.packaging.markersr   rl   Z#setuptools.extern.packaging.versionr   r   &setuptools.extern.packaging.specifiersr   Zsetuptools._deprecation_warningr   r   r   r%   r   distutils.distr   r    PathLiker   SingleCommandOptionsr   r!   rL   r0   r2   r  r'   rK   r(   r>   r   rv   r4   rT   rU   r.   r.   r.   r/   <module>   sx    8


.%  %Z