
    Kh                         S r SSKJr  \R                  rSSKJrJrJrJ	r	J
r
Jr  SSKJr  SSKJr  SSKJr  S
S jrS rg	)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                    / n[        U 5      (       aH  U S   R                  5        H0  u  p4U Vs0 s H  oUU S   U   _M     nnUR                  X4U45        M2     O+[        U 5      (       a  U S    H  nU[	        US5      -   nM     U(       a?  / n/ n	U H3  n
U
S   U	;  d  M  U	R                  U
S   5        UR                  U
5        M5     U$ U$ s  snf )Ncommonvarsbody    )r   itemsappendr   findcommonblocks)blocktopretkeyvaluevvars_btretnamests              I/var/www/html/env/lib/python3.13/site-packages/numpy/f2py/common_rules.pyr   r      s    
C///1JC278%Qfa((%E8JJE*+ 2 
vA(A..C 
At5 QqT"A  J 9s   Cc                 	   / / S/S.nS/nU4S jnS/nU4S jnS/nU4S jnS/nU4S jn	[        U 5       GH]  u  pnU
R                  5       n/ / pU H:  n[        UU   5      (       a  UR                  U5        M)  UR                  U5        M<     U(       a7  [	        SU
< S	S
R                  U5      < SS
R                  U5      < S35        O#[	        SU
< S	S
R                  U5      < S35        U" SU
-  5        [        U 5       H  nU" SU 35        M     U" S5        U H   nU" [        R                  " UU5      5        M"     U
S:X  a  U" SS
R                  U5      -  5        OU" SU
< SS
R                  U5      < 35        U" SS
R                  U5      -  5        U" S5        U" SU
-  5        / nU H  n[        R                  " UU   5      n[        R                  " UU   5      n[        R                  U   n[        R                  " UUU   5      nUS   (       a  UR                  SUS   -  5        OUR                  S5        US   R                  5       nU(       d  SnU" SU< SUS   < SU< SU< SU< S 35        M     U" S!5        [        U5      nS
R                  U Vs/ s H  nS"U-   PM
     sn5      nU" S#U
< S$U< S%35        U" S&5        U H  nU" S'U
< S(U< S)35        M     U" S*5        S+U;   a  S,nOS-nU" S.U< S/U< S0U
R!                  5       < S1S
R                  S2/[#        U5      -  5      < S33	5        U" S4U
-  5        U" S5U< S/U< S0U
R!                  5       < S6U
< S73	5        U" S85        U" S9U
< S:U
< S735        U" S;5        U" S<U
-  5        U" S=5        U
R%                  S+S>5      nU	" S?U-  5        U	" S@5        U Ht  nU	" SA[        R&                  " UUU   5      -  5        [)        UU   5      (       d  M;  UU   SB   n[+        U[,        5      (       a  SR                  U5      nU	" SCU-  5        Mv     U	" SD5        USE   R                  SFU
< SS
R                  [/        SG UU5      5      < SH35        GM`     XASI'   XaSJ'   USK   USL'   [#        USE   5      SM::  a  SUSE'   XSK   4$ s  snf )NNz"COMMON blocks:\n")commonhooksinitcommonhooksdocs c                 "    US   < SU < 3US'   g )Nr   z
       liness     r    faddbuildhooks.<locals>.fadd/   s    !"1t,!    c                 "    US   < SU < 3US'   g Nr   
r'   r(   s     r    caddbuildhooks.<locals>.cadd3       Q4&!r-   c                 "    US   < SU < 3US'   g r/   r'   r(   s     r    iaddbuildhooks.<locals>.iadd7   r3   r-   c                 "    US   < SU < 3US'   g r/   r'   r(   s     r    daddbuildhooks.<locals>.dadd;   r3   r-   z)		Constructing COMMON block support for "z	"...
		  ,z
		  Hidden: r0   z subroutine f2pyinit%s(setupfunc)zuse zexternal setupfunc_BLNK_z	common %szcommon /z/ zcall setupfunc(%s)zend
z'static FortranDataDef f2py_%s_def[] = {dimsz(%s)z-1z	{"z",rankz,{{z}},z, z},z
	{NULL}
};zchar *zstatic void f2py_setup_(z) {z	int i_f2py=0;z	f2py_z_def[i_f2py++].data = ;}_	F_FUNC_USF_FUNCzextern void z	(f2pyinitz	,F2PYINITz
)(void(*)(zchar*z));z static void f2py_init_%s(void) {	z)(f2py_setup_z);z}
z 	tmp = PyFortranObject_New(f2py_z_def,f2py_init_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@{}}notez--- %sz\end{description}r$   z"	/c                 
    X-   $ )Nr'   )r   ds     r    <lambda>buildhooks.<locals>.<lambda>   s    r-   z\n"r"   r#   r   latexdocr   )r   lowerr   r   r   joinr	   r   var2fixfortranr
   getctype
get_elsize
c2capi_map
getarrdimsstripr   upperlenreplacegetarrdocsignr   
isinstancelistmap)mr   fwrapr+   chooksr1   ihooksr5   docr8   namevnamesr   
lower_namehnamesinamesnusenameidimsctelsizeatdmdmsinames1r*   inames1_tpsrC   tnamerE   s                                 r    
buildhooksro   *   s   )*,CDE -TF 'TF '$C ' 0 3tZZ\
RAT!W%%a a 	 
 chhv&(8: ; chhv&( )/$67#AG4y!" '!"A))$23 8 012T388F+;<=!SXXf%567W6$?@A##DG,B))$q'2F%%b)B%%aa1B&zVr&z23R V*""$Cr&z3F4 5  	^F#hhg>g1g>?$DEAqAB S	* FF
DJJL'S\124 	5 	/$67
DJJL$8 	9UtTU./O 	 !S%(8EBC#$A+))!T!W57 8tAwAwvdD))99T?DX&'  	!"F $chhs3Evu/U&VW	Y] !4`  #!fC
O
3v;1Fa=S  ?s   0S
N)r   )__doc__r%   r   versionf2py_versionauxfuncsr   r   r   r   r   r	   r
   r   crackfortranr   r   ro   r'   r-   r    <module>ru      s:   	 ""    #(hr-   