U
    i]$                     @   s   d Z ddlmZmZm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

    )divisionabsolute_importprint_functionz$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kindselectorZkindcharselectorlen*)r   :(*)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aZfaf90modeZvardefZselectorZlk r$   6/usr/lib/python3/dist-packages/numpy/f2py/func2subr.pyvar2fixfortran   sP    





r&   c                    s  t | stg  | d }| d D ]z}| d | }t|dg D ]X\}}|dkr@d||f }tddgd}d	||f |d
<  | |||< ||d |< q@q | 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|rXd|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 | }|	r2| d d D ]}| d!r|| q|dd  }g }|D ]*}t|| rF|d|  || qF|D ]>}||krqvt|| rv|t
|||d" || qv|D ]>}||kr̐qt|| r|t
|||d" || q|D ]&}||krq|t
|||d" q|| |	r\|r<n |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   f2py_%s_d%sintegerhider   intentshape(%s, %s)=r   c                 S   s   d|d | f |d< d S Nz%s
      %sr   r$   lineretr$   r$   r%   addd   s    zcreatefuncwrapper.<locals>.addnamez
%sf2pywrapr      zcharacter*(*)zcharacter(len=10)zcharacter*10r   r   r   Z10, subroutine f2pywrap_%s_%s (%s)
modulenameuse %s, only : %ssubroutine f2pywrap%s (%s)external %ssaved_interface
use r#   	interfaceend interfacec                    s   g | ]}| kr|qS r$   r$   .0r"   Z
extra_argsr$   r%   
<listcomp>   s      z%createfuncwrapper.<locals>.<listcomp>z%s = .not.(.not.%s(%s))z%s = %s(%s)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_interfacer2   r3   r4   fortrannamer#   Znewnamer'   lZ
charselectsargsr1   dumped_argsr$   rD   r%   createfuncwrapperP   s    






r^   c                    s  t | stg  | d }| d D ]z}| d | }t|dg D ]X\}}|dkr@d||f }tddgd}d	||f |d
<  | |||< ||d |< q@q | d   t }	dg}
|
fdd}| d }t| }t	| }| d }d
|}|r&|d| d ||f  |sH|d| d |f  n"|d||f  |	sH|d|  |	r|| d dD ]}| dr\|| q\g }|D ]*}t|| r|d|  || q|D ]>}||krƐqt|| r|t|||d || q|D ]&}||kr
q|t|||d q|	rN|r.n |d || d   |d d
 fdd|D }|s||d||f  |r|d| d |f  n|d |
d  S )!Nr!   r'   r   r   r(   r)   r*   r+   r-   r.   r   c                 S   s   d|d | f |d< d S r/   r$   r0   r$   r$   r%   r3      s    zcreatesubrwrapper.<locals>.addr4   r6   r7   r8   r9   r:   r;   r<   r=   r>   r?   r@   rA   c                    s   g | ]}| kr|qS r$   r$   rB   rD   r$   r%   rE      s      z%createsubrwrapper.<locals>.<listcomp>zcall %s(%s)rF   rG   r   )r   rH   rI   rJ   rK   rL   rM   rN   r   r   r    rO   rP   rQ   r	   r   r&   )rR   rS   r!   r"   rT   rU   rV   rW   rX   rY   r2   r3   r4   rZ   r#   r'   r\   r1   r]   r$   rD   r%   createsubrwrapper   s~    



r_   c                 C   s8  t | rt| }| d }td||f  t| } |}|}d| kr^| d }| d | | d |< | d | }t|sd|krg |d< |d d d}|d D ]}|drd	} qq|r|d d
|  |g| d  | d d d < | t| fS t| r0t| }| d }td||f  t| } | t	| fS | dfS )Nr4   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   rL   rQ   r^   r   r_   )rR   rZ   r4   fnameZrnameZfvarflagrU   r$   r$   r%   assubr
  sJ     


 
re   )NN)r   )r   )__doc__Z
__future__r   r   r   __version__Zf2py_versionrb   Zauxfuncsr   r	   r
   r   r   r   r   r   r   r   r   r   r   r&   r^   r_   re   r$   r$   r$   r%   <module>   s   <
1
j
P