File: //usr/local/lib/python3.10/dist-packages/numpy/distutils/__pycache__/conv_template.cpython-310.pyc
o
���g@% � @ s� d Z ddgZddlZddlZddlZi ZdZdd� Zdd � Ze� d
�Z
e� d�Zdd
� Ze� d�Z
e� d�Ze� d�Ze� d�Zdd� Ze� d�Zdd� Zdd� Ze� dej�Zdd� Zdd� Zdd� Zdd� Zed krqe� dS dS )!aX
takes templated file .xxx.src and produces .xxx file where .xxx is
.i or .c or .h, using the following template rules
/**begin repeat -- on a line by itself marks the start of a repeated code
segment
/**end repeat**/ -- on a line by itself marks it's end
After the /**begin repeat and before the */, all the named templates are placed
these should all have the same number of replacements
Repeat blocks can be nested, with each nested block labeled with its depth,
i.e.
/**begin repeat1
*....
*/
/**end repeat1**/
When using nested loops, you can optionally exclude particular
combinations of the variables using (inside the comment portion of the inner loop):
:exclude: var1=value1, var2=value2, ...
This will exclude the pattern where var1 is value1 and var2 is value2 when
the result is being generated.
In the main body each replace will use one entry from the list of named replacements
Note that all #..# forms in a block must have the same number of
comma-separated entries.
Example:
An input file containing
/**begin repeat
* #a = 1,2,3#
* #b = 1,2,3#
*/
/**begin repeat1
* #c = ted, jim#
*/
@a@, @b@, @c@
/**end repeat1**/
/**end repeat**/
produces
line 1 "template.c.src"
/*
*********************************************************************
** This file was autogenerated from a template DO NOT EDIT!!**
** Changes should be made to the original source (.src) file **
*********************************************************************
*/
#line 9
1, 1, ted
#line 9
1, 1, jim
#line 9
2, 2, ted
#line 9
2, 2, jim
#line 9
3, 3, ted
#line 9
3, 3, jim
�process_str�process_file� NaE
/*
*****************************************************************************
** This file was autogenerated from a template DO NOT EDIT!!!! **
** Changes should be made to the original source (.src) file **
*****************************************************************************
*/
c C s� |dkr d}d}nd| }d| }d}d}g } | � ||�}|dkr#n?| � d|�}| � d |�}| � ||�} | � d | �}
|| �d ||d
�7 }|�||d
| |
d
|f� || �d |d
|
�7 }|
}q|�� |S )z�
The returned line number is from the beginning of the string, starting
at zero. Returns an empty list if no loops found.
r z/**begin repeatz/**end repeat**/z/**begin repeat%dz/**end repeat%d**/T���z*/�
� )�find�count�append�sort)�astr�level�loopbeg�loopend�ind�line�spanlist�start�start2�fini1�fini2� r �H/usr/local/lib/python3.10/dist-packages/numpy/distutils/conv_template.py�parse_structureg s. �r c C s( | � d�}| � d�}d�|gt|� �S )Nr � �,)�group�join�int)�obj�torep�numrepr r r �
paren_repl� s
r! z\(([^)]*)\)\*(\d+)z([^*]+)\*(\d+)c C s0 t �t| �} d�dd� | �d�D ��} | �d�S )Nr c S s g | ]
}t �t|�� ��qS r )�plainrep�subr! �strip��.0�xr r r �
<listcomp>� s �z parse_values.<locals>.<listcomp>)�parenrepr# r! r �split)r r r r �parse_values� s
�
r+ z\n\s*\*?z#\s*(\w*)\s*=([^#]*)#z(\w*)=(\w*)z :exclude:c s t �d| �} g }t�| �}d}|D ].}|d }t|d �}t|�}|du r(|}n||kr8d}t|||||f ��|�||f� qg } t� | �D ]"}
|
�
� }| �d|d �}| |d |� }
t�|
�}| �t
|�� qGg }|du rttd��t|�D ]� � fdd �|D �}|�|� qx|S )
a� Find all named replacements in the header
Returns a list of dictionaries, one for each loop iteration,
where each key is a name to be substituted and the corresponding
value is the replacement string.
Also return a list of exclusions. The exclusions are dictionaries
of key value pairs. There can be more than one exclusion.
[{'var1':'value1', 'var2', 'value2'[,...]}, ...]
� Nr r z.Mismatch in number of values, %d != %d
%s = %sr zNo substitution variables foundc s i | ] \}}||� �qS r r )r&