B
    G0d=                 @   sl   d Z ddlmZ ejZddlmZmZmZm	Z	m
Z
 ddlmZ ddlmZ ddlmZ dddZd	d
 ZdS )aM  

Build common block mechanism for f2py2e.

Copyright 2000 Pearu Peterson all rights reserved,
Pearu Peterson <pearu@ioc.ee>
Permission to use, modify, and distribute this software is given under the
terms of the NumPy License

NO WARRANTY IS EXPRESSED OR IMPLIED.  USE AT YOUR OWN RISK.
$Date: 2005/05/06 10:57:33 $
Pearu Peterson

   )__version__)hasbody	hascommonhasnoteisintent_hideoutmess)	capi_maps)	func2subr)	rmbadnamec       
         s   g }t  rJxd d  D ]*\}} fdd|D }||||f qW n(t rrx d D ]}|t|d }q\W |rg }g }x0|D ](}	|	d |kr||	d  ||	 qW |S |S )Ncommonc                s   i | ]} d  | |qS )vars ).0v)blockr   I/var/www/html/venv/lib/python3.7/site-packages/numpy/f2py/common_rules.py
<dictcomp>   s    z$findcommonblocks.<locals>.<dictcomp>body    )r   itemsappendr   findcommonblocks)
r   topretkeyvalueZvars_bZtretnamestr   )r   r   r      s"    
r   c             C   s  g g dgd}dg}|fdd}dg}|fdd}dg}|fdd	}dg}|fd
d}	xXt | D ]J\}
}}|
 }g g  }}x.|D ]&}t|| r|| q|| qW |rtd|
d|d|f  ntd|
d|f  |d|
  |d x|D ]}|t|| qW |
dkr<|dd|  n|d|
d|f  |dd|  |d |d|
  g }x|D ]}t	|| }tj
| }t||| }|d r|d|d   n
|d |d  }|sd}|d||d ||f  qW |d t|}ddd |D }|d|
|f  |d  x|D ]}|d!|
|f  qLW |d" d#|kr~d$}nd%}|d&|||
 dd'gt| f  |d(|
  |d)|||
 |
f  |d* |d+|
|
f  |d,|
  |d- |
d#d.}|	d/|  |	d0 xb|D ]Z}|	d1t|||   t|| r || d2 }t|trld3|}|	d4|  q W |	d5 |d6 d7|
dtd8d9 ||f  qbW ||d:< ||d;< |d< |d=< t|d6 d>krd|d6< ||d< fS )?Nz"COMMON blocks:\n")commonhooksinitcommonhooksdocs c             S   s   d|d | f |d< d S )Nz%s
      %sr   r   )linesr   r   r   fadd4   s    zbuildhooks.<locals>.faddc             S   s   d|d | f |d< d S )Nz%s
%sr   r   )r#   r$   r   r   r   cadd8   s    zbuildhooks.<locals>.caddc             S   s   d|d | f |d< d S )Nz%s
%sr   r   )r#   r$   r   r   r   iadd<   s    zbuildhooks.<locals>.iaddc             S   s   d|d | f |d< d S )Nz%s
%sr   r   )r#   r$   r   r   r   dadd@   s    zbuildhooks.<locals>.daddzF		Constructing COMMON block support for "%s"...
		  %s
		  Hidden: %s
,z7		Constructing COMMON block support for "%s"...
		  %s
z subroutine f2pyinit%s(setupfunc)zexternal setupfuncZ_BLNK_z	common %szcommon /%s/ %szcall setupfunc(%s)zend
z'static FortranDataDef f2py_%s_def[] = {Zdimsz(%s)z-1z	{"%s",%s,{{%s}},%s},Zrankz
	{NULL}
};c             S   s   g | ]}d | qS )zchar *r   )r   r$   r   r   r   
<listcomp>j   s    zbuildhooks.<locals>.<listcomp>zstatic void f2py_setup_%s(%s) {z	int i_f2py=0;z!	f2py_%s_def[i_f2py++].data = %s;}_Z	F_FUNC_USF_FUNCz3extern void %s(f2pyinit%s,F2PYINIT%s)(void(*)(%s));zchar*z static void f2py_init_%s(void) {z*	%s(f2pyinit%s,F2PYINIT%s)(f2py_setup_%s);z}
z5	tmp = PyFortranObject_New(f2py_%s_def,f2py_init_%s);z&	F2PyDict_SetItemString(d, "%s", tmp);z	Py_DECREF(tmp);z\_z&\subsection{Common block \texttt{%s}}
z\begin{description}z\item[]{{}\verb@%s@{}}note
z--- %sz\end{description}r!   z"	/%s/ %s\n"c             S   s   | | S )Nr   )r   dr   r   r   <lambda>       zbuildhooks.<locals>.<lambda>r   r    r   Zlatexdocr   )r   lowerr   r   r   joinr	   Zvar2fixfortranr   ZgetctypeZ
c2capi_mapZ
getarrdimsstripr
   upperlenreplaceZgetarrdocsignr   
isinstancelistmap)mr   Zfwrapr%   Zchooksr&   Zihooksr'   docr(   nameZvnamesr   Z
lower_nameZhnamesZinamesnZidimsctatdmZdmsZinames1Zinames1_tpsr-   Ztnamer.   r   r   r   
buildhooks/   s    













$rC   N)r   )__doc__r"   r   versionZf2py_versionZauxfuncsr   r   r   r   r   r   r	   Zcrackfortranr
   r   rC   r   r   r   r   <module>   s   
