U
    9%ePT                     @   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
mZ ddlZddlZdd ZG dd	 d	eZG d
d deZeddddgZG dd deZdddZdd ZdddZG dd deZG dd deZdS ) z=Extract reference documentation from the NumPy source tree.

    N)warn)
namedtuple)CallableMappingc                 C   s4   | r| d   s| d= q | r0| d   s0| d= q| S )z<Remove leading and trailing blank lines from a list of linesr   strip)l r
   T/var/www/html/Darija-Ai-API/env/lib/python3.8/site-packages/scipy/_lib/_docscrape.pystrip_blank_lines   s
    r   c                   @   sj   e Zd Z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dddZdd ZdS )Readerz!A line-based string reader.

    c                 C   s*   t |tr|| _n|d| _|   dS )zs
        Parameters
        ----------
        data : str
           String with lines separated by '\n'.

        
N)
isinstancelist_strsplitreset)selfdatar
   r
   r   __init__   s    
zReader.__init__c                 C   s
   | j | S N)r   r   nr
   r
   r   __getitem__,   s    zReader.__getitem__c                 C   s
   d| _ d S )Nr   )_lr   r
   r
   r   r   /   s    zReader.resetc                 C   s,   |   s$| | j }|  jd7  _|S dS d S )N    )eofr   )r   outr
   r
   r   read2   s
    
zReader.readc                 C   s4   | | j d  D ] }| r  q0q|  j d7  _ qd S Nr   )r   r   )r   r	   r
   r
   r   seek_next_non_empty_line:   s    zReader.seek_next_non_empty_linec                 C   s   | j t| jkS r   r   lenr   r   r
   r
   r   r   A   s    z
Reader.eofc                 C   sb   | j }| |d  D ]J}||r0| || j    S |  j d7  _ |  r| || j d    S qg S r"   )r   r   )r   Zcondition_funcstartliner
   r
   r   read_to_conditionD   s    zReader.read_to_conditionc                 C   s   |    dd }| |S )Nc                 S   s
   |    S r   r   r'   r
   r
   r   is_emptyQ   s    z0Reader.read_to_next_empty_line.<locals>.is_empty)r#   r(   )r   r*   r
   r
   r   read_to_next_empty_lineN   s    zReader.read_to_next_empty_linec                 C   s   dd }|  |S )Nc                 S   s   |   ot|  t| kS r   )r   r%   lstripr)   r
   r
   r   is_unindentedW   s    z:Reader.read_to_next_unindented_line.<locals>.is_unindented)r(   )r   r-   r
   r
   r   read_to_next_unindented_lineV   s    z#Reader.read_to_next_unindented_liner   c                 C   s*   | j | t| jk r"| | j |  S dS d S Nr   r$   r   r
   r
   r   peek[   s    zReader.peekc                 C   s   d | j  S r/   )joinr   r   r   r
   r
   r   r*   a   s    zReader.is_emptyN)r   )__name__
__module____qualname____doc__r   r   r   r!   r#   r   r(   r+   r.   r0   r*   r
   r
   r
   r   r      s   

r   c                   @   s   e Zd Zdd ZdS )
ParseErrorc                 C   s&   | j d }t| dr"d|| jf }|S )Nr   	docstringz%s in %r)argshasattrr7   )r   messager
   r
   r   __str__f   s    

zParseError.__str__N)r2   r3   r4   r;   r
   r
   r
   r   r6   e   s   r6   	Parameternametypedescc                   @   s  e Zd ZdZddgg g g g g g g g g g g g g ddi dZi f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dMddZdZdZdZde e d e d Zedd Zed!d"Zd#Zed$e d% Zed&e d' e d( d d) e Zd*Zd+d, Zd-d. Zd/d0 Zd1d2 ZdNd4d5ZdOd7d8Z dPd:d;Z!d<d= Z"d>d? Z#d@dA Z$dBdC Z%dDdE Z&dFdG Z'dHdI Z(dQdJdKZ)dLS )RNumpyDocStringzParses a numpydoc string to an abstract representation

    Instances define a mapping from section title to structured data.

    r   )	SignatureSummaryExtended Summary
ParametersReturnsYieldsReceivesRaisesWarnsOther Parameters
AttributesMethodsSee AlsoNotesWarnings
ReferencesExamplesindexc              
   C   sh   |}t |d}t|| _t| j| _z| 	  W n* t
k
rb } z||_ W 5 d }~X Y nX d S Nr   )textwrapdedentr   r   _doccopydeepcopysections_parsed_data_parser6   r7   )r   r7   configZorig_docstringer
   r
   r   r      s    
zNumpyDocString.__init__c                 C   s
   | j | S r   )rZ   )r   keyr
   r
   r   r      s    zNumpyDocString.__getitem__c                 C   s,   || j kr| jd| dd n
|| j |< d S )NzUnknown section %sFerror)rZ   _error_location)r   r^   valr
   r
   r   __setitem__   s    
zNumpyDocString.__setitem__c                 C   s
   t | jS r   )iterrZ   r   r
   r
   r   __iter__   s    zNumpyDocString.__iter__c                 C   s
   t | jS r   )r%   rZ   r   r
   r
   r   __len__   s    zNumpyDocString.__len__c                 C   sh   | j   | j  rdS | j   }|dr4dS | j d }|dt| pf|dt| S )NF
.. index::Tr   -=)rV   r#   r   r0   r   
startswithr%   )r   l1l2r
   r
   r   _is_at_section   s    


zNumpyDocString._is_at_sectionc                 C   sb   d}d}t |D ]\}}| r q&qt |d d d D ]\}}| r8 qNq8||t||  S )Nr   r   )	enumerater   r%   )r   docijr'   r
   r
   r   _strip   s    zNumpyDocString._stripc                 C   sJ   | j  }|  sF| j  sF| j d s6|dg7 }|| j  7 }q
|S )Nr   r   )rV   r+   rm   r   r0   r   )r   sectionr
   r
   r   _read_to_next_section   s    

z$NumpyDocString._read_to_next_sectionc                 c   sn   | j  sj|  }|d  }|dr<||dd  fV  q t|dk rPtV  q || |dd  fV  q d S )Nr   ..r      )rV   r   rt   r   rj   r%   StopIterationrr   )r   r   r=   r
   r
   r   _read_sections   s    

zNumpyDocString._read_sectionsFc           	      C   s   t |}g }| s|  }d|kr@|dd d \}}n|rPd| }}n
|d }}| }t|}t|}|t	||| q|S )N : rv   r   )
r   r   r!   r   r   r.   dedent_linesr   appendr<   )	r   contentsingle_element_is_typerparamsheaderZarg_nameZarg_typer?   r
   r
   r   _parse_param_list   s    
z NumpyDocString._parse_param_listz:(?P<role>\w+):z'`(?P<name>(?:~\w+\.)?[a-zA-Z0-9_\.-]+)`z(?P<name2>[a-zA-Z0-9_\.-]+)(|)roleZrolenextr=   Znamenextz/(?P<description>\s*:(\s+(?P<desc>\S+.*))?)?\s*$z^\s*z\s*z^\s*(?P<allfuncs>z(?P<morefuncs>([,]\s+z)*)z(?P<trailing>[,\.])?ru   c                    s,  g } fdd}g }|D ]}|  s(q j|}d}|rp|d}|drp|rp jd|d|f dd |s|d	r||   q|rg }|d
}	|	  sq||	\}
}}||
|f |	|d   }	|	r|	d dkr|	dd   }	qtt	d|g}|||f qt
d| q|S )z
        func_name : Descriptive text
            continued text
        another_func_name : Descriptive text
        func_name1, func_name2, :meth:`func_name`, func_name3

        c                    sL    j | }|std|  |d}|r4|dn|d}||| fS )zMatch ':role:`name`' or 'name'.%s is not a item namer   r=   Zname2)	_func_rgxmatchr6   groupend)textmr   r=   r   r
   r   parse_item_name  s    
z7NumpyDocString._parse_see_also.<locals>.parse_item_nameNr?   ZtrailingzGUnexpected comma or period after function list at index %d of line "%s"Fr_    Zallfuncsr   ,r   r   )r   	_line_rgxr   r   ra   r   rj   r{   r   filterr6   )r   r|   itemsr   restr'   Z
line_matchdescriptionfuncsr   r=   r   Z	match_endr
   r   r   _parse_see_also  sF    		


zNumpyDocString._parse_see_alsoc                 C   sz   dd }i }| d}t|dkr<||d  dd |d< |D ]4}| d}t|d	kr@||d	  d||d < q@|S )
zT
        .. index: default
           :refguide: something, else, and more

        c                 S   s   dd | D S )Nc                 S   s   g | ]}|  qS r
   r   .0sr
   r
   r   
<listcomp>Q  s     zFNumpyDocString._parse_index.<locals>.strip_each_in.<locals>.<listcomp>r
   )lstr
   r
   r   strip_each_inP  s    z2NumpyDocString._parse_index.<locals>.strip_each_inz::r   r   r   default:rv   )r   r%   )r   rs   r|   r   r    r'   r
   r
   r   _parse_indexJ  s    

zNumpyDocString._parse_indexc                 C   s   |   rdS | j }ddd |D  }td}||rX|| d< |   sXqqXq|dk	rh|| d< |   s||  | d< dS )	z%Grab signature (if given) and summaryNr   c                 S   s   g | ]}|  qS r
   r   r   r
   r
   r   r   e  s     z1NumpyDocString._parse_summary.<locals>.<listcomp>z^([\w., ]+=)?\s*[\w\.]+\(.*\)$rA   rB   rC   )	rm   rV   r+   r1   r   recompiler   rt   )r   summaryZsummary_strcompiledr
   r
   r   _parse_summary]  s    


zNumpyDocString._parse_summaryc                 C   s2  | j   |   t|  }tdd |D }d|k}d|k}|rT|rTd}t||sld|krld}t||D ]\}}|dsd	d
 |dD }d	|}| 
|r| d|  |dkr| || |< qp|dkr| j|dd| |< qp|dr
| ||| d< qp|dkr$| || d< qp|| |< qpd S )Nc                 S   s   g | ]\}}|qS r
   r
   )r   rs   r|   r
   r
   r   r   x  s     z)NumpyDocString._parse.<locals>.<listcomp>rE   rF   z5Docstring contains both a Returns and Yields section.rG   z5Docstring contains a Receives section but not Yields.ru   c                 s   s   | ]}|  V  qd S r   )
capitalizer   r
   r
   r   	<genexpr>  s     z(NumpyDocString._parse.<locals>.<genexpr>r   zThe section %s appears twice)rD   rJ   rK   rL   )rE   rF   rH   rI   rG   T)r}   rg   rR   rM   )rV   r   r   r   rx   set
ValueErrorrj   r   r1   getra   r   r   r   )r   rY   Zsection_namesZhas_returnsZ
has_yieldsmsgrs   r|   r
   r
   r   r[   s  s@    



 
zNumpyDocString._parseTc                 C   s`   t | drFzt| j}W n tk
r2   d }Y nX |d| j|f  }|rTt|nt| d S )N_objz in the docstring of %s in %s.)r9   inspectgetsourcefiler   	TypeErrorr   r   )r   r   r`   filenamer
   r
   r   ra     s    


zNumpyDocString._error_locationrh   c                 C   s   |t || gS r   r%   )r   r=   symbolr
   r
   r   _str_header  s    zNumpyDocString._str_header   c                 C   s$   g }|D ]}|d| | g7 }q|S )Nr   r
   )r   ro   indentr    r'   r
   r
   r   _str_indent  s    zNumpyDocString._str_indentc                 C   s*   | d r | d  ddgdg S dgS d S )NrA   *z\*r   )replacer   r
   r
   r   _str_signature  s    zNumpyDocString._str_signaturec                 C   s   | d r| d dg S g S d S )NrB   r   r
   r   r
   r
   r   _str_summary  s    zNumpyDocString._str_summaryc                 C   s   | d r| d dg S g S d S )NrC   r   r
   r   r
   r
   r   _str_extended_summary  s    z$NumpyDocString._str_extended_summaryc                 C   s   g }| | r||  |7 }| | D ]b}g }|jr<||j |jrN||j |d|g7 }|jr"d|j r"|| |j7 }q"|dg7 }|S )Nry   r   )r   r=   r{   r>   r1   r?   r   r   )r   r=   r    parampartsr
   r
   r   _str_param_list  s    
zNumpyDocString._str_param_listc                 C   s4   g }| | r0||  |7 }|| | 7 }|dg7 }|S r/   )r   )r   r=   r    r
   r
   r   _str_section  s    
zNumpyDocString._str_sectionc           
      C   s   | d sg S g }||  d7 }|dg7 }d}| d D ]\}}t|tsJtg }|D ]>\}}|rld||f }	n|r~d||f }	nd| }	||	 qRd|}	||	g7 }|r|| d|g7 }d}q4d}|| | jg7 }q4|r|dg7 }|dg7 }|S )	NrM   r   Tz:%s:`%s`z`%s`_, r   F)r   r   r   AssertionErrorr{   r1   r   empty_description)
r   	func_roler    Zlast_had_descr   r?   linksfuncr   linkr
   r
   r   _str_see_also  s6    




zNumpyDocString._str_see_alsoc                 C   sz   | d }g }d}| dd}|r$d}|d| g7 }| D ].\}}|dkrLq:d}|d|d|f g7 }q:|rr|S dS d S )	NrR   Fr   r   Tz.. index:: %sz
   :%s: %sr   )r   r   r1   )r   idxr    Zoutput_indexZdefault_indexrs   Z
referencesr
   r
   r   
_str_index  s    zNumpyDocString._str_indexc                 C   s   g }||   7 }||  7 }||  7 }dD ]}|| |7 }q,|| d7 }|| |7 }dD ]}|| |7 }q`dD ]}|| |7 }qx||  7 }d|S )N)rD   rE   rF   rG   rJ   rH   rI   rO   )rN   rP   rQ   )rK   rL   r   )r   r   r   r   r   r   r   r1   )r   r   r    Z
param_listr   r
   r
   r   r;     s    zNumpyDocString.__str__N)F)T)rh   )r   )r   )*r2   r3   r4   r5   rY   r   r   rc   re   rf   rm   rr   rt   rx   r   _roleZ_funcbacktickZ
_funcplainZ	_funcnamer   Z_funcnamenextZ_descriptionr   r   r   r   r   r   r   r   r[   ra   r   r   r   r   r   r   r   r   r   r;   r
   r
   r
   r   r@   p   s   
%6'


 r@   r   c                    s6   d|  | d kr S |  d}d fdd|D S )Nr   r   c                 3   s   | ]} | V  qd S r   r
   )r   r	   Z
indent_strr
   r   r   &  s     zindent.<locals>.<genexpr>)r   r1   )strr   linesr
   r   r   r   !  s
    
r   c                 C   s   t d| dS )z"Deindent a list of lines maximallyr   )rT   rU   r1   r   )r   r
   r
   r   rz   )  s    rz   rh   c                 C   s   | d |t |   d S rS   r   )r   styler
   r
   r   r   .  s    r   c                       s4   e Zd Zddi fddZdd Z fddZ  ZS )	FunctionDocr   Nc                 C   sD   || _ || _|d kr2|d kr$tdt|p0d}t| || d S )NzNo function or docstring givenr   )_fr   r   r   getdocr@   r   )r   r   r   ro   r\   r
   r
   r   r   3  s    zFunctionDoc.__init__c                 C   s@   t | jd| jj}t| jr2t | jd| jj}n| j}||fS )Nr2   __call__)getattrr   	__class__r2   r   isclassr   )r   	func_namer   r
   r
   r   get_func=  s
    zFunctionDoc.get_funcc                    sn   d}|   \}}ddd}| jrR| j|kr8td| j  |d|| jd|f 7 }|tt| j| jd7 }|S )Nr   functionmethod)r   methzWarning: invalid role %sz.. %s:: %s
    

)r   )r   r   printr   superr   r;   )r   r    r   r   Zrolesr   r
   r   r;   E  s    
zFunctionDoc.__str__)r2   r3   r4   r   r   r;   __classcell__r
   r
   r   r   r   2  s   
r   c                   @   sD   e Zd ZdgZddei fddZedd Zedd	 Zd
d Z	dS )ClassDocr   Nr   c              
   C   s  t |s|d k	rtd| || _dtjkr<ddlm} nt }|	dd| _
|rf|dsf|d7 }|| _|d kr|d krtdt|}t| | |	d	g }||krd }|	d
g }|	ddr||k	rdd }	d| jfd| jffD ]\}
}| |
 sg }t|D ]h}||ks|r0||kr0qz,tt| j|}|t|d|	| W n tk
rr   Y nX q|| |
< qd S )Nz$Expected a class or None, but got %rZsphinxr   )ALLZshow_inherited_class_membersT.z&No class or documentation string givenmemberszexclude-membersZshow_class_membersc                 S   s   | sg S |   S d S r   )
splitlines)r   r
   r
   r   splitlines_xz  s    z'ClassDoc.__init__.<locals>.splitlines_xrL   rK   r   )r   r   r   _clssysmodulesZsphinx.ext.autodocr   objectr   show_inherited_membersendswith_modpydocr   r@   r   methods
propertiessortedr   r{   r<   AttributeError)r   clsro   
modulenameZfunc_docr\   r   Z_membersZ_excluder   fieldr   Zdoc_listr=   Zdoc_itemr
   r
   r   r   [  sX    
 


zClassDoc.__init__c                    s(    j d krg S  fddt j D S )Nc                    s<   g | ]4\}}| d r | jkrt|tr |r|qS )_)rj   extra_public_methodsr   r   _is_show_memberr   r=   r   r   r
   r   r     s    



z$ClassDoc.methods.<locals>.<listcomp>r   r   
getmembersr   r
   r   r   r     s    
zClassDoc.methodsc                    s(    j d krg S  fddt j D S )Nc                    sD   g | ]<\}}| d s|dks2t|ts2t|r |r|qS )r   N)rj   r   propertyr   isdatadescriptorr   r   r   r
   r   r     s    
 


z'ClassDoc.properties.<locals>.<listcomp>r   r   r
   r   r   r     s    
zClassDoc.propertiesc                 C   s   | j r
dS || jjkrdS dS )NTF)r   r   __dict__)r   r=   r
   r
   r   r     s
    zClassDoc._is_show_member)
r2   r3   r4   r   r   r   r   r   r   r   r
   r
   r
   r   r   W  s   
4
	
	r   )r   )rh   )r5   r   rT   r   r   warningsr   collectionsr   collections.abcr   r   rW   r   r   r   r   	Exceptionr6   r<   r@   r   rz   r   r   r   r
   r
   r
   r   <module>   s,   	L   4

%