Server : LiteSpeed
System : Linux server51.dnsbootclub.com 4.18.0-553.62.1.lve.el8.x86_64 #1 SMP Mon Jul 21 17:50:35 UTC 2025 x86_64
User : nandedex ( 1060)
PHP Version : 8.1.33
Disable Function : NONE
Directory :  /opt/cppython/lib/python3.8/test/__pycache__/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]


Current File : //opt/cppython/lib/python3.8/test/__pycache__/test_buffer.cpython-38.opt-2.pyc
U

>��g'��@sddlZddlZddlmZddlmZmZddlmZm	Z	m
Z
ddlZddlZddl
Z
ddlZddlZddlmZddlmZzddlTWnek
r�dZYnXzddlZWnek
r�dZYnXzddlZWnek
r�dZYnXz:e���(e_e���ddlmZW5QRXW5QRXWnek
�rFdZYnXd	Zdddddddddddddddd
�Ze�r�ed=ed=e�r�z e� d
d�ded<ded
<Wnej!k
�r�YnXddddddddddddddd>dd>fd�Z"dd�Z#eee"e"e"e"d�Z$e�r2e$dD]Z%e#e%�e$de%<�qe�&�Z'e�&�Z(eD]Z)e)d k�rFe(e)=�qFe�&�Z*eD]Z)e)d!k�rje*e)=�qje'e$d"<e'e$d#<e(e$d$<e*e$d%<e*e$d&<dZ+dZ,d'dd(d)d*d+gd'd,d-d.gfd$gd'gfd'gd'gfd#d"gd'gfd&d%gd'gfd/�Z-d0d1�Z.d2d3�Z/d4d5�Z0d6d7�Z1d�d9d:�Z2d�d;d<�Z3d�d=d>�Z4d?d@�Z5dAdB�Z6dCdD�e$dD�Z7dEdF�Z8dGdH�Z9dIdJ�Z:dKdL�Z;dMdN�Z<dOdP�Z=dQdR�Z>dSdT�Z?dUdV�Z@dWdX�ZAdYdZ�ZBd[d\�ZCd]d^�ZDd_d`�ZEdadb�ZFdcdd�ZGdedf�ZHdgdh�ZIdidj�ZJdkdl�ZKdmdn�ZLdodp�ZMd�dtdu�ZNdvdw�ZOdxdy�ZPd�dzd{�ZQd|d}�ZRd�d~d�ZSd�d��ZTd�d�d��ZUd�d��ZVd�d��ZWd�d��ZXd�d�d��ZYd�d�d��ZZd�d�d��Z[d�d�d��Z\d�d��Z]d�Z^dqZ_d�Z`e�r�d�Z^d�Z_d�Z`eZZWe[ZXe\Ze�aed��e�aed��Gd�d��d�ejb���Zcedd�k�re�e�dS)��N)�support)�permutations�product)�	randrange�sample�choice)�Decimal)�Fraction)�*)�ndarrayT)�?�c�b�B�h�H�i�I�l�L�n�N�f�d�Prr�Q������q�r��r�)i�����)i�����)ri)���)rl�l������r���)rr
rrrrrrrrrrrrc	Cs�|dkrd}n�|dkrd}n�|dkr*d}n�|dkrFdd	>dd	>f}nfd
D]:}zt�|d|>d�Wq�WqJtjk
r�YqJXqJ|d@r�d|>d|>fn
dd|>f}|S)Nr
r rrrr&rr*r+)
r"��@�?� �����r)�struct�pack�error)�fmt�lh�exp�r;�//opt/cppython/lib/python3.8/test/test_buffer.py�native_type_rangeYs 
&r=)��@�<�>�=�!r?Z
bBhHiIlLfdZBbc�m�@m�ar�@br>r@rArBrC�1�2�3)r�array�numpy�
memoryview�bytefmtcCsvtt||�}|dkr6t|g�}|dkr6|dkr6d}|dkrFt|�}|dksV|dkrrt�||�}t�||�d}|S)	Nr
rL��rrrr)r�fmtdict�bytes�boolr5r6�unpack)�mode�char�obj�xr;r;r<�
randrange_fmt�s
rYcCsJ|�d�\}}g}|D]}|�t|||��qt|�dkrB|dSt|�S)N�#r*r)�split�appendrY�len�tuple)r8rWrU�charsrXr
r;r;r<�gen_item�s
r`cCs<|dkrt||�Sdg|}t|�D]}t||�||<q$|S�Nr)r`�range)rr8rW�lstrr;r;r<�	gen_items�s

rdcCs�tt|t�}|d}|�d�}tdd�}t|�D]H}ttt|��}tt|t�}||t	|rf|nd�7}|||7}q4t
|||�}	t||�}
||	|
fS)NrZ�ambr�
r*)r�cap�MODE�striprrbr^rQ�MULT�intrdr`)rrWrUZxfmtr8�nmemb�_rV�
multiplier�items�itemr;r;r<�struct_items�s


rqrcCs�|dkrtt|t�}|dkr0ttt|��}tt|t�}|d|t|rR|nd�}t|||�}t||�}|�	d�||}|||fS)NrZr*re)
rrgrhr^rQrjrkrdr`ri)rrWrUrVrnr8rorpr;r;r<�	randitems�s
rrccs4t|tD]"}t|D]}t||||�VqqdS�N)rgrhrQrr)rrWrUrVr;r;r<�	iter_mode�srtccs2t||�D]
}|Vq
|dkr"dSt||�VdS)Nr)rtrq)�nitemsZtestobj�tr;r;r<�iter_format�s
rwcCsd|kpd|kpd|kS)Nr
rrr;)r8r;r;r<�is_byte_format�srxcCs4t|�}|dks$|dko2|ddko2||dtkS)Nr*rrr?)r]�
MEMORYVIEW)r8rXr;r;r<�is_memoryview_format�s�rzcCsg|]}t|�s|�qSr;)rx��.0r
r;r;r<�
<listcomp>�sr}cCst|t�Srs��
isinstance�list�rcr;r;r<�atomp�sr�cCs
t|t�Srsr~r�r;r;r<�listp�sr�cCs6t|�dkrdS|d}|dd�D]}||9}q$|S�Nrr*)r])rcrX�vr;r;r<�prod�s
r�cCs�|dkrdS|dkrZt|dd��|g}t|ddd�D]}||||d9<q:n>|gt|dd��}td|�D]}||||d9<qz|S)Nrr;�Cr*r���)r�rb)�ndim�shape�itemsizeZlayout�stridesrr;r;r<�strides_from_shapesr�cCs�t|�r|St|�dkr |dSdg|d}|drFt|�|dnd}t|d�D].}||}t||||�|dd��||<qV|Sr�)r�r]rb�_ca)ro�src�strider�startr;r;r<r�s$r�cCslt|�r|St|�dkr |dSdg|d}|d}t|d�D]$}t||d|�|dd��||<qB|Sr�)r�r]rb�_fa)ror�rcr�rr;r;r<r�s"r�cCs2t|�r(d|kr(t|�t|�kr(td��t||�S�Nrzprod(shape) != len(items))r�r�r]�
ValueErrorr��ror�r;r;r<�carray,s r�cCs2t|�r(d|kr(t|�t|�kr(td��t||�Sr�)r�r�r]r�r�r�r;r;r<�farray1s r�cCsdd�|D�}t|�S)NcSsg|]}t|��qSr;�rb�r|r�r;r;r<r}8szindices.<locals>.<listcomp>)r)r��	iterablesr;r;r<�indices6sr�cCs*d}t|�D]}|||||7}q|Srar�)r��indr��retrr;r;r<�getindex;sr�c	Cs�|s|St|�}t||dd�}t||ddd�dd�}dgt|�}t|�D]2}t|||�}t||ddd�|�}||||<qL|S)Nr*r�r�r)r]r�r�r�)	�srcr�r�ZsstridesZdstrides�destr��fr�tor;r;r<�	transposeBsr�cCs6|gkr|St|�r|gSt|d�t|dd��Sr��r��_flattenr�r;r;r<r�Qs
r�cCst|�r|St|�Srsr�r�r;r;r<�flattenYsr�cCs4t|�rgSt||d�gt|d|dd��Sr�)r�r]�slice_shape�rc�slicesr;r;r<r�_sr�cs&t|�r|S�fdd�|�dD�S)Ncsg|]}t|�dd���qS�r*N)�
multislice)r|Zsublst�r�r;r<r}jszmultislice.<locals>.<listcomp>r)r�r�r;r�r<r�fsr�csFt|�r|S��fdd�t|�d|�d�D�}||�d<|S)Nc	s.g|]&\}}t||�dd��dd���qSr�)�m_assign)r|r�r��lslices�rslicesr;r<r}}s�zm_assign.<locals>.<listcomp>r)r��zip��llst�rlstr�r�r;r�r<r�ls�r�cCsft||�}t||�}t|�t|�kr(dStt|��D],}||||krNdS||dkr4dSq4dS)Nr�r)r�r]rb)r�r�r�r��lshape�rshaperr;r;r<�
cmp_structure�s

r�cCs(t||||�dkrtd��t||||�S)Nrz+lvalue and rvalue have different structures)r�r�r�r�r;r;r<�multislice_assign�sr�cs�|�rdS|dks |�|kr$dSt�fdd��D��r>dS|dkrZ|dkoX�oX�Sd�krfdSt��fdd�t|�D��}t��fdd�t|�D��}d||ko�||�|kS)NFrc3s|]}|�VqdSrsr;r��r�r;r<�	<genexpr>�sz#verify_structure.<locals>.<genexpr>Tc3s.|]&}�|dkr�|�|dVqdS�rr*Nr;�r|�j�r�r�r;r<r��s�c3s.|]&}�|dkr�|�|dVqdSr�r;r�r�r;r<r��s�)�any�sumrb)�memlenr�r�r�r��offset�imin�imaxr;)r�r�r�r<�verify_structure�sr�cCs|D]}||}q|Srsr;)rcr�rr;r;r<�get_item�s
r�c
Cs:|\}}}}}}|}t|�D]}	|||	||	7}q|Srsr�)
r�rvr�r�r�r�r�r��prr;r;r<�memory_index�s
r�cCsR|\}}}}}}d|>}t|�D],}t||�}	d|	>}
||
@rDdS||
O}q dS)Nr*TF)r�r�)rvr�r�r�r�r�r�Zvisitedr�r�bitr;r;r<�is_overlapping�s

r��r1r;csZ�s�t|d�}|dkrd|r,|||dddfStdd�}||}td�dkrP|n|}|||dd|fSd}	td�}
|
dkr�|r�d}	n|
dkr�d}	dg|�t|�D]}t|	|d��|<q�nt��}d	}td�}
|
dkr�|
d@r�d
nd}
dg|�|t||d��|d<|
�s0�|ddk�r0|�|d<t|ddd�D]j}|�|d�r`�|dnd9}|
�r�|t||d��|<n"d
td�|td|d��|<�q@d}}d�k�r�t��fdd�t|�D��}t��fdd�t|�D��}||}|�r ||}||d|}n*|||}td�dk�rF||n|}|||��|fS)Nr*rr;�r�d�_�Zr�TFr��r*r�c3s.|]&}�|dkr�|�|dVqdSr�r;r�r�r;r<r�s�z!rand_structure.<locals>.<genexpr>c3s.|]&}�|dkr�|�|dVqdSr�r;r�r�r;r<r�s�)rrbr]r�)r�Zvalid�maxdim�maxshaper�r�rur�r��minshaperrZ	maxstrideZzero_strider�r�r;r�r<�rand_structure�s\


"
��

r�c
Csp||}t|d�}|r$|||nd}td|d�}|||}t|||�}t||�\}}}}	|	|krlt�|S�Nr*)r�slice�
slice_indices�RuntimeError)
�slicelenZlistlenZmaxstartr�Zmaxstep�step�stopr�rmZcontrolr;r;r<�randslice_from_slicelen!sr�cCspdg|}dg|}t|�D]B}||}|dkr>td|d�nd}t||�||<t||�||<qt|�t|�fSr�)rbrr�r^)r�r�r�r�rrr�r;r;r<�randslice_from_shape.s

r�cCs�td|d�}d}td�}|dkr(d}n|dkr4d}td�dkrDdnd	}dg|}dg|}dg|}dg|}	t|�D�]}t||d�}
t||d�}||
kr�|
|}}
|�rt|
|
d�}t|
|
d�}
d
td�td|
d�}t||
|�}t||
�\}}}}n&|
dk�r$td|
d�nd}t||
�}t||�}td�dk�rp||
||<||<|||	|<||<qx|
|||<||<|||	|<||<qx||t|�t|	�fS)Nr*rr�r�rr��PTFr�)rrbr�r�r�r^)r�r�r�r�rZ
all_randomr�r�r�r�Zsmall�bigr�r�r�Zs_smallrmr�Zs_bigr;r;r<�rand_aligned_slices:s@






r�cCs$|\}}}}}}t||d|d�S)NrZrL)rd)r8rvr�r�rmr;r;r<�randitems_from_structureesr�c
Cs(|\}}}}}}	t|||||	t|Bd�S)N�r�r��formatr��flags)r�ND_WRITABLE)
ror8rvr�r�r�r�r�r�r�r;r;r<�ndarray_from_structureks

�r�cCsP|\}}}}}}t|�}	t|�D]\}
}t�||	|
||�q t|	||||d�S)N)�bufferr�r��dtyper�)�	bytearray�	enumerater5�	pack_into�numpy_array)ror8rvr�r�r�r�r�r��bufr�r�r;r;r<�numpy_array_from_structureqs�r�cs�|j}|r$t|��|krld|fSnH|gkrH|jdks>�|krld|fSn$t|��\}}|g}|dkrld|fS|�����fdd�tdt����D�}g}|D]2}	t�||	�d}
|
|
kr�d|fS|�	|
�q�|gkr�||fS|d|fS)Nrcsg|]}�||���qSr;r;)r|r�r�Zmemr;r<r}�szcast_items.<locals>.<listcomp>�nan)
�nbytesr�r��divmod�tobytesrbr]r5rTr\)Zexporterr8r�r�Zbytelenrr�Z	byteitemsror�rpr;r�r<�
cast_itemss(

 r�c#s�td�D]}|gVqtdd�}td�dkr0dnd��fdd	�t|�D�Vtdd�}td�dkrfdnd��fd
d	�t|�D�VdS)Nr/��r�r�r*rcsg|]}t�d��qS�r��r�r|rm�r�r;r<r}�sz!gencastshapes.<locals>.<listcomp>csg|]}t�d��qSr�r�r�r�r;r<r}�s)rbr)rr�r;r�r<�
gencastshapes�s


r�cCs0tt||d�t||d�t||d��Sr�)rrb)rr;r;r<�	genslices�sr�cs�fdd�t|�D�}t|�S)Ncsg|]}t�|��qSr;)r��r|r�r�r;r<r}�sz"genslices_ndim.<locals>.<listcomp>)rbr)r�r�r�r;r�r<�genslices_ndim�srFcCs,|s|dkrdnd}t||d�}t||�Sr�)rr�)r�allow_emptyZminlenr�r;r;r<�rslice�srccstd�D]}t||�VqdS)Nr�)rbr)rrrmr;r;r<r��sr�c#spt|�D] }t�fdd�t|�D��Vqt|�D] }t�fdd�t|�D��Vq2tdd�t|�D��VdS)Nc3s|]}t�|�VqdSrs�rr�r�r;r<r��szrslices_ndim.<locals>.<genexpr>c3s|]}t�|dd�VqdS)T)rNrr�r�r;r<r��scss|]}tddd�VqdSr�)r�r�r;r;r<r��s)rbr^)r�r�Z
iterationsrmr;r�r<�rslices_ndim�s
rccs0t|�}|dkrt|�n|}tt||��VdSrs)r^r]r)�iterabler��poolr;r;r<�rpermutation�src
Cs�z|��}Wn ttfk
r,|��}YnXt|t�rF|j}|j}nd}d}td||j	|j
|j||j|j
|f�tj��dS)N�unknownz_ndarray(%s, shape=%s, strides=%s, suboffsets=%s, offset=%s, format='%s', itemsize=%s, flags=%s))�tolist�	TypeError�NotImplementedErrorr�rrr�r��printr�r��
suboffsetsr�r��sys�stdout�flush)�ndrXr�r�r;r;r<�
ndarray_print�s"
��rr�rf�r�z%struct module required for this test.z%ndarray object required for this testc@s�eZdZdd�Zddd�dd�Zd�dd�Zd	d
�Zdd�Zd
d�Zdd�Z	dd�Z
dd�Zdd�Zdd�Z
dd�Zdd�Zdd�Zdd �Zd!d"�Zd#d$�Zd%d&�Zd'd(�Zd)d*�Zd+d,�Zd-d.�Zd/d0�Zd1d2�Zd3d4�Zd5d6�Zd7d8�Zd9d:�Zd;d<�Zd=d>�Z d?d@�Z!dAdB�Z"dCdD�Z#dEdF�Z$dGdH�Z%dIdJ�Z&dKdL�Z'dMdN�Z(dOdP�Z)e*j+Z+dQdR�Z,dSdT�Z-dUdV�Z.dWdX�Z/dYdZ�Z0d[d\�Z1d]d^�Z2d_d`�Z3dadb�Z4e5j6dcdd��Z7dedf�Z8dgdh�Z9didj�Z:dkdl�Z;dmdn�Z<dodp�Z=dqdr�Z>dsdt�Z?dudv�Z@dwdx�ZAdydz�ZBd{d|�ZCd}d~�ZDdd��ZEd�d��ZFd�d��ZGd�d��ZHd�d��ZId�d��ZJd�d��ZKd�d��ZLd�d��ZMd�d��ZNd�d��ZOd�d��ZPd�d��ZQd�d��ZRd�S)��TestBufferProtocolcCst�|_dSrs)Zget_sizeof_void_p�
sizeof_void_p��selfr;r;r<�setUp�szTestBufferProtocol.setUpF)�sliced�castc
%
s(�	rt�	���n�s t���n��d��jrΈ��d�d}td��D]:}
�	|
dkr\q��|
dkrH|�|
�	|
d7}qH|gdd�t�d�D���j}�ddkr�|}|gt�dd������j|���	�j
����	�j����	�j�����j
|���	�j����	�jt�	���
�r@��sR��	�jt�����	�jt���t�t��szt���r���r����n���}��	|����s�dS|�s�t�}d}t�	�D]�}zLt�|�}t�|�}t|t��r�tj�f|��}nt��|�}|�|�Wn"tk
�r0d}Y�qBYnX��	||��q�|�s���	���|�t��}d� dd	�|D��}��	|�!�|���r��nd
}t"��}dD�]�}�}|dk�r�t#�d
��r�t#�d��rt$|�	�}t|�	|t%d�}n0t#�d
��rt#�d��r|dk�rt|�	|d�}t&�t'|����	���|���(t)�|���dk�rP�q�t|�}|�rbdnt*}t+�dt,����	t��|�����fdd�t|�D�}t|d�dk�r�dd�|D�}t|�	|�d�} ��	t| �t���t����}!��	|!��t��jdd�}!��	|!��t��jdd�}!��	|!��t+�dt,����	t��|�����fdd�t|�D�}t|d�dk�r�dd�|D�}t|�	|t%B�d�} ��	t| �t���t��jdd�}!��	|!��t+�d
t,����	t��|�����fdd�t|�D�}t|d�dk�r,dd�|D�}t#�d��r<t%nd}"t|�	|"|B�d�} ��	t| �t���t��jd
d�}!��	|!���q�t���r$zt��}Wntk
�r�YdSXt�t��rʈjn��|f���������	�
��fdd�	}#|#|�|�-��}$|#|$dd�W5QRX|��dS)Nr;rr*cSsg|]}d�qS)r�r;r�r;r;r<r}sz-TestBufferProtocol.verify.<locals>.<listcomp>Tr>css|]}d|VqdS)z%02xNr;r{r;r;r<r�Osz,TestBufferProtocol.verify.<locals>.<genexpr>r�r��F�Arrr��r�r�r��r�r�csg|]}t���|���qSr;�r5�unpack_fromr���contigr8r�r;r<r}zs�cSsg|]}|d�qS�rr;r�r;r;r<r}}s�r�r�r���ordercsg|]}t���|���qSr;r r�r"r;r<r}�s�cSsg|]}|d�qSr$r;r�r;r;r<r}�scsg|]}t���|���qSr;r r�r"r;r<r}�s�cSsg|]}|d�qSr$r;r�r;r;r<r}�scs���|j����|j����|j����|j����|j|���|j����|jt	����	rn�s���|j
t	�
����|jt	����dkr�dnt��}��t|�|��rˆ�
�n���}��|����|��dSr�)�assertIsrW�assertEqualr�r�r��readonlyr�r�r^r�r
r]r	r�)rD�expected_readonlyr�rep)�ex�expected_lenr8r�rcr��resultrr�rr�r
r;r<�check_memoryview�sz3TestBufferProtocol.verify.<locals>.check_memoryview)r+).r�r]r
Z
assertGreaterrbrr�r(rWr)r�r�r�r*r�r�r^r�rrrzr	r�r�r��get_pointerr�r5r6�extend�BufferErrorrM�join�hexr��
is_contiguousr��
ND_FORTRAN�get_contiguous�
PyBUF_READ�
assertTrue�
cmp_contigr��py_buffer_to_contiguous�
PyBUF_FULL_RO�
toreadonly)%rr/rWr�r8r*r�r�r�rcrrZ
suboffset0rZstride0r,rZbuf_errr�Zitem1Zitem2rXrDrZffZ	flattenedr'�expectedZtransrl�roZinitlst�yZcontig_bytesrr0Zmmr;)
r#r-r.r8r�rcr�r/rr�rr�r
r<�verify�s




�
���
����
&
zTestBufferProtocol.verifycCstdd�}dd�}|jr ||t�s�||t�r0|jr�||t�r@|jr�||t�rP|jr�||t�s`|j	s�||t
�sp|jr�||t�s�||t�r�|j
tt||d�dSt|t�s�t|j�r�|��}nt|td�}|��}||t�r�dn|j}	|j}
|j}|j}||t��s
d}
|��}||t��sd}||t��r,|jnd	}
||t
��rB|jnd	}t||d�}|j||||
|	||
|||d
�
dS)NcSs|jdkp|jdkS)Nr>r�r��r-r;r;r<�
simple_fmt�sz4TestBufferProtocol.verify_getbuf.<locals>.simple_fmtcSs||@|kSrsr;)�req�flagr;r;r<�match�sz/TestBufferProtocol.verify_getbuf.<locals>.match��getbufFr>r*r;)	rWr�r8r*r�r�r�rcr)r*�PyBUF_WRITABLE�PyBUF_C_CONTIGUOUS�c_contiguous�PyBUF_F_CONTIGUOUS�f_contiguous�PyBUF_ANY_CONTIGUOUS�
contiguous�PyBUF_INDIRECTr
�
PyBUF_STRIDES�PyBUF_ND�PyBUF_FORMAT�assertRaisesr3rrrzr�r	r=r�r�r�r�r�rB)rZorig_exr-rFrrErHrcrr@r8r�r�r�r�r;r;r<�
verify_getbuf�st����������	�	���

�z TestBufferProtocol.verify_getbufcs8tttttttttt	t
ttt
tf}dd�td�D�dfddddd	d
ddd
dddgdfddddd	d
ddd
dddgdfdd�td�D�dff}ggdfdddggdfdggdfdgdgdfd
gdgdfd
gdgdfddggdfddgddgdfddgddgdfddgddgdff
}dttttBtttBf}dttttBf}|D�]�\}}t�|��|D�]x\}}	}
�fdd�|	D�}	|
�9}
|D�]J}|	�r�|t@�r��q||�s�|t@�r��q||�r�|n|d}t|||||	|
d�}
|�r�|
ddd�nd}t|
�}|�r�t|�}|
jdk�s"|
jdk�r.|�r.|	�r.|�||
�|�rX|jdk�rX|�rX|	�rX|�||�|D]h}|D]\}|�|
|
||B�|�|
|||B�|�rd|j||||Bdd�|j||||Bdd��qd�q\�q|�qR�q:ddddd	d
ddd
dddg}t|dgtd�}|�tt|�td
gdg�}t|td�}|jtt|td�|jtt|td�|jtt|td�|jtt|td�|jtt|td�|jtt|td�t|td�}dddgdddgfD]�}dtfD]p}t|||tBd�}|�t |d��|�t |d��|D]2}t||d�}|�t |d��|�t |d���q��q��q�dS) NcSsg|]}|drdnd�qS)rTFr;�r|rXr;r;r<r}sz:TestBufferProtocol.test_ndarray_getbuf.<locals>.<listcomp>�rr*rrr�r�r�r4r3�	rf�rrcSs$g|]}|drd|nd|�qS)rr%r$r;rXr;r;r<r}
srrr�������csg|]}|��qSr;r;r�r�r;r<r}%s)r�r�r�r�r�T)r�r�r�rIrr�)!rRrSrT�PyBUF_SIMPLErLrNrP�
PyBUF_FULLr=�
PyBUF_RECORDS�PyBUF_RECORDS_RO�
PyBUF_STRIDED�PyBUF_STRIDED_RO�PyBUF_CONTIG�PyBUF_CONTIG_ROrbr�r7�ND_PILrKrUr5�calcsizerrMr�r)rW�ND_GETBUF_FAILrVr3r:r6)r�requestsZ	items_fmtZ	structureZndflagsZ
real_flagsror8r�r�r�r�Z_items�ex1�ex2�m1�m2rF�bitsr-�baserr'r;r�r<�test_ndarray_getbuf�s���
���

�$��z&TestBufferProtocol.test_ndarray_getbufc
Cstdgdg�}tdgdgtd�}t|j|jfD�]z}|�t|dddh�|�t|dddg�|�t|dddg�|jt|dddgdhd�|jt|dddgdgdhd	�|jt|dddgdggd
�|jt|dgdgid�|jt|dgdgid�|jt|dgdgid
�|jt|dgdgdgtd�|jt|dggtd�|jt|gdgd�|jt|dgdgdd�|jtj	|dgdgdd�|jt|ddgdgdd�|jt|dddgdgdd�t
d}|jt|dg|dg|d�|jt|dgdgd�|jt|dddgdgd�|jt|dgddgd�|jt|dddddgddgdd
�|jt|dddgdgdgd	�|jt|dgdgddgd	�|jt|ddgddgdgd	�|jt|ddddgdgdgdd�|jt|dddgdgdd
�|jt|dddgdgddd�|jt|dddgdgdd�|jtj	|dgdgdd�ddddddd d!dd"g
}|jt||ddgd#d$gdd%�|jt|t�d&d'�|jt|dgdgt
d
�|�t|dg�q.|jttd(td)�tdgdgtd�}|jt|jdgdgtd�td(�}|�t|jdgdg�|�t|j�tdgdg�}|�dgdg�t|�}|�t|jdgdg�|�t|j�|��|��|�t|j�~|�ttidddg�|�ttd(i�tttd*��dgd*d�}|�tt|dg�tttd+��ddgd�}|�tt|dddg�|�tt|ddg�|�tt|d#dg�|�tt|d,dg�tdddgdgdd�}t|td)�}|�t|j�tdddgdgdd�}t|�}	t|	�}|�t|j�td-gdgd.d�}|�t|j�t
}ttt|��dg|d�}|�t|j�tdgdgd�}|�ttddddd�|�tt|d/d0�|�tt|d,d0�|�tt|td1�|�tt|td2�|�tt|td3�|�tt|d4d5�tdgdgd�}|�ttddddd�|�tti|�|�tt|i�tdgdgd�}|�ttddddd�|�ttid5�|�tt|d6�dS)7NrZr*�r�rrrJ�rr�r�r��r�r�rr^)r�rJ�r�r�r�ZXXXri�r�rrZQLr�r"r�r�rH�r�r�r�)r�r�r�r>�r*rrz@#$r�r4r3rf���r\)r�r�r�rrC�123rIr�rYr))�r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*r*Z�LLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLL�xyzr��u �Z�r��)r�ND_VAREXPORT�pushrVr
r7rgr�r5r7ZND_MAX_NDIM�
OverflowErrorr�r`r3rK�poprM�releaser1r�rbr_r	�memoryview_from_bufferr8r9�UnicodeEncodeErrorr;r6)
rrZndmr
rrorDr-rkrlr;r;r<�test_ndarray_exceptionscs��"������z*TestBufferProtocol.test_ndarray_exceptionscCs�ttd��D]�}dgd}tdddgdgtd�}t|�|d<tdd�D]&}|jdddgdgd�t|�||<qFtd�D]}|||��qv|�t|j	�~qdS)Nr�rr*rrr^r�)
rrbrr�rMr�r�rVr3r�)r�permrDrrr;r;r<�test_ndarray_linked_lists
z+TestBufferProtocol.test_ndarray_linked_listcCsLtd�D]>\}}}t�|�}t|d|d�}|j|d||dddd|d�	qdS)Nrr;rT�rWr�r8r*r�r�r�rc)rwr5rhrrB)rr8Zscalarrmr�rr;r;r<�test_ndarray_format_scalars
�z-TestBufferProtocol.test_ndarray_format_scalarc
Csltdd�}t|�D]T\}}}t�|�}dtfD]6}t||g||d�}|j|d||dd|f|f|d�	q.qdS)Nr*rfrrTr�)rrwr5rhrgrrB)rrur8rormr�r�rr;r;r<�test_ndarray_format_shapes

�z,TestBufferProtocol.test_ndarray_format_shapecCs�tdd�}t|�D]�\}}}t�|�}tdd�D]�}|dkr>q0t|dd|��g}||g}|dkrp||dnd}	dtfD]>}
t|||||	|
d�}|j|d||dd|||dd|�d�	q|q0qdS)	Nr*����r�rr�Tr�)	rrwr5rhrbr]rgrrB)rrur8rormr�r�r�r�r�r�rr;r;r<�test_ndarray_format_strides's0


��z.TestBufferProtocol.test_ndarray_format_stridescCsTddddddddd	d
ddg}t|d
dd�}t|ttBd�}|�|��t|d
��dS)Nr*rrr�r�r�r4r3rZrfr[rYrs)r*rr�rI)rrNrUr)r	r�)rror-rr;r;r<�test_ndarray_fortran<sz'TestBufferProtocol.test_ndarray_fortrancCs^td�D�]N}dd�t|�D�}t|�}t|�D�]$}t|�\}}}t�|�}dtfD]�}	|dkrl|	tkrlqVt||||	d�}
t|||d�}t	||�}|j
|
d||d||||d�	t|��rt|||d	�}
t|
tt
Bd
�}
|�|
jdk�|
��}|j
|d||d||||d�	t||||	tBd�}
t|||d�}t||�}|j
|
d||d||||d�	qVq0qdS)
Nr�cSsg|]}tdd��qS)rrfr�r�r;r;r<r}Dsz<TestBufferProtocol.test_ndarray_multidim.<locals>.<listcomp>rrr�Tr�rrIr;r)rbr�rrrr5rhrgrr�r�rBrzrfrUr:r�r�r7r�)rr��shape_trur�r8rormr�r�rr�rcr-�mvr;r;r<�test_ndarray_multidimBsb

�
��
�z(TestBufferProtocol.test_ndarray_multidimcCs�tdgdgd�}|�t|jdd�t|�}|�||�|�t|jdd�tdgdgtd�}|�t|jd�t|�}|�||�|�t|jd�tdgdgtd�}|�t|j	d�|�t|jdd�t|�}|�||�|�t
|j	d�|�t
|jdd�ddddd	d
ddg}t|t|�gdtd
�}|�tj
|jdd�|�t|jdd�t|�}|�||�|�t|jdd�|�t|jdd�dddg}t|t|�gdtd
�}|�t|jdd�|�tj
|jdd�dS)Nr*r�r3r^r)rrr�r�r�r4rri,)r����r*rrs)r�r�ZLQ)s1r�)rrVr
�__setitem__rMr)r��__delitem__r��__getitem__�
IndexErrorr]r5r7r�)rrr�ror;r;r<�test_ndarray_index_invalidos:
z-TestBufferProtocol.test_ndarray_index_invalidcCsJtddtd�}t|�}|�||�|d}|�|d�|d}|�|��|���|d}|�|d�|d}|�|��|���|�t|jd�|�t|jd�|�t|jdd�|�t|jdd�|�|��d�|�|��d�d|d<|�|��d�d|d<|�|��d�d|d<|�|��d�d|d<|�|��d�dS)	Nr*r;r^.rr3rZr�)	rr�rMr)r	rVr
r�r�)rrr�rXr;r;r<�test_ndarray_index_scalar�s2z,TestBufferProtocol.test_ndarray_index_scalarcCsRtttd��ddgtd�}t|td�}|�t|jd�|�t|jtddd��dS)	Nr3rr�r^rIr*rr�)	rr�rbr�rerVr3r�r�)rr-rr;r;r<�test_ndarray_index_null_strides�sz2TestBufferProtocol.test_ndarray_index_null_stridescCstd�D]�\}}}t|dg|d�}tdd�D]}|�||||�q,|�t|jd�|�t|jd�t|�rt|�}|�||�tdd�D]}|�||||�q�|�t|jd�|�t|jd�qtd�D]�\}}}t|dgt	|d�}t|t
tBd�}tdd�D]}|�||||��qt|�r�|��}|�
|�|�t�tdd�D]}|�||||��qNq�ddd	d
dg}t|dgd�}t|td�}tdd�D]}|�||||��q�ddd	d
dg}t|dgd�}t|td�}tdd�D]}|�||||��q�dS)Nr�rr����r%rIr*rrr�r�)rwrrbr)rVr�r�rzrMr�rerUr�r(�__eq__�NotImplementedrfr_)rr8rormrrr�r-r;r;r<�!test_ndarray_index_getitem_single�sBz4TestBufferProtocol.test_ndarray_index_getitem_singlecCs�td�D]�\}}}t|dg|td�}td�D]}|||<|||<q,|�|��|�|�t|jd|�|�t|jd|�t	|�s�qt|dg|td�}t
|�}|�||�td�D]}|||<|||<q�|�|��|�|�t|jd|�|�t|jd|�qtd�D]�\}}}t|dg|td�}tdd�D]&}||d||<||d||<�q(|�|��|�t	|��sn�qt|dg|td�}t
|�}|�||�tdd�D]&}||d||<||d||<�q�|�|��|��qdS)Nr�rr�r�r�r*)rwrr�rbr)r	rVr�r�rzrM)rr8roZsingle_itemrrr�r;r;r<�!test_ndarray_index_setitem_single�sD


z4TestBufferProtocol.test_ndarray_index_setitem_singlec

Cs�d}t|�}t|�D�]�}t|�\}}}dtfD�]�}t||||d�}t||�}	t|d|d�D]�}
|�|	|
||
���t|d|d�D]b}|�|	|
|||
|���t|d|d�D](}|�|	|
||||
||�q�q�qdt||||t	Bd�}t
||�}	t|d|d�D]�}
|�|	|
||
���t|d|d�D]d}|�|	|
|||
|���t|d|d�D]*}|�|	|
||||
||��q��q\�q,q0qdS)N�rrr�rrr*r)r�rrrrgrr�rbr)r	r7r�)
rr�rur�r8rormr�rrcrr��kr;r;r<�#test_ndarray_index_getitem_multidims.
 *�
 z6TestBufferProtocol.test_ndarray_index_getitem_multidimcCs�tddd�}|�ttdt��t|�}|�||�|�ttdt��td�D]�\}}}t|dg|d�}t|�D]&\}}|�|||�|�	||k�qnt
|�rLt|�}t|�D]&\}}|�|||�|�	||k�q�qLdS)Nr*r;r�z1 in ndz1 in mvr�r)rrVr
�eval�localsrMr)rwr�r:rz)rrr�r8rormrr�r;r;r<�test_ndarray_sequence6sz(TestBufferProtocol.test_ndarray_sequencec	Cs�ddddddddg}t|dgtd	�}t|�}|�t|jtd
dd�|�|�t|jtd
dd�|�t|dgtd	�}t|dgtd	�}t|td�}|�t|jtd
dd�|�t|dgdtd
�}t|�}|�t	|j
td
dd
��|�t	|j
td
dd
��t|ddgdtd
�}t|�}|�t	|j
td
dd�td
dd
�f�|�t	|j
td
dd
�td
dd�f�|�t|j
d�|�t|j
dtd
dd�f�|�t|j
td
dd�if�|�t|j
td
dd�td
dd
�f�|�t|j
d�t|dgdtd
�}t|dgdd�}t|�}t|�}|�t	|jtd
dd�|dd��|�|�
�|�|�t	|jtd
dd�|dd��|�|�
�|�t|dgdtd
�}t|dgdd�}	t|�}t|�}|�t	|jtd
dd�|dd��|�|�
�|�|�t	|jtd
dd�|dd��|�|�
�|�t|ddgdtd
�}t|dgdd�}t|�}t|�}|�t	|jtd
dd�|dd��|�|�
�ddddgddddgg�|�t|jtd
dd�|dd��t|dgdtd
�}t|dgdd�}t|�}t|�}|�t	|jtd
dd�|dd��|�|�
�|�|�t	|jtd
dd�|dd��|�|�
�|�|�tttd
dd�i�|�ttdd�|�t	ttd
dd
�d�t|dgdtd
�}
|�t|
j�t|dgdd�}t|td�}
|�t|
j�dS)Nr*rrr�r�r�r4r3r^rrIrrz@%$rrrz###########)rr�rMrVr
r�r�rTr3r�r�rr)r	r�rg�add_suboffsetsr_)rro�xl�mlr-�xrrr��mr�yrrXr;r;r<�test_ndarray_slice_invalidIs�
�
�
�"""""$
�""z-TestBufferProtocol.test_ndarray_slice_invalidcCsddddddddd	d
ddg}t|dgd
td�}t|dgd
d�}|d	d	�|dd�<|�|��|�t|�}t|�}|�||�|�||�|d	d	�|dd�<|�|��|�t|ddgd
td�}t|ddgd
d�}|dd�dd�f|dd�dd�f<|�|��t|ddg��dS)Nr*rrr�r�r�r4r3rZrfr[rYrrr)rr�r)r	rMr�)rrorXrAr�r�r;r;r<�test_ndarray_slice_zero_shape�s$z0TestBufferProtocol.test_ndarray_slice_zero_shapec
Csd}t|�}t|�}t|�D]�}t|�\}}}t�|�}dtfD]�}	t||||	d�}
t||�}t	||�D]�}d}
zt
||�}Wn(tk
r�}z
|j}
W5d}~XYnXd}z|
|}Wn(tk
r�}z
|j}W5d}~XYnX|s�|
r�|�
||
�qh|�|��|�qhq@qdS�Nr�rr)r]r�rrrr5rhrgrr�rr��	Exception�	__class__r(r)r	)rr�r�rur�r8rormr�r�rrcr��listerrr�e�nderr�ndslicedr;r;r<�test_ndarray_slice_multidim�s.

z.TestBufferProtocol.test_ndarray_slice_multidimcCs.d}t|�}t|�}t|�D�]
}t|�\}}}t�|�}t|||d�}	|	��t|||d�}
|
��t|
�}t	||�}t
||�D]�}
d}zt||
�}Wn(tk
r�}z
|j
}W5d}~XYnXd}z|	|
}Wn(tk
r�}z
|j
}W5d}~XYnX|�s|�r|�||�q�|�|��|�q�qdS)N)rrr�rr)r]r�rrrr5rhrr�rMr�rr�r�r�r(r)r	)rr�r�rur�r8rormr�rr-r�rcr�r�rr�r�r�r;r;r<�'test_ndarray_slice_redundant_suboffsets�s4

z:TestBufferProtocol.test_ndarray_slice_redundant_suboffsetscCstd�D�]�\}}}td�D�]�}td�D�]�}dtfD�]�}|tB}t|dg||d�}t|dg||d�}	t|	�}
d}d}|dd�}
z0|
|}|
|}|
||
|<t|�t|�k}Wn(tk
r�}z
|j}W5d}~XYnXd}z||||<Wn*tk
�r}z
|j}W5d}~XYnX|�r4|�	|t
�n|�|��|
�|�	||�t
|��s\q8d}z|
||
|<Wn*tk
�r�}z
|j}W5d}~XYnX|�r�|�	|t
�q8|�|
��|
�|�|
|�|�	||�|j|
|	|j|d|j|j|j|��d�	q8q*qqdS)Nr�rrFr�)rwr�rgr�rrMr]r�r�r(r�r)r	rzrBr�r�r�r�)rr8rorm�lslicerr�rrr-r�ZlsterrZdiff_structurercZlvalZrvalr�r�Zmverrr;r;r<� test_ndarray_slice_assign_single�s`
�z3TestBufferProtocol.test_ndarray_slice_assign_singlec
Cs$d}t|�}t|�}t|�D�]}t|�\}}}dtfD]�}tt�D]�}t||�\}	}
t||||t	Bd�}t
||�}d}
zt|||	|
�}Wn(tk
r�}z
|j
}
W5d}~XYnXd}z||
||	<Wn(tk
r�}z
|j
}W5d}~XYnX|s�|
�r
|�||
�qD|�|��|�qDq8qdSr�)r]r�rrrrgrb�
ITERATIONSr�rr�r�r�r�r�r(r)r	)rr�r�rur�r8rormr�r�r�rrcr�r/r�r�r;r;r<�"test_ndarray_slice_assign_multidim/s2�

z5TestBufferProtocol.test_ndarray_slice_assign_multidimc
Cs8tt�D�](}tdD�]}t�|�}t|dttd�}|�t	|��t
||�}t|||�}|��}t
|�}t|�r�|��}	|�|	|�|ddkr�t|||td�}
|
��}|�||�t
|
�}t|�r�|�||
�|��}	|�|	|�tr|d}d|kr�qt|||�}
|j|d|
j|d|
j|
j|
j|
��d	�	qqdS)
Nr?T�r�r�rrrrrFr�)rbr�rQr5rhr��MAXDIM�MAXSHAPEr:r�r�r�r	rMrzr)rgr�r�rBr�r�r�r�)rrmr8r�rvrorXZxlistr�ZmvlistrAZylistr��zr;r;r<�test_ndarray_randomPsJ
�
�z&TestBufferProtocol.test_ndarray_randomcCs�tt�D]�}tdD]�}t�|�}t|dttd�}|�t	|��t
||�}d}zt|||�}Wn(tk
r�}z
|j
}W5d}~XYnX|�|�trd}	zt|||�}
Wqtk
r�}z
|j
}	W5d}~XYqXqqdS)Nr?Fr�)rbr�rQr5rhr�r�r��assertFalser�r�r�r�r�r:r�r�)rrmr8r�rvror�rXr�Z	numpy_errrAr;r;r<�test_ndarray_random_invalidys*
�

z.TestBufferProtocol.test_ndarray_random_invalidc
Cs2tt�D�]"}tdD�]}t�|�}tttd�\}}}}t|d|d�}t|d|d�}	|�	t
|��|�	t
|	��t||�}
t||	�}t|
||�}t|||	�}
|
|||<|�
�}|
�
�}t|�}t|
�}|�|�
�|�|�|�
�|�|ddk�r�|	ddk�r�t|
||td�}t|||	td�}||||<|�
�}|�
�}|�||�|�||�t|�}t|�}|�|�
�|�|�|�
�|�trd|ksd|k�r�qt|
||�}t|||	�}||||<t|��st|	��s|j|d|j|d|j|j|j|�
�d	�	|j|
d|j|d|j|j|j|�
�d	�	qqdS)
Nr?r�Tr�rrrrFr�)rbr�rQr5rhr�r�r�r�r:r�r�r�r	rMr)rgr�r�r�rBr�r�r�r�)rrmr8r�r�r�r�r��tl�trZlitemsZritemsr�r�ZxllistZxrlistr�r�Zylr�ZyllistZyrlistZzlZzrr;r;r<� test_ndarray_random_slice_assign�sr

�


��z3TestBufferProtocol.test_ndarray_random_slice_assigncCs�ddddddddd	d
ddg}t|ddgtd
�}t|�}|�|jt@�|�|j|�|�|jd�|�|j	�|�|j
�|�|j�dS)Nr*rrr�r�r�r4r3rZrfr[rYr^)rr�)rrgr:r�r(rWr)r
r�rMrOrQ)rrorr-r;r;r<�test_ndarray_re_export�sz)TestBufferProtocol.test_ndarray_re_exportc	Cs�dtfD]�}tdddgdg|d�}t|�}|�||�|�|��g�|�|��g�tdddgdddg|d�}|�|��g�tdddgdddg|d�}|�|��gggg�tdddgdddg|d�}|�|��ggggggggggggg�qdS)Nrr*rrr^�rgrrMr)r	�rr�rr�r;r;r<�test_ndarray_zero_shape�s
�z*TestBufferProtocol.test_ndarray_zero_shapec	CspdtfD]b}tdgdgdg|d�}t|�}|�||�|�|��dddddg�|�|��dddddg�qdS)Nrr*r�rur�r�r;r;r<�test_ndarray_zero_strides�sz,TestBufferProtocol.test_ndarray_zero_stridescCs@tttd��dgdd�}|�|jd�|�|��dddg�dS)N�rr4rtr3rZ)rr�rbr)r�r	�rrr;r;r<�test_ndarray_offset�sz&TestBufferProtocol.test_ndarray_offsetcCs>dtfD]0}tttd��dg|d�}|��}|�||�qdS�Nrrr^)rgrr�rbr�r))rr�rrDr;r;r<�#test_ndarray_memoryview_from_buffersz6TestBufferProtocol.test_ndarray_memoryview_from_buffercCsPdtfD]B}tttd��dg|d�}td�D]}|�||t||g��q,qdSr�)rgrr�rbr)r1)rr�rrr;r;r<�test_ndarray_get_pointersz+TestBufferProtocol.test_ndarray_get_pointercCs^tttd��dddgd�}t|ttBd�}|�|��|���t|�}|�|��|���dS)Nr�rr�r�rI)rr�rbrTrUr)r	rM)rr-rrDr;r;r<� test_ndarray_tolist_null_strides
s
z3TestBufferProtocol.test_ndarray_tolist_null_stridescCs�|�tdd��tttd��ddgd�}tttd��ddgd�}|�t||��tdgdgdd	�}|�t|d
��|�td
|��dS)Nrzs456rYrr�r�r*rrrP)r�r;rr�rbr:)rrXrAr;r;r<�test_ndarray_cmp_contigsz*TestBufferProtocol.test_ndarray_cmp_contigcCs�t�ddddg�}t|�}|�tt|�tttd���}tttd��dgd�}|�t|�t|��tttd��ddgd�}|�t|�t|��tttd��dddgd�}|�t|�t|��tt	ttd��ddgd��}tttd��ddgt
d�}|�t|�t|��tt	ttd��dddgd��}tttd��dddgt
d�}|�t|�t|��tttd���}tttd��dddgtd�}|�t|�t|��tttd��dddgdd	�}|�t|�t|����dS)
Nrr*rrrYr�r�r^r)
rKrrVr��hashrRr�rbr)r�r7rgr�)rrFrrr;r;r<�test_ndarray_hash"s*z$TestBufferProtocol.test_ndarray_hashc
Csdtttttttttt	t
tf}|�t
tidt�tdddtd�}dD]*}|D] }t|||�}|�||���qJqBtdgdgdtd�}dD]&}|D]}t|||�}|�|d	�q�q�tttd
��dddgdtd�}dD]&}|D]}t|||�}|�|d	�q�q�dtfD]�}tdgdgd
|tBd�}|��}dD]*}|D]}t|||�}|�||��q0�q(tdddgdgd|tBd�}|��}dD]*}|D]}t|||�}|�||��q��q|�qtdddgdgdgtd�}|��}dD].}ttfD]}t|||�}|�||��qސq�|ddd�}|��}dD]L}|D]@}zt|||�}Wntk
�rTY�q$YnX|�||��q$�qttd��}dtfD�]�}t|ddg|tBd�}t�r�tt|�ddgd|dk�r�dndd�}	|tk�r�tt|ddg�ddgtd�}
|
��}n|��}|D]�}zt|d|�}Wntk
�r2Y�qYnX|�||�tdd�|D�ddgtd�}|�t|�t|��t�r|�||	jdd���q|dk�r�tt|ddg�ddgtd�}
nt|ddgtd�}
|
��}tttttfD]�}zt|d|�}Wntk
�rY�q�YnX|�||�tdd�|D�ddgttBd�}|�t|�t|��t�r�|�||	jdd���q�|tk�r�t|ddgtd�}
|
��}n|��}tttttfD]�}zt|d|�}Wntk
�r�Y�q�YnX|�||�tdd�|D�ddg|tBd�}|�t|�t|��t�r�|�||	jdd���q��q~tttd��ddgttBd�}t|dt�}|�||���tdd�|D�ddgtd�}|�t|�t|��t|dt�}tt|ddg�ddgtd�}
|�||
���tdd�|D�ddgttBd�}|�t|�t|��t|dt�}|�||���td d�|D�ddgtd�}|�t|�t|��dS)!NrrZr;rrrr*r�r3rr4rrrrur�rYr�r^rr�)r�r�r�r'cSsg|]}|�qSr;r;r�r;r;r<r}�szCTestBufferProtocol.test_py_buffer_to_contiguous.<locals>.<listcomp>r&cSsg|]}|�qSr;r;r�r;r;r<r}	srcSsg|]}|�qSr;r;r�r;r;r<r}	scSsg|]}|�qSr;r;r�r;r;r<r}'	scSsg|]}|�qSr;r;r�r;r;r<r}.	scSsg|]}|�qSr;r;r�r;r;r<r}4	s)rRrSrTr_r`r=rarbrcrdrerfrVr
r<rr�r)r�r�rbr7r3r�r�r�rM�tostringrg)
rrjrr'ZrequestrrZndbytesrcZnarXr?rAr;r;r<�test_py_buffer_to_contiguousGs���B�
�

�� 

�  z/TestBufferProtocol.test_py_buffer_to_contiguouscCs�dgfdddgdgfttd��dddgfg}|D�]H\}}t||d�}t|�}|�|j�|�|j�t|�}t||dd�}t	||�}|j
||dd	d
||||d�	t|�}	|j
|	|dd	d
||||d�	t|ttBd�}
|�
|
jd
�|
��}|j
|ddd	d
||||d�	t|td�}
|�
|
jd�|�
|
jd
�|�
|
jd
�|
��}|dk�rV|gn|}|j
|ddd	d
d|jgd|d�	q0|D]�\}}t||td�}t|�}|�|j�|�|j�t|�}t||dd�}t||�}|j
||dd	d
||||d�	t|�}	|j
|	|dd	d
||||d�	�q�|dd�D]v\}}t||td�}t|�}t|�}t	||�}|j
||dd	d
|||j|d�	t|�}	|j
|	|dd	d
|||j|d�	�q&|�ttdd�|�tti�tdddgdgd�}t|td�}
|�tt|
�t|ttBd�}
|�tt|
�tdgddgddd�}
|�tt|
�|�t|
j�|�tt|
td�|�tt|
td�|�tt|
ddd�td�dS)NrZr*rrr�r�r�r�rTr�rIr;r>r�r*r^r�9rXr"rrr�)r�rbrrMr:rMrQr]r�r�rBrfrUr)r�r�r_r�r�r�r7rOr�rgrVr
r3r�r8r9)rZitems_shaperor�r-rDr�r�rcrnrr;r;r<�test_memoryview_construction7	s�,
����
��

��
z/TestBufferProtocol.test_memoryview_constructioncCs�dddg}dddgdddgdddgfD]4}t||d�}|�|j�t|�}|�t|jd�q&tdd�D]<\}}}td�}|�|�}|�|�	�d�|�|�
�g�qfdS)	Nr*rrrr�r
rMr�)rr:rMrMrVr
rrwr)r�r	)rror�r-�msrcr8rmrDr;r;r<�test_memoryview_cast_zero_shape�	s
 
z2TestBufferProtocol.test_memoryview_cast_zero_shapecCs�|j}tj}d}d}ttd��}|td�||d|��t|ddgdd	�}|t|�||d|��t|dddgdd	�}|t|�||d
|��dS)NzPnin 2P2n2i5P PZ3nr3r�r*rr�rrr)�check_sizeofrZcalcvobjsizer�rbrMr)r�checkZvsizeZbase_structZper_dimrorFr;r;r<�test_memoryview_sizeof�	sz)TestBufferProtocol.test_memoryview_sizeofcCs�Gdd�dt�}Gdd�dt�}dd�}|d�|d�dtd	�d
tdd�d
ddgdddhddidddddtddtd�td�dddd|dd�g}tdd�D�]6\}}}t|dg|td�}t|dg|td�}	t|�}
t	�
||	d |�||
d <|�|
d |	d �t	�|�}d!|k�rq�|D]�}d}
zt	�
||	||�Wnt	j
k
�rNt	j
}
YnXd}z||
d
<Wn.ttfk
�r�}z
|j}W5d}~XYnX|
�s�|�r�|�|
d�|�|d�n|�|
d
|	d
��qq�dS)"Nc@seZdZdd�Zdd�ZdS)z=TestBufferProtocol.test_memoryview_struct_module.<locals>.INTcSs
||_dSrs��val�rr�r;r;r<�__init__�	szFTestBufferProtocol.test_memoryview_struct_module.<locals>.INT.__init__cSs|jSrsr�rr;r;r<�__int__�	szETestBufferProtocol.test_memoryview_struct_module.<locals>.INT.__int__N)�__name__�
__module__�__qualname__r�r�r;r;r;r<�INT�	sr�c@seZdZdd�Zdd�ZdS)z=TestBufferProtocol.test_memoryview_struct_module.<locals>.IDXcSs
||_dSrsr�r�r;r;r<r��	szFTestBufferProtocol.test_memoryview_struct_module.<locals>.IDX.__init__cSs|jSrsr�rr;r;r<�	__index__�	szGTestBufferProtocol.test_memoryview_struct_module.<locals>.IDX.__index__N)r�r�r�r�r�r;r;r;r<�IDX�	sr�cSsdS)Nr4r;r;r;r;r<r�	r�z;TestBufferProtocol.test_memoryview_struct_module.<locals>.frZy������@@z-21.1gffffff(@r�rr*rr�r�r4r3r;�rZTF�asabcrF�abccSs|Srsr;)rXr;r;r<�<lambda>�	r�zBTestBufferProtocol.test_memoryview_struct_module.<locals>.<lambda>rfrMrrr)�objectrr	r�r�rwrr�rMr5r�r)rhr7r
r�r�ZassertIsNot)rr�r�r�valuesr8rorpr-rrDr�r�Z
struct_errZmv_errr�r;r;r<�test_memoryview_struct_module�	sj�

z0TestBufferProtocol.test_memoryview_struct_modulecCs@tdddgdgdgd�}|�|j�t|�}|�t|jd�dS)Nr*rrrr�r
)rr�rMrMrVr
r)rr-r�r;r;r<�!test_memoryview_cast_zero_strides
sz4TestBufferProtocol.test_memoryview_cast_zero_stridescCs�tD]�}td�rd|n|}t�|�}tD]^}td�r>d|n|}t�|�}tttd��d|g|d�}t|�}|�t	|j
|d|g�q*qtd�D]�\}}	}
t|	dg|d�}t|�}td�D]T\}}
}
t|�s�|�t
|j
|d|g�q�t|�s�t|�s�|�t	|j
|d|g�q�q�t�d�}t�d�}tttd|��dd|gdd�}t|�}|jt	|j
dd|gdd�tttd	��ddd
ddgd�}t|�}
|�t	|
j
�|�t	|
j
ddd
�|�t	|
j
i�|�t
|
j
d
�|�t
|
j
d�|�t
|
j
d�|�t
|
j
d�|�t
|
j
d�|�t
|
j
d�|�t
|
j
d�|�t
|
j
d�|�t
|
j
d�tddgdgdd�}t|�}
|�t|
jd�|�t|
jdd�|�t|
j�tttd	��ddd
ddgd�}t|�}
|jt	|
j
did�tttd	��d	gd�}t|�}
|jt|
j
ddgd�|jt
|
j
ddgd�|jt
|
j
ddd
dddddgd�|jt
|
j
ddd
dddddgd�|jt	|
j
ddd
ddddd gd�ttd!d"�td#�D��d
ddd$gd�}t|�}
|jt	|
j
d%dd
ddgd�tttd&��d&gd%d�}t|�}
|�t
|
j
d%dgd&�ttd'd"�td#�D��d#gd�}t|�}
|jt	|
j
d%dd
ddgd�ttd(d"�td#�D��d#gd�}t|�}
|jt	|
j
ddd
ddgd�tttd&��d&gd%d�}t|�}tttd&��d&gdd�}t|�}tjd)k�r:|�t	|j
dddd*d+d,d-d.g�|�t
|j
dd/d/d0d0dg�|�t
|j
d%d/d/d0d0dg�nN|�t	|j
ddd1g�|�t
|j
dd0d0dddg�|�t
|j
d%d0d0dddg�dS)2Nrr?r/rr*rrr��xrr�r��Xz@Xz@XYz=Bz!Lz<Pz>lZBIZxBIr�rsZIIrr3rr)r�r�r4rXcSsg|]}d�qSr�r;r�r;r;r<r}Z
szCTestBufferProtocol.test_memoryview_cast_invalid.<locals>.<listcomp>i�r[rr"cSsg|]}d�qSr�r;r�r;r;r<r}d
scSsg|]}d�qSr�r;r�r;r;r<r}i
sl�����Ir,iQiAji��	i���)�NON_BYTE_FORMATrr5rhrr�rbrMrVr
rrwrzr�rxrr�r�r	r�r�maxsize)rZsfmtZsformatZssizeZdfmtZdformatZdsizer-r�ZsitemsrmZsize_hZsize_drDrrmrnr;r;r<�test_memoryview_cast_invalid
s�

��

 """&  ������z/TestBufferProtocol.test_memoryview_cast_invalidcslddd�fddd�fddd�ff���fdd	�}t�d
�}tdgd
d�}t|dd
�\}}t|�}|�d�}�j||d
ddd
|d|dd�
t�d
�}tdg||gdd�}t|d
|gd�\}}t|�}|jd
gd�}�j|||d
dddd|dd�
tdd�D],\}	}
}t�|	|
�}t|�}||||
|	�q�tdd�D]4\}	}
}t|
dg|	t	d�}t|�}||||
|	��q2dS)NrcSst|���Srs�r�r�rDr;r;r<r��
r�z9TestBufferProtocol.test_memoryview_cast.<locals>.<lambda>rcSsdd�t|���D�S)NcSs g|]}|dkr|dn|�qS)r,r!r;rXr;r;r<r}�
s�MTestBufferProtocol.test_memoryview_cast.<locals>.<lambda>.<locals>.<listcomp>r�rDr;r;r<r��
r�r
cSsdd�t|���D�S)NcSsg|]}tt|�d��qS)zlatin-1)rR�chrrXr;r;r<r}�
sr�r�rDr;r;r<r��
r�c

s�t�|�}�D]~\}}|�|�}||�}�j||d|ddd|gd|dd�
|�|�}	��|	|�|��}�j|	|||dddg|f|dd�
qdS)Nr*Fr0r�T�	rWr�r8r*r�r�r�rcr)r5rhrrBr)r	)
r-rDror8�srcsizerNZto_bytelistrnrc�m3�Zbytespecrr;r<�iter_roundtrip�
s6

�
�z?TestBufferProtocol.test_memoryview_cast.<locals>.iter_roundtriprrZrr*Tr�r�r�rr;r0rKrMr)
r5rhrr�rMrrBrwrKr�)rrrr-Z	destitemsZ	destshaperDrnZdestsizer8rormr;rr<�test_memoryview_cast�
sV


�

�
�z'TestBufferProtocol.test_memoryview_castcCs�t�D�]�}tdD�]�}|dkr$qdtd�|}t�|�}t|�|}t|�rVdnd}t||�D�]:\}}}	t�|�}
|dkr�|gng}||
g}t|||d�}
t	|
�}t
|
|||d	�\}}|dkr�|�t|j
||�qd|d
kr�qdt|||d�}|j
||d	�}t|�}|j}|��}|j||
||d||||dd�
|�
|�}|j
||d	�}t|�}|
j}|
��}|j||
|
|d||||dd�
|j||
|
|d||||dd�
qdqqt�r�Gd
d�dtj�}|dd�}t	|�}|�
d�}|�|j|�|�|jd�|�|jd�|�|jd�|�|j|jf�|�|jd�|�|jd�t�d�}t	|�}|�
d�}|�|j|�|�|jd�|�|jd�|�|jd�|�|j|jf�|�|jd�|�|jd�dS)Nr?r)r>r?rrMrNrrr�r�Tr�c@s eZdZdejfdejfgZdS)z>TestBufferProtocol.test_memoryview_cast_1D_ND.<locals>.BEPointrXrAN)r�r�r��ctypes�c_long�c_double�_fields_r;r;r;r<�BEPoint�
sr	r�g33333i@rr*Fr�r;�333333�?r
)r�rQrr5rhr�rxrwrrMr�rVr
rr]r�r	rBr�BigEndianStructurer)rWr�r(r*r�r�r�r
r)rZ_tshaperVZtfmtZtsizerrWr8rorm�sizer�Ztshaper-rDZtitemsrrnr�r�rcrZm4r	�pointrmrXr;r;r<�test_memoryview_cast_1D_ND�
s�


�
��



z-TestBufferProtocol.test_memoryview_cast_1D_NDcCs@t�dttdd���}t|�}|�||�|�|��|���|ddd�}|ddd�}|�||�|�|��|���tttd��ddddd	gd
d�}t|�}|�|��|���tdd
gdgdd�}t|�}|�t|j�tdgdgdd�}t|�}|�t|j�tddddddgddgdd�}t|�}|�t|j�dS)Nrr�r�rri	r[r4r�rr)rr�)r4r[r9�12345r*r�r��b�c�d�e�f)	rKr�rbrMr)r	rrVr)rrFrDr-r;r;r<�test_memoryview_tolists( z)TestBufferProtocol.test_memoryview_tolistcCsHttd��}|��}|�|�d��|��|��}|�|�d��dS)NrZz<memoryz	<released)rMr��__repr__r:�
startswithr�)rrDr�r;r;r<�test_memoryview_repr/sz'TestBufferProtocol.test_memoryview_reprcCs|dD]J}td�}t�|d|dg�}t|�}|�d|�|�d|�|�d|�qtdgdd�}t|�}|�ttdt��dS)	N)rrg���?g@g"@rrCz9.0 in m)	�floatrKrMZassertInrrVr
r�r�)rr8�infr-rDr;r;r<�test_memoryview_sequence8sz+TestBufferProtocol.test_memoryview_sequencec	cs8|�t��}dVW5QRX|�t|j�d|f�dS)Nz#index out of bounds on dimension %d)rVr�r)�str�	exception)r�dim�cmr;r;r<�assert_out_of_bounds_errorFs
�z-TestBufferProtocol.assert_out_of_bounds_errorc
Cs"tdgdd�}t|�}|�|dd�|�|d|�|�|d|�|�t|jd�tdgdd�}t|�}|�t|jd�tttd	��d	gt	d
�}t|�}|�t
|jd�|�t|jd�|�t|jd
�|�t
|jd�|�t
|jd�tttd��ddgt	d
�}t|�}|�|dd�|�|dd�|�|dd�|�|dd�|�|dd�dD]*}|jdd��||dfW5QRX�qbdD]*}|jdd��|d|fW5QRX�q�|�t
|jd�|�t
|jd�|�t|jd �|�t|jd!�|�t|jd�|�t|jd�dS)"N�)@rrr;.rrxZiiir4r^r)�@����r3rYrr��rr)rrrvr[�r�r�)ryr]�rr]r*�r�r�r�r�r)rr(�rrr�r$r$)rrMr)rVr
r�rr�rbr�r�r!)rr-rD�indexr;r;r<�test_memoryview_indexMsFz(TestBufferProtocol.test_memoryview_indexc
Cs�tdgdtd�}t|�}d|d<|�|dd�d|d<|�|dd�|�t|jdd	�tttd
��d
gd�}t|�}|�t|jdd
�tttd
��d
gtd�}t|�}|�t	|jdd�|�t|jdd
�|�t|jdd�|�t	|jdd�|�t	|jdd�t
dD]t}|dk�s|dk�r(�qtdddgdg|td�}t|�}tdd�}d||<|�||d�|�||||��qtddd gdgdtd�}t|�}d!|d<|�|dd!�td"d#d"gdgdtd�}t|�}d"|d<|�|dd"�td$gdgdtd�}t|�}|�t|jdd%�tttd&��dddd'd(gtd�}t|�}t
d�
�D]�\}}|dk�rj�qT|dk�rx�qT|�|�}|\}	}
|d)k�s�|dk�r�dd*dd*}	}
|d+k�r�|�t|jd|	d�|�t|jdd,�|�t|jd|
��qT|�d�}|�t|jdd-�tttd��dgd.td�}t|�}|�t|jdd�td/gdgd0td�}t|�}|�t|jdd�tttd1��dd'gtd�}t|�}d2|d3<|�|ddd2�d4|d5<|�|ddd4�d6D]*}|jdd7��d||df<W5QRX�q�d8D]*}|jdd7��d|d|f<W5QRX�q|�t	|jd9d�|�t	|jd:d�|�t|jd;d�|�t|jd<d�|�t|jdddg�dS)=Nr"rrg�6@r;g�7@.rg33333�8@r4r�rrfr^r)rZr#r$r[r%r�r3�r?r
rr*rry�1�2�3r�TF�xr�r�r�r�rr�rr{s��ZxLrr�rY�*)rr*�+r'r(r)r*r+r(r,r-)rr�rMr)rVr
r�r�rbr�rQrr(rorr�rr!)rr-rDr8rrrmZ_rangern�lo�hir.r;r;r<�test_memoryview_assign�s�
�� 




z)TestBufferProtocol.test_memoryview_assignc	Cs�tttd��dgtd�}t|�}|�t|jtddd��|�t|j	tddd�t
ddg��|�t|jd�tttd��dgtd�}t|�}|�t|jtddd�tddd�f�|�t|j	tddd�tddd�ft
ddg��|�t|jtddd�if�|�t|j	tddd�ift
ddg��|�t|j	tddd�dg�dt
fD�]l}tttd��dgdgdt|Bd	�}tttd
��dgdg|d�}t|�}t|�}|dd�|dd�<|dd�|dd�<|�||�|�||�|dd�ddd�|dd
�ddd�<|dd�ddd�|dd
�ddd�<|�||�|�||�|ddd�ddd�|ddd�ddd�<|ddd�ddd�|ddd�ddd�<|�||�|�||��qBdS)NrYr^rrr*r;r�r[)r�r�r�r��rur�rr�r\)rr�rbr�rMrVr�r�r�r�r�rr
rgr))rr-rDr�rkrlrmrnr;r;r<�test_memoryview_slice�sP
�
�

�
��((,,z(TestBufferProtocol.test_memoryview_slicecCs�dd�}tdd�D�]�}t|d�D�]�\}}}t|�D�]�}t|�D�]�}t�||�}t�||�}	t|	�}
|�|
|�|�|
��|���|�|
��|���|�t|
�t|��||||	|
|�d}d}z0||}
||}||||<t|
�t|�k}Wn*t	k
�r$}z
|j
}W5d}~XYnXd}z|
||
|<Wn*t	k
�rd}z
|j
}W5d}~XYnX|�rz|�|t�qD|�s�|�r�|�||�qD|�|
|�|�|
��|���|�|
��|���||||	|
|�qDq6q"qdS)Nc	Ss�t|�D]�\}}||}||}|�||�|||<||krV|�||�|�||�n|�||�|�||�|||<|�||�|�||�|||<|||<qdSrs)r�r)�assertNotEqual)	ZtestcaserFrrD�
singleitemrrmZai�mir;r;r<�cmptest)sz9TestBufferProtocol.test_memoryview_array.<locals>.cmptestr*r�rK)
rbrwr�rKrMr)r	r�r]r�r�r(r�)rr?rr8ror=r�rrFrrDZ	array_errZhave_resizeZal�arr�Zm_errr;r;r<�test_memoryview_array'sFz(TestBufferProtocol.test_memoryview_arrayc	Cs�t�ddddg�}t�ddddg�}t|�}t|�}dD]0}|�t||�|�t�|�t||�|�t�q8t|�}|��|�||�|�||�|�||�t|�}t|�}|��|�||�|�||�t|�}|�|dddg�tdgdgdt	d	�}d
t
d�f|d<|�t|�|�t�d
d�}t|�}|�||�|�||�t�r�Gdd�dtj�}|dd�}t|�}t|�}|�||�|�||�|�||�|�
t|j�dS)Nrr*rrr4)�__lt__�__le__�__gt__�__ge__r&zl x d xrr�r�r�ur{c@s eZdZdejfdejfgZdS)zITestBufferProtocol.test_memoryview_compare_special_cases.<locals>.BEPointrXrAN�r�r�r�rrrr;r;r;r<r	�sr	r�r�)rKrMr(�getattrr�r�r)r<rr�rrrrVrr	)	rrFrr��w�attrrr	r
r;r;r<�%test_memoryview_compare_special_casesesF
z8TestBufferProtocol.test_memoryview_compare_special_casescCsntdgdd�}tdgdtd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�|�||�|�|�|��|�|�|��d|d<|�||�|�||�|�||�|�||�|�||�|�||�|�|�|��|�|�|��ttt	d��dgtt
Bd	�}ttt	d��dgtt
Bd	�}t|�}|�||�d
|d<|�||�tdgd
d�}tdgdtd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�|�||�tdgd
d�}tdgdtd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�|�||�|�||�|�||�dS)N��@Lrrri�r;rYr^r�rZ)rLr
rZLf5sZhf5s)i?���r
r)rr�rMr)r��__ne__r<r�r�rbrg)r�nd1�nd2r�rIrr-rDr;r;r<�!test_memoryview_compare_ndim_zero�sj��z4TestBufferProtocol.test_memoryview_compare_ndim_zerocCs�tdddddgdgdd�}tddddd	gdgdd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tdddddgdgd
d�}tddddd	gdgdd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tdddgdgdd�}tdddddgdgdd�}t|�}t|�}|�||ddd
��|�|ddd
�|�|�||ddd
��|�|ddd�|ddd��tdddgdgdd�}tdddddgdgdd�}t|�}t|�}|�||ddd
��|�|ddd
�|�|�||ddd
��|�|ddd�|ddd��tdddgdgdd�}tdddddgdgdtd�}t|�}t|�}|�||ddd
��|�|ddd
�|�|�||ddd
��|�|ddd�|ddd��tdddgdgdd�}tdddddgdgdtd�}t|�}t|�}|�||ddd
��|�|ddd
�|�|�||ddd
��|�|ddd�|ddd��dS)N����@�����'���r��@hri�z<iz>hrrr�r\z!hz<lrzh  0cz>  h)rrMr)r<rg�rrOrPr�rIr;r;r<� test_memoryview_compare_ndim_one�sl  � �z3TestBufferProtocol.test_memoryview_compare_ndim_onecCs�tddgdgdd�}tddgdgdd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tddgdgdd�}tddgdgd	d�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�dS)
N�r|rrWri|���i?���z= h0cz@   i�rrMr)rXr;r;r<�"test_memoryview_compare_zero_shape!
s$z5TestBufferProtocol.test_memoryview_compare_zero_shapecCs�tddddgdgdd�}tdgdgdgdd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tdgddgd	d�}tdgdgdgd
d�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�dS)NrZr�rMrrrrw)rZrZz@ Liz!L  hr[rXr;r;r<�$test_memoryview_compare_zero_strides;
s$z7TestBufferProtocol.test_memoryview_compare_zero_stridesc
Cs�d}tdD]n}t|dd|�\}}}dtfD]L}t||g||d�}t|�}|�||�|ddd�}t|�}|�||�q,qd}td�D]h}	t|�\}}}dtfD]L}t||g||d�}t|�}|�||�|ddd�}t|�}|�||�q�q�dS)	NrfrErMr?rrryr�)rQrrrgrrMr)rb)
rrrVr8ror=r�rrDrmr;r;r<�&test_memoryview_compare_random_formatsU
s(z9TestBufferProtocol.test_memoryview_compare_random_formatscCs�tttdd��dddgdd�}tttdd	��dddgdd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�td
gd	dddgdd�}tdgd	dddgd
d�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tttd	��dddgdd�}tttd	��dddgdd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�td
gdddgdd�}td
gdddgdd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tttd	��dddgdd�}tttd	��dddgdd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�dS)N��r2rrr�rWrrr�)rr*rz=f q xxL)g333333�r*rz< f 2Qr�r4z! b B xLz
= Qx l xxLr�rr�rbrMr)r<rXr;r;r<�"test_memoryview_compare_multidim_cq
sZz5TestBufferProtocol.test_memoryview_compare_multidim_ccCs�tttdd��dddgdtd�}tttdd	��dddgdtd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�td
gdddgdtd�}td
gdddgdtd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tttdd��dddgdtd�}tttdd��dddgdtd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tttdd��dddgdtd�}tttdd��dddgdtd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tttd	��dddgdtd�}tttd	��dddgdtd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�dS)Nr_r2r�rrrWrrr��rr�r��=Qq)r�rz=qQrZ0llrG)rr�rbr7rMr)r<rXr;r;r<�(test_memoryview_compare_multidim_fortran�
s�����������z;TestBufferProtocol.test_memoryview_compare_multidim_fortranc	Cshttdd��}t|dddg�}t|dddgdd�}t|dddgdtd	�}t|�}t|�}|�||�|�||�|�||�d
gd}d|d<t|dddg�}t|dddgd
d�}t|dddgdtd	�}t|�}t|�}|�||�|�||�|�||�tttd��ddgdd�}|ddd�ddd�f}tttd��ddgdd�}|ddd�ddd�f}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tdgdddgdd�}|ddd�ddd�f}tdgdddgdd�}|ddd�ddd�f}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tttd��dddgdd�}|dd�ddd�f}tttd��dddgdd�}|dd�ddd�f}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tttd��dddgdd�}|dd�ddd�f}tttd��dddgdd�}|dd�ddd�f}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tdgddddgdd�}|dd�ddd�f}tdgddddgdd�}|dd�ddd�f}t|�}t|�}|�||�|�||�|�||�|�||�|�||�dS) Nr_r2rrr��@lrrr)gffffff
����r4r�)g�������rgr4zd b czd h c�(r3�@Ir*r�r\r)r�r$�r[z=iiz>iirr)rrzZb3sZi3s)r�rbr�rr7rMr)r<)	r�lst1�lst2rOrPr�rIrkrlr;r;r<�&test_memoryview_compare_multidim_mixed�
s�
z9TestBufferProtocol.test_memoryview_compare_multidim_mixedcCstttd��dddgdd�}tttd��dddgdd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tttd��dddgdd�}tttd��dddgdd�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�dS)	Nr�rrrrrr�z@irarXr;r;r<�+test_memoryview_compare_multidim_zero_shapeXs$z>TestBufferProtocol.test_memoryview_compare_multidim_zero_shapecCstdgddddgdd�}tdgdddgdddgdd	�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�|�|��|���td
gdddgd
d�}td
gddgddgdd	�}t|�}t|�}|�||�|�||�|�||�|�||�|�||�dS)NrZr�r�r�rMrrrrwr�rfrz=lQz<lQ)rrMr)r	rXr;r;r<�-test_memoryview_compare_multidim_zero_stridesrs&z@TestBufferProtocol.test_memoryview_compare_multidim_zero_stridesc	Csztttd��ddgdd�}|ddd�ddd	�f}tttd��ddgd
td�}|ddd�ddd	�f}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tdgdddgd
td�}d|dd<|ddd�ddd	�f}tdgdddgdttBd�}d|dd<|ddd�ddd	�f}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tttd��dddgdtd�}|dd�ddd	�f}tttd��dddgdd�}|dd�ddd	�f}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tdgddddgdttBd�}|dd�ddd	�f}tdgddddgdd�}|dd�ddd	�f}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tttd��dddgdtd�}|dd�ddd	�f}tttd��dddgdtd�}|dd�ddd	�f}t|�}t|�}|�||�|�||�|�||�|�||�|�||�tdgddddgdttBd�}d|ddd<|dd�ddd	�f}tdgddddgdttBd�}d|ddd<|dd�ddd	�f}t|�}t|�}|�||�|�||�|�||�|�||�|�||�ttdd��}t|dddg�}t|dddgdtd�}t|dddgdt	tBd�}t|�}t|�}|�||�|�||�|�||�dgd}d |d!<t|dddg�}t|dddgd"td�}t|dddgd#t	tBd�}t|�}t|�}|�||�|�||�|�||�dS)$Nrhr�r3rirrr*r�r\rrrcrd)r*r\rr4z>Qqr�r)r~r�ZBbr)shellor�r*�Z5s0sP)ssushir�r*r_r2rfr)ssashimisslicedg�����4@)sramensspicygfffff�"@r[z
< 10p 9p dz
> 10p 9p d)
rr�rbrgrMr)r<r�r�r7)	rrkrOrlrPr�rIrkrlr;r;r<�+test_memoryview_compare_multidim_suboffsets�s�������
�z>TestBufferProtocol.test_memoryview_compare_multidim_suboffsetscCsldD�]`}tdgddddddg|dd�}tdgddddddg|dttBd	�}d
|ddd
d
d
<t|�}t|�}|�||�|�||�|�||�|�||�|�||�tdgddddddg|dd�}tdgddddddg|dttBd	�}d
|ddd
d
d
<t|�}t|�}|�||�|�||�|�||�|�||�|�||�qdS)N)rBr@rArCr'r�rr�rrrrr*)r'r%r#ZQLH)r*r*r*)rr�r7rMr)r<)r�	byteorderrXrArFrr;r;r<�!test_memoryview_compare_not_equals8
"���z4TestBufferProtocol.test_memoryview_compare_not_equalcCst�ddddg�}t|�}|��|�tt|�|�t|jd�|�tt|�|�t|j�|�t|j�|�tt	dt
��|�t|jd�|�t|jdd�d	D]}|�t|j
|�q�t�ddddg�}t|�}t|�}|�||�|��|�||�|�||�|�||�dS)
Nrg�������?g������@gffffff
@r
z1.0 in mrr*)rWr�r*r�r�r�r�r�r
rMrOrQ)rKrMr�rVr�rrr	r�r�r�r�r��__getattribute__r)r<)rrFrDrJrrmrnr;r;r<�test_memoryview_check_released+s*z1TestBufferProtocol.test_memoryview_check_releasedcsXd�t�dgdd�}t|�}|�||�|�|��|���t�gdgdd�}t|�}|�||�|�|��|���t�fdd�td	�D�d
d
dgdd�}t|�}|�||�|�|��|���t�fd
d�td�D�dd
d
dd
gdd�}t|�}|�||�|�|��|���t�rTGdd�dtj�}|dd�}t|�}|�|��t|��dS)N)rRrSrTrUrVr�rWrr*z>hQiLlcsg|]}��qSr;r;r��rvr;r<r}bsz>TestBufferProtocol.test_memoryview_tobytes.<locals>.<listcomp>rYrrz=hQiLlcsg|]}��qSr;r;r�rvr;r<r}gsr�z<hQiLlc@s eZdZdejfdejfgZdS)z;TestBufferProtocol.test_memoryview_tobytes.<locals>.BEPointrXrANrGr;r;r;r<r	psr	r�r�)rrMr)r�rbrrrR)rrrDr	r
rFr;rvr<�test_memoryview_tobytesSs0&"�
z*TestBufferProtocol.test_memoryview_tobytescCs|�ttitd�|�ttdtd�tdddgdgdgd�}|�tt|td�td	d
dd�}d
D],}t|t|�}|�||�|�|d
d	�q`td	d
dtd�}d
D],}t|t|�}|�||�|�|d
d	�q�d
D]\}d	|d
<t|t|�}|�||�|�|d
d	�d|d
<|�|d
d�|�|d
d�q�tdgdgdtd�}d
D]>}t|t|�}|�t	|j
d�|�||�|�|��g��qJttt
d��dddgdtd�}d
D]*}t|t|�}|�t|���ggg��q�tdgdgdtd�}d
D]2}t|t|�}|�||�|�|��|����q�tdddgdgdtd�}d
D]2}t|t|�}|�||�|�|��|����q@tdddgdgdgtd�}d
D]d}t|t|�}|�||�|�|��|���|�t|jdd�|�|dd�|�|dd��q�|ddd�}d
D]d}t|t|�}|�||�|�|��|���|�t|jdd�|�|dd�|�|dd��q
ttt
d��ddgtd�}dD]*}t|t|�}|�t|���|����q�|�tt|td�t|t|�}|�t|���|���ttt
d��ddgttBd�}dD]*}t|t|�}|�t|���|����q|�tt|td�t|t|�}|�t|���|���ttt
d��ddgttBd�}d
D]<}|�tt|t|�t|t|�}|�t|���|����q�tdddddgdgdgd�}t|td�}|�|j�dS)Nrr4r�r*rrr�rrZr;rrrrrfrr3r4rrrur�r�rYr�r^)r�r)rrr�)rVr
r8r9r3ZPyBUF_WRITErr)r�r�r�r	r�rbr�r7rgr:rM)rrr'rDr;r;r<�test_memoryview_get_contiguousvs����z1TestBufferProtocol.test_memoryview_get_contiguouscCs�t�d�}t�ddddddg�}t|�}t�|�}td|�}|�|�|�|�	�|�t�d�}t
ttd��dddgdd	�}t|�}t�|�}td|�}|�|�|�|�	�|�dS)
Nrr*rrr�r�rrYr)
r5rhrKrM�io�BytesIOr��readintor)r�rr�rb)rrrFrDr�rrr;r;r<�test_memoryview_serializing�s





z.TestBufferProtocol.test_memoryview_serializingc	Cs�tttd���}t|�}|�t|�t|��|jdddgd�}|�t|�t|��|ddd�}tttd��ddd��}|�t|�t|��tttd��ddd	gtd
�}t|�}|�t|�t|��tttd��ddd	gd�}|ddd�dd�ddd�f}t|�}|�t|�t|��tttd��dd	dgt	d
�}|ddd�dd�ddd�f}t|�}|�t|�t|��tttd��dgdd
�}t|�}tttd��dgdd
�}t|�}|�||�|�t|�t|��tttd��dddgdd
�}t|�}|�
t|j�tttdd��dddgdd
�}t|�}|�
t|j�tttd��dddgdd
�}t|�}|�
t|j�tttdd��dddgdd
�}t|�}|�
t|j�dS)NrYr
rr�r�r\r�rr�r^r�rrrrr�r�rz= Lz< h)
rRr�rbrMr)r�rrr7rgrVr��__hash__)	rrrDZmcZmxrrXrFrAr;r;r<�test_memoryview_hash	sJz'TestBufferProtocol.test_memoryview_hashcCs�tdddg�}t|�}t|�}|�t|j�~|��tdddg�}t|�}t|ttd�}t|ttd�}|�|j	|�|�t|j�~~|��tdddg�}t|�}t|�}t|�}|��|�t|j�~|��tdddg�}t|�}t|�}t|ttd�}t|ttd�}|�|j	|�|��|�t|j�~~|��tdddgdgt
d�}t|�}|jdddd	d
gdgd�t|�}t|�}|�|�
�|�
��t|�}	|�|	�
�|�
��|�|	�
�|�
��|��|	��|��|�|�
�|�
��~|��|��dd
�}
td�}t|��"}|
|�|�|dtd��W5QRXtttd��dddgdd�}t|ttd�}	t|	ttd�}|�|j	|�t|��8}|
|�|�|dd��
�dddgdddggg�W5QRXdtfD�]�}td�}t|���}~t|t|d�}	t|	���}~	t|t|d�}t|��^}
~|
|
�|
|�|
|�|�|dtd��|�|dtd��|�|
dtd��~
W5QRX~W5QRX~W5QRXtd�}t|���}~t|t|d�}	t|	���}~	t|t|d�}t|��b}
~|
|�|
|�|
|
�|�|dtd��|�|dtd��|�|
dtd��~~~
W5QRXW5QRXW5QRX�q�td�}|�t��2t|��}t|�}|dtd�kW5QRXW5QRXdS)Nr*rr�rJr�r^r�r�r�r4r3r�c	Sst|��}W5QRXdSrs)rM)rrnr;r;r<�catch22�s
z;TestBufferProtocol.test_memoryview_release.<locals>.catch22rzrr1rYrrr2r3)r�rMrrVr3r�r=�ND_REDIRECTr(rWr�r�r)r	r��ordr�rb)rrFrDrrOrPrmrnrXrAr�r�r�rr-r;r;r<�test_memoryview_releaseEs�

4





(
z*TestBufferProtocol.test_memoryview_releasecCs0tdd�td�D�dgdd�}t�ddd�td�D��}||fD]�}t|ttd�}t|ttd�}t|�}|�|j|�|�|j|�|�|j|�|�||�|�||�|�||�|�|dd	�|dd	��|�|dd	�|dd	��|�|dd	�|dd	��~~|�|dd	�|dd	��q@dS)
NcSsg|]}d|�qS�rr;rXr;r;r<r}�sz?TestBufferProtocol.test_memoryview_redirect.<locals>.<listcomp>rYrrcSsg|]}d|�qSr�r;rXr;r;r<r}�srr*r)	rrbrKr=r�rMr(rWr))rrrFrXrAr�rDr;r;r<�test_memoryview_redirect�s"z+TestBufferProtocol.test_memoryview_redirectcCs�d}dddddddd	d
ddd
g}|�ttddd�t�}t|�}|j||d|dddgdg|d�	td�D]}|�|||�qh~~t�}t|�}~~t�}t|td�}t|td�}t|�}|�	|j
|�|�	|j
|�|j||d|dddgdg|d�	~~~~t�}t|ttd�}t|ttd�}t|�}|�	|j
|�|�	|j
|�|�	|j
|�|j||d|dddgdg|d�	~~~~tdd�}t|�}|j|dd|dddgdg|d�	td�D]}|�|||��q�~~tdd�}t|�}~~tdd�}t|td�}t|td�}t|�}|�	|j
d�|�	|j
|�|j||d|dddgdg|d�	~~~~tdd�}t|ttd�}t|ttd�}t|�}|�	|j
d�|�	|j
|�|�	|j
|�|j||d|dddgdg|d�	~~~~dS)Nrrr*rrr�r�r�r4r3rZrfr[TrYr�rIr)Zlegacy_mode)rVr
ZstaticarrayrMrBrbr)rr=r(rWr�)rr8rcrXrArr�rDr;r;r<�$test_memoryview_from_static_exporter�s����
�

�
�z7TestBufferProtocol.test_memoryview_from_static_exportercCs,tdddgdgttBd�}|�tt|�dS)Nr*rrrr)rriZND_GETBUF_UNDEFINEDrVr3rMr�r;r;r<�#test_memoryview_getbuffer_undefined;sz6TestBufferProtocol.test_memoryview_getbuffer_undefinedcCs(tdddgdgtd�}|�tt|�dS)Nr*rrr^)rrirVr3rM)rrXr;r;r<�test_issue_7385Asz"TestBufferProtocol.test_issue_7385N)F)Sr�r�r�rrBrWrqr�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�rr�r�r�r�r�rrrrr�
contextlib�contextmanagerr!r/r9r;rArKrQrYr\r]r^rbrermrnrorqrsrurwrxr|r~r�r�r�r�r�r;r;r;r<r�s��K
2i
-'	0.Y #6!)>
		%qu
8	s<T	
5m8>5?H>Ha(#u<^r�__main__)rNN)r)r)r�r1r;)r�r1)r)N)F)F)r�)N)fr�Zunittest�testr�	itertoolsrr�randomrrr�warningsrrKry�osZdecimalrZ	fractionsr	Z_testbuffer�ImportErrorrr5rZEnvironmentVarGuard�environ�catch_warningsrLr�Z
SHORT_TESTZNATIVEr6r7ZSTANDARDr=rQr8�copyryZARRAYr�ZBYTEFMTrhrjrgrYr`rdrqrrrtrwrxrzr�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�rrr�rrrr�r�r�Z
skipUnlessZTestCaserr��mainr;r;r;r<�<module>s� 


�$
	��
�	





�	



	


?

+

!





j


F1le Man4ger