B
    G0d$                 @   s   d Z ddd ZdZddl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mZ dd	d
ZdddZdddZdd ZdS )aW  

Rules for building C/API module with f2py2e.

Copyright 1999,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: 2004/11/26 11:13:06 $
Pearu Peterson

z$Revision: 1.16 $
   zSee `f2py -v`    N   )getfortranname
isexternal
isfunctionisfunction_wrapisintent_inisintent_outislogicalfunctionismoduleroutineisscalarissubroutineissubroutine_wrapoutmessshowc             C   s  |d kr|}|| kr,t |  td|  dS d| | krTt | |  td|  dS | | d }|dkrd| | krd|| | d f }i }d}d| | kr| | d }d	}nd
| | kr| | d
 }d}d|kr6|r|d dkrd| }nd|||d f }n0|d dkr$d||d f }nd||d f }nZd|krvd||d f }d	|krld||d	 f }nd| }nd	|krd||d	 f }d||f }d| | krd|d| | d f }|S )Nz1var2fixfortran: No definition for argument "%s".
 typespecz/var2fixfortran: No typespec for argument "%s".
typetypenamez%s(%s)Zkindselectorkindcharselectorlen*)r   :z(*)z	%s(len=*)z	%s(%s=%s))r   r   z%s*(%s)z%s*%sz	%s(len=%sz%s,kind=%s)z%s)z%s(kind=%s)z%s %s	dimension,)r   r   join)varsafaf90modeZvardefselectorZlk r#   F/var/www/html/venv/lib/python3.7/site-packages/numpy/f2py/func2subr.pyvar2fixfortran   sP    





r%   c                s  t | stg  | d }x| d D ]~}| d | }xlt|dg D ]X\}}|dkrDd||f }tddgd}d	||f |d
<  | |||< ||d |< qDW q"W | d   t }	dg}
|
fdd}| d }t| }t	| }d| }||kr|| ||< |g| d dd   }n|g| d  }t
||||}|d d dkr|r`d|dd   }nd|dd   }|| d }|dddkrd|d< d|}|r|d| d ||f  |s|d| d |f  n.|d||f  |	s|d|  |d | }|	rHx:| d d D ](}| d!rd"|kr|| qW |dd  }g }x2|D ]*}t|| r^|d|  || q^W xF|D ]>}||krqt|| r|t
|||d# || qW xF|D ]>}||krqt|| r|t
|||d# || qW x.|D ]&}||kr4q"|t
|||d# q"W || |	r|rbn |d$ || d   |d% d fd&d'|D }|st| r|d(|||f  n|d)|||f  |r|d*| d |f  n|d+ |
d, S )-Nr   argsr   r   zf2py_%s_d%sintegerhide)r   intentzshape(%s, %s)=r   c             S   s   d|d | f |d< d S )Nz%s
      %sr   r#   )lineretr#   r#   r$   addb   s    zcreatefuncwrapper.<locals>.addnamez
%sf2pywrapr      zcharacter*(*)zcharacter(len=10)zcharacter*10r   r   z(*)10z, zsubroutine f2pywrap_%s_%s (%s)
modulenamezuse %s, only : %szsubroutine f2pywrap%s (%s)zexternal %ssaved_interface
zuse __user__)r!   	interfacezend interfacec                s   g | ]}| kr|qS r#   r#   ).0r   )
extra_argsr#   r$   
<listcomp>   s    z%createfuncwrapper.<locals>.<listcomp>z%s = .not.(.not.%s(%s))z%s = %s(%s)zend subroutine f2pywrap_%s_%sendr   )r   AssertionError	enumerategetdictappendextendboolr   r   r%   r   splitlstrip
startswithr   r   r	   r   )rout	signaturer   r   viddndvneed_interfacer,   r-   r.   fortrannamer!   Znewnamer&   lZ
charselectsargsr+   dumped_argsr#   )r7   r$   createfuncwrapperN   s    










rP   c                s  t | stg  | d }x| d D ]~}| d | }xlt|dg D ]X\}}|dkrDd||f }tddgd}d	||f |d
<  | |||< ||d |< qDW q"W | d   t }	dg}
|
fdd}| d }t| }t	| }| d }d
|}|r.|d| d ||f  |sP|d| d |f  n"|d||f  |	sP|d|  |	rx:| d dD ](}| drfd|krf|| qfW g }x2|D ]*}t|| r|d|  || qW xF|D ]>}||krqt|| r|t|||d || qW x.|D ]&}||kr*q|t|||d qW |	r|rPnP|d x>| d dD ],}| drd|krqh|| qhW |d d
 fdd|D }|s|d||f  |r|d| d |f  n|d  |
d! S )"Nr   r&   r   r   zf2py_%s_d%sr'   r(   )r   r)   zshape(%s, %s)r*   r   c             S   s   d|d | f |d< d S )Nz%s
      %sr   r#   )r+   r,   r#   r#   r$   r-      s    zcreatesubrwrapper.<locals>.addr.   z, zsubroutine f2pywrap_%s_%s (%s)r1   zuse %s, only : %szsubroutine f2pywrap%s (%s)zexternal %sr2   r3   zuse r4   )r!   r5   zend interfacec                s   g | ]}| kr|qS r#   r#   )r6   r   )r7   r#   r$   r8      s    z%createsubrwrapper.<locals>.<listcomp>zcall %s(%s)zend subroutine f2pywrap_%s_%sr9   r   )r   r:   r;   r<   r=   r>   r?   r@   r   r   r   rA   rB   rC   r   r   r%   )rD   rE   r   r   rF   rG   rH   rI   rJ   rK   r,   r-   r.   rL   r!   r&   rN   r+   rO   r#   )r7   r$   createsubrwrapper   s    






rQ   c             C   s:  t | rt| }| d }td||f  t| } |}|}d| kr^| d }| d | | d |< | d | }t|sd|krg |d< |d d d}x |d D ]}|drd	}P qW |r|d d
|  |g| d  | d d d < | t| fS t| r2t| }| d }td||f  t| } | t	| fS | dfS )Nr.   z6		Creating wrapper for Fortran function "%s"("%s")...
resultr   r)   outr   zout=r   zout=%sr&   z8		Creating wrapper for Fortran subroutine "%s"("%s")...
r   )
r   r   r   copyr
   r>   rC   rP   r   rQ   )rD   rL   r.   fnamernameZfvarflagrG   r#   r#   r$   assubr  sB    



rX   )NN)r   )r   )__doc____version__Zf2py_versionrT   Zauxfuncsr   r   r   r   r	   r
   r   r   r   r   r   r   r   r%   rP   rQ   rX   r#   r#   r#   r$   <module>   s   <
1
j
S