o
    ȧe7                     @   s"  U 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ZddlmZm	Z	m
Z
mZmZmZmZmZ ddlmZ zddlZW n eyF   dZY nw zddlZW n eyX   dZY nw dZdZdZedZeeeje gZee e d	< dZ!ee d
< dZ"ej#e d< G dd deZ$de	e%ef de$fddZ&de$fddZ'de%fddZ(dej)de%dedej*fddZ+defddZ,dee% dee% dee% fdd Z-d!d" Z.		#	d3d$e%d%ee d&e%d'ee% de%f
d(d)Z/	d4d*e	e%ef d+eee%  de
e% fd,d-Z0d.e%de%fd/d0Z1de%de%fd1d2Z2dS )5z:Internal helper functions for Abseil Python flags library.    N)AnyDictIterableList
NamedTupleOptionalSequenceSet)minidomP   (   g      ?u    [ -----￾￿]disclaim_module_idsSPECIAL_FLAGSFLAGS_MODULEc                   @   s$   e Zd ZU dZejed< eed< dS )_ModuleObjectAndNamezkModule object and name.

  Fields:
  - module: object, module object.
  - module_name: str, module name.
  modulemodule_nameN)__name__
__module____qualname____doc__types
ModuleType__annotations__str r   r   3lib/python3.10/site-packages/absl/flags/_helpers.pyr   P   s   
 
r   globals_dictreturnc                 C   s8   |  dd}tj |d}t||dkrtjd S |S )aN  Returns the module that defines a global environment, and its name.

  Args:
    globals_dict: A dictionary that should correspond to an environment
      providing the values of the globals.

  Returns:
    _ModuleObjectAndName - pair of module object & module name.
    Returns (None, None) if the module could not be identified.
  r   N__main__r   )getsysmodulesr   argv)r   namer   r   r   r   get_module_object_and_name[   s   r%   c                  C   sV   t dt D ]} t| j}t|\}}t|tvr&|dur&t||  S qt	d)a)  Returns the module that's calling into this module.

  We generally use this function to get the name of the module calling a
  DEFINE_foo... function.

  Returns:
    The module object that called into this one.

  Raises:
    AssertionError: Raised when no calling module could be identified.
     NzNo module was found)
ranger!   getrecursionlimit	_getframe	f_globalsr%   idr   r   AssertionError)depthZglobals_for_framer   r   r   r   r   "get_calling_module_object_and_nameo   s   r.   c                   C   s   t  jS )z?Returns the name of the module that's calling into this module.)r.   r   r   r   r   r   get_calling_module   s   r/   docr$   valuec                 C   sD   t |}t|tr| }td|}| |}|| | |S )a  Returns an XML DOM element with name and text value.

  Args:
    doc: minidom.Document, the DOM document it should create nodes from.
    name: str, the tag of XML element.
    value: object, whose string representation will be used
        as the value of the XML element. Illegal or highly discouraged xml 1.0
        characters are stripped.

  Returns:
    An instance of minidom.Element.
   )	r   
isinstanceboollower_ILLEGAL_XML_CHARS_REGEXsubZcreateElementZappendChildZcreateTextNode)r0   r$   r1   ser   r   r   create_xml_dom_element   s   

r:   c               
   C   s   t j rtdu stdu rtS z!tt jtjd} t	d| d }|t
kr(|W S ttdtW S  tttjfy?   t Y S w )zAReturns the integer width of help lines that is used in TextWrap.Ns   1234Zhhr&   COLUMNS)r!   stdoutisattytermiosfcntl_DEFAULT_HELP_WIDTHZioctlZ
TIOCGWINSZstructunpack_MIN_HELP_WIDTHintosgetenv	TypeErrorIOErrorerror)datacolumnsr   r   r   get_help_width   s   rL   attemptlongopt_listc           	         s   t  dks|s
g S dd |D } fdd|D }|  |d \}}|tt   kr.g S g }|D ]\}}||kr@|| q2 |S |S )z4Returns helpful similar matches for an invalid flag.   c                 S   s   g | ]	}| d d qS )=r   )split).0vr   r   r   
<listcomp>   s    z(get_flag_suggestions.<locals>.<listcomp>c                    s&   g | ]}t  |d t  |fqS )r   )_damerau_levenshteinlen)rR   optionrM   r   r   rT      s    r   )rV   sort _SUGGESTION_ERROR_RATE_THRESHOLDappend)	rM   rN   Zoption_namesZ	distancesZleast_errors_Zsuggestionserrorsr$   r   rX   r   get_flag_suggestions   s    
r^   c                    s   i  fdd  | |S )z6Returns Damerau-Levenshtein edit distance from a to b.c                    s   | |fv r| |f S | st |}nc|st | }n\t | dd |d  | |dd d  | dd |dd | d |d k }t | dkrvt |dkrv| d |d krv| d |d krv | dd |dd d }||krv|}|| |f< |S )z5Recursively defined string distance with memoization.r&   Nr   rO   )rV   min)xydtdistanceZmemor   r   re      s"   

(8z&_damerau_levenshtein.<locals>.distancer   )abr   rd   r   rU      s   
rU   r2   textlengthindentfirstline_indentc                 C   s   |du rt  }|du rd}|du r|}t||krtdt||kr'td| d} g }tj|||d}tj|||d}dd |  D D ]}|rT||| n|	d |}qGd	
|S )
aL  Wraps a given text to a maximum line length and returns it.

  It turns lines that only contain whitespace into empty lines, keeps new lines,
  and expands tabs using 4 spaces.

  Args:
    text: str, text to wrap.
    length: int, maximum length of a line, includes indentation.
        If this is None then use get_help_width()
    indent: str, indent for all but first line.
    firstline_indent: str, indent for first line; if None, fall back to indent.

  Returns:
    str, the wrapped text.

  Raises:
    ValueError: Raised if indent or firstline_indent not shorter than length.
  Nr2   zLength of indent exceeds lengthz*Length of first line indent exceeds length   )widthinitial_indentsubsequent_indentc                 s   s    | ]}|  V  qd S N)strip)rR   pr   r   r   	<genexpr>%      ztext_wrap.<locals>.<genexpr>
)rL   rV   
ValueError
expandtabstextwrapZTextWrapper
splitlinesextendwrapr[   join)rh   ri   rj   rk   resultwrapperZsubsequent_wrapperZ	paragraphr   r   r   	text_wrap   s0   


r   flag_mapmulti_flagsc              	   c   s    |   D ]h\}}|du rd| V  qt|tr&|r d| V  qd| V  qt|ttdfr7d||f V  qz&|rM||v rM|D ]}d|t|f V  q@nd|ddd |D f V  W q tym   d||f V  Y qw dS )	a3  Convert a dict of values into process call parameters.

  This method is used to convert a dictionary into a sequence of parameters
  for a binary that parses arguments using this module.

  Args:
    flag_map: dict, a mapping where the keys are flag names (strings).
        values are treated according to their type:

        * If value is ``None``, then only the name is emitted.
        * If value is ``True``, then only the name is emitted.
        * If value is ``False``, then only the name prepended with 'no' is
          emitted.
        * If value is a string then ``--name=value`` is emitted.
        * If value is a collection, this will emit
          ``--name=value1,value2,value3``, unless the flag name is in
          ``multi_flags``, in which case this will emit
          ``--name=value1 --name=value2 --name=value3``.
        * Everything else is converted to string an passed as such.

    multi_flags: set, names (strings) of flags that should be treated as
        multi-flags.
  Yields:
    sequence of string suitable for a subprocess execution.
  Nz--%sz--no%sr2   z--%s=%s,c                 s   s    | ]}t |V  qd S rp   )r   )rR   itemr   r   r   rs   ^  rt   z$flag_dict_to_args.<locals>.<genexpr>)itemsr3   r4   bytestyper   r|   rG   )r   r   keyr1   r   r   r   r   flag_dict_to_args0  s*   
r   	docstringc                 C   s   | sdS d}|    }|}|dd D ]}| }|r't|t|t| }q|d  g}||k rG|dd D ]}|||d   q9|rW|d sW|  |rW|d rM|rh|d sh|d |rh|d r]d	|S )a  Removes indentation from triple-quoted strings.

  This is the function specified in PEP 257 to handle docstrings:
  https://www.python.org/dev/peps/pep-0257/.

  Args:
    docstring: str, a python docstring.

  Returns:
    str, docstring with indentation removed.
  r2   i    r&   Nr   ru   )
rw   ry   lstripr_   rV   rq   r[   rstrippopr|   )r   Z
max_indentlinesrj   linestrippedZtrimmedr   r   r   trim_docstringd  s*   

r   c                 C   sB   |   } tdtj}|d| } t| } tjdd| tjd} | S )z0Takes a __doc__ string and reformats it as help.z^[ 	]+$r2   z(?<=\S)\n(?=\S) )flags)rq   recompileMr7   r   )r0   Zwhitespace_only_liner   r   r   doc_to_help  s   r   )Nr2   Nrp   )3r   rE   r   rA   r!   rx   r   typingr   r   r   r   r   r   r   r	   Zxml.domr
   r?   ImportErrorr>   r@   rC   rZ   r   r6   setr+   r"   r   r   rD   r   r   r   r   r   r   r%   r.   r/   ZDocumentZElementr:   rL   r^   rU   r   r   r   r   r   r   r   r   <module>   s   ( 




?


4*