HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux spn-python 5.15.0-89-generic #99-Ubuntu SMP Mon Oct 30 20:42:41 UTC 2023 x86_64
User: arjun (1000)
PHP: 8.1.2-1ubuntu2.20
Disabled: NONE
Upload Files
File: //usr/local/lib/python3.10/dist-packages/numpy/f2py/__pycache__/common_rules.cpython-310.pyc
o

���g�@spdZddlmZejZddlmZmZmZm	Z	m
Z
mZddlmZddlm
Z
ddlmZddd�Zd	d
�ZdS)
a5
Build common block mechanism for f2py2e.

Copyright 1999 -- 2011 Pearu Peterson all rights reserved.
Copyright 2011 -- present NumPy Developers.
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.
�)�__version__)�hasbody�	hascommon�hasnote�
isintent_hide�outmess�getuseblocks)�	capi_maps)�	func2subr)�	rmbadnamec
s�g}t��r#�d��D]\}}�fdd�|D�}|�|||f�qnt��r5�dD]	}|t|d�}q+|rTg}g}|D]}	|	d|vrQ|�|	d�|�|	�q=|S|S)N�commoncsi|]	}|�d|�qS)�vars�)�.0�v��blockr�B/usr/local/lib/python3.10/dist-packages/numpy/f2py/common_rules.py�
<dictcomp>sz$findcommonblocks.<locals>.<dictcomp>�body�)r�items�appendr�findcommonblocks)
r�top�ret�key�value�vars_�b�tret�names�trrrrs&�
�rcCsggdgd�}dg}|fdd�}dg}|fdd�}dg}|fdd	�}dg}|fd
d�}	t|�D�]�\}
}}|
��}
gg}}|D]}t||�rN|�|�q@|�|�q@|rftd|
d
�|�d
�|�f�ntd|
d
�|�f�|d|
�t|�D]	}|d|���q{|d�|D]
}|t�||��q�|
dkr�|dd
�|��n|d|
d
�|�f�|dd
�|��|d�|d|
�g}|D]H}t	�
||�}t	�||�}t	j|}t	�
|||�}|dr�|�d|d�n|�d�|d��}|�sd}|d||d|||f�q�|d�t|�}d
�dd�|D��}|d |
|f�|d!�|D]}|d"|
|f��q/|d#�d$|
v�rGd%}nd&}|d'||
|
��d
�d(gt|��f�|d)|
�|d*||
|
��|
f�|d+�|d,|
|
f�|d-�|d.|
�|d/�|
�d$d0�}|	d1|�|	d2�|D]-}|	d3t	�|||��t||��r�||d4}t|t��r�d5�|�}|	d6|��q�|	d7�|d8�d9|
d
�td:d;�||��f�q/||d<<||d=<|d>|d?<t|d8�d@k�r�d|d8<||d>fS)ANz"COMMON blocks:\n")�commonhooks�initcommonhooks�docs�cS�d|d|f|d<dS)Nz%s
      %srr��line�srrr�fadd/�zbuildhooks.<locals>.faddcSr'�Nz%s
%srrr(rrr�cadd3r,zbuildhooks.<locals>.caddcSr'r-rr(rrr�iadd7r,zbuildhooks.<locals>.iaddcSr'r-rr(rrr�dadd;r,zbuildhooks.<locals>.daddzF		Constructing COMMON block support for "%s"...
		  %s
		  Hidden: %s
�,z7		Constructing COMMON block support for "%s"...
		  %s
z subroutine f2pyinit%s(setupfunc)zuse zexternal setupfunc�_BLNK_z	common %szcommon /%s/ %szcall setupfunc(%s)zend
z'static FortranDataDef f2py_%s_def[] = {�dimsz(%s)z-1z	{"%s",%s,{{%s}},%s, %s},�rankz
	{NULL}
};cSsg|]}d|�qS)zchar *r)rr*rrr�
<listcomp>iszbuildhooks.<locals>.<listcomp>zstatic void f2py_setup_%s(%s) {z	int i_f2py=0;z!	f2py_%s_def[i_f2py++].data = %s;�}�_�	F_FUNC_US�F_FUNCz3extern void %s(f2pyinit%s,F2PYINIT%s)(void(*)(%s));zchar*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	if (tmp == NULL) return NULL;z=	if (F2PyDict_SetItemString(d, "%s", tmp) == -1) return NULL;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"cSs||S)Nr)r�drrr�<lambda>�szbuildhooks.<locals>.<lambda>r#r$r�latexdocr)r�lowerrrr�joinrr
�var2fixfortranr	�getctype�
get_elsize�
c2capi_map�
getarrdims�stripr�upper�len�replace�
getarrdocsignr�
isinstance�list�map)�mr�fwrapr+�chooksr.�ihooksr/�docr0�name�vnamesr
�
lower_name�hnames�inames�n�usename�idims�ct�elsize�at�dm�dms�inames1�inames1_tpsr9�tnamer:rrr�
buildhooks*s��

�
�

�

�����
��rcN)r)�__doc__r&r�version�f2py_version�auxfuncsrrrrrrr	r
�crackfortranrrrcrrrr�<module>s