U
    ,d                     @   s<  d dl Z d dlZd dlZd dlZd dlZd dlZd dlZd dlmZ d dl	Z	d dl
Zd dlmZmZmZmZmZ d dlmZmZmZmZmZ d dlmZ d dlmZ d dlmZ d dlmZ d d	l m!Z!m"Z"m#Z#m$Z$m%Z%m&Z& d d
l'm(Z( d dl)Z)d dl*m+Z+m,Z,m-Z-m.Z.m/Z/m0Z0m1Z1m2Z2m3Z3m4Z4m5Z5m6Z6m7Z7m8Z8m9Z9m:Z:m;Z;m<Z< d dl=m>Z>m?Z?m@Z@mAZAmBZB ddlCmDZDmEZE z4d dlFZFeeFjGdk rdZHnd dlImJ  mKZH W n eLk
r   dZHY nX G dd deMZNG dd dejOZPePdZQeN ZRe+SeNdd ZTe.ePejUdd ZVdd ZWe3ePe2jX e5ePdd ZYdd ZZeZd\Z[Z\Z]e5e[d d! Z^dd"d#Z_d$d% Z`e,e_e`Zae-e_e-e_ejbd&d' Zce-e_ejdd(d) Zee@G d*d+ d+e>Zfe-d,ePd-d. Zgd/d0 Zhd1d2 Zid3d4 Zje/ehd5d6 Zke/ehd7d8 Zle/emd9d: Zne/ejod;d< Zpe/ejqd=d> Zre/ejsd?d@ Zte/ejudAdB ZvdCdD ZwdEdF Zxe/ejydGdH ZzdIdJ Z{dKdL Z|dMdN Z}dOdP Z~dQdR Ze1ePdSdTdU ZdVdW ZdXdY ZdZd[ Zd\d] Zd^d_ Zd`da Zdbdc Zddde Zdfdg Zdhdi Zdjdk Zdldm Zdndo Ze/edpdq Zdrds Zdtdu Zdvdw ZeAeG dxdy dyeBZdzd{ ZG d|d} d}eMZG d~d dejZe3eG dd de2jXZeAeee eedd Ze/ejdd ZG dd de!ZG dd de!ZG dd de!Zdd Ze&G dd de!Zdd ZG dd de!ZG dd de)j!ZG dd de)j!Ze1ePdddiddd Ze1ePdddiddd Ze0ePdddiddd Ze0ePdddiddd ZG dd de!ZG dd de!Zdd Ze&G dd de!ZG dd de!ZG dd de!Zedkr8e)  dS )    N)LooseVersion)njitjit	vectorizeguvectorizeobjmode)typeserrorstypingcompilercgutils)type_inference_stage)
cpu_target)compile_isolated)lower_constant)TestCasecaptured_stdouttemp_directoryoverride_configrun_in_new_process_in_cache_dirskip_if_typeguard)LoweringError)typeof_impltype_callablelower_builtin
lower_castoverloadoverload_attributeoverload_methodmodelsregister_modelboxunboxNativeValue	intrinsic
_Intrinsicregister_jitableget_cython_function_address	is_jittedoverload_classmethod)ConcreteTemplate	signatureinferinfer_globalAbstractTemplate   )IndexSeriesz0.19c                   @   s   e Zd ZdS )MyDummyN__name__
__module____qualname__ r7   r7   >/tmp/pip-unpacked-wheel-eu7e0c37/numba/tests/test_extending.pyr2   N   s   r2   c                   @   s   e Zd Zdd ZdS )MyDummyTypec                 C   s"   t |tjrddlm} |jS d S )Nr   )
Conversion)
isinstancer   NumberZnumba.core.typeconvr:   safe)selfcontexttotyr:   r7   r7   r8   can_convert_toS   s    zMyDummyType.can_convert_toN)r4   r5   r6   rA   r7   r7   r7   r8   r9   R   s   r9   mydummyc                 C   s   t S N)mydummy_typevalcr7   r7   r8   typeof_mydummy^   s    rH   c                 C   s   |  |dS )z2
    Implicit conversion from MyDummy to int.
    *   )get_constant)r?   builderZfromtyr@   rF   r7   r7   r8   mydummy_to_numberc   s    rL   c                   C   s   t S rC   )rB   r7   r7   r7   r8   	get_dummyk   s    rM   c                 C   s   t |j S rC   r#   r?   get_dummy_valuetypobjrG   r7   r7   r8   unbox_indexr   s    rS   c                    sX   G dd dt }G dd dtj}||  t| fdd}t|tj || fS )Nc                   @   s   e Zd ZdS )z(base_dummy_type_factory.<locals>.DynTypeNr3   r7   r7   r7   r8   DynType|   s   rT   c                   @   s   e Zd ZdS )z,base_dummy_type_factory.<locals>.DynTypeTypeNr3   r7   r7   r7   r8   DynTypeType   s   rU   c                    s    S rC   r7   rE   dyn_type_typer7   r8   rH      s    z/base_dummy_type_factory.<locals>.typeof_mydummy)objectr   Opaquer   registerr    r   OpaqueModel)namerT   rU   rH   r7   rV   r8   base_dummy_type_factory{   s    r]   mydummy2c                 C   s   t |j S rC   rN   rP   r7   r7   r8   unbox_index2   s    r_   c                 C   s   t d S rC   NotImplementedErrorxr7   r7   r8   func1   s    rd   c                 C   s   ddd}|S )Nc                 S   s(   | d t jfkrt jS t| t jr$| S d S rC   )r   noneint32r;   Floatrb   r7   r7   r8   typer   s    ztype_func1_.<locals>.typer)Nr7   )r?   rh   r7   r7   r8   type_func1_   s    
ri   c                 C   s   |  |jdS NrI   )rJ   return_type)r?   rK   sigargsr7   r7   r8   func1_nullary   s    rn   c                 C   s   dd }|  ||||S )Nc                 S   s   t d|  S )N   )mathsqrtrb   r7   r7   r8   
func1_impl   s    zfunc1_unary.<locals>.func1_impl)Zcompile_internal)r?   rK   rl   rm   rr   r7   r7   r8   func1_unary   s    rs   c                   @   s   e Zd ZdZeejegZdS )
PrintDummy
print_itemN)	r4   r5   r6   keyr+   r   re   rD   Zcasesr7   r7   r7   r8   rt      s   rt   ru   c                 C   s<   |\}|  |}||d}|| || |  S )Nzhello!)Zget_python_apiZunserializeZserialize_objectZprint_objectZdecrefrO   )r?   rK   rl   rm   rc   pyapiZstrobjr7   r7   r8   print_dummy   s    


rx   c                 C   s   t d S rC   r`   condrc   yr7   r7   r8   where   s    r|   c                 C   s   t | ||S )z8
    Wrap np.where() to allow for keyword arguments
    )npr|   ry   r7   r7   r8   np_where   s    r~   c                 C   s   t | ||dS )N)r{   rc   )r|   ry   r7   r7   r8   
call_where   s    r   c                 C   sT   t | tjrP|j|jkr"tdtdd | ||fD rDdd }ndd }|S dS )z'
    Implement where() for arrays.
    "x and y should have the same dtypec                 s   s   | ]}|j d kV  qdS )CN)Zlayout).0tyr7   r7   r8   	<genexpr>   s     z(overload_where_arrays.<locals>.<genexpr>c           
      S   st   | j }|j |ks|j |kr"tdt|}| j}|j}|j}|j}t| jD ] }	||	 rb||	 n||	 ||	< qN|S )zM
                Fast implementation for C-contiguous arrays
                %all inputs should have the same shape)shape
ValueErrorr}   
empty_likeZflatrangesize)
rz   rc   r{   r   rescfZxfZyfrfir7   r7   r8   
where_impl   s    
z)overload_where_arrays.<locals>.where_implc                 S   s\   | j }|j |ks|j |kr"tdt|}t| D ] \}}|rJ|| n|| ||< q6|S )zI
                Generic implementation for other arrays
                r   )r   r   r}   r   Zndenumerate)rz   rc   r{   r   r   idxrG   r7   r7   r8   r      s    
N)r;   r   Arraydtyper	   TypingErrorallrz   rc   r{   r   r7   r7   r8   overload_where_arrays   s    

r   c                 C   s.   t | tjs*||krtddd }|S dS )z(
    Implement where() for scalars.
    z!x and y should have the same typec                 S   s"   | r|n|}t |}||d< |S )z@
            Scalar where() => return a 0-dim array
            r7   )r}   r   )rz   rc   r{   Zscalarrr7   r7   r8   r     s    
z*overload_where_scalars.<locals>.where_implN)r;   r   r   r	   r   r   r7   r7   r8   overload_where_scalars  s
    

r   c                 C   s   t | trdd }|S d S )Nc                 S   s   dS )N   r7   argr7   r7   r8   len_impl1  s    z$overload_len_dummy.<locals>.len_implr;   r9   )r   r   r7   r7   r8   overload_len_dummy-  s    
r   c                 C   s,   t | ttfr(t |ttfr(dd }|S d S )Nc                 S   s   dS rj   r7   arg1arg2r7   r7   r8   dummy_add_impl=  s    z*overload_add_dummy.<locals>.dummy_add_implr;   r9   MyDummyType2)r   r   r   r7   r7   r8   overload_add_dummy7  s     r   c                 C   s&   t | tr"t |tjr"dd }|S d S )Nc                 S   s   t d| | d S )NdelprintrR   r   r7   r7   r8   dummy_delitem_implG  s    z2overload_dummy_delitem.<locals>.dummy_delitem_implr;   r9   r   Integer)rR   r   r   r7   r7   r8   overload_dummy_delitemC  s    r   c                 C   s&   t | tr"t |tjr"dd }|S d S )Nc                 S   s   |d S )N{   r7   r   r7   r7   r8   dummy_getitem_implQ  s    z2overload_dummy_getitem.<locals>.dummy_getitem_implr   )rR   r   r   r7   r7   r8   overload_dummy_getitemM  s    r   c                 C   s4   t t| tt|tjt|tjgr0dd }|S d S )Nc                 S   s   t || d S rC   r   rR   r   rF   r7   r7   r8   dummy_setitem_impla  s    z2overload_dummy_setitem.<locals>.dummy_setitem_impl)r   r;   r9   r   r   )rR   r   rF   r   r7   r7   r8   overload_dummy_setitemW  s    

r   c                 C   s   t | |S rC   operatoraddr   r7   r7   r8   call_add_operatorg  s    r   c                 C   s   | | S rC   r7   r   r7   r7   r8   call_add_binopk  s    r   c                 C   s,   t | ttfr(t |ttfr(dd }|S d S )Nc                 S   s   dS rj   r7   r   r7   r7   r8   dummy_iadd_implu  s    z,overload_iadd_dummy.<locals>.dummy_iadd_implr   )r   r   r   r7   r7   r8   overload_iadd_dummyo  s     r   c                 C   s   t | |S rC   r   r   r7   r7   r8   call_iadd_operator{  s    r   c                 C   s   | |7 } | S rC   r7   r   r7   r7   r8   call_iadd_binop  s    r   c                 C   s
   | |= d S rC   r7   r   r7   r7   r8   call_delitem  s    r   c                 C   s   | | S rC   r7   r   r7   r7   r8   call_getitem  s    r   c                 C   s   || |< d S rC   r7   r   r7   r7   r8   call_setitem  s    r   lengthc                 C   s   dd }|S )Nc                 S   s   t | S rC   lenr   r7   r7   r8   imp  s    z#overload_method_length.<locals>.impr7   )r   r   r7   r7   r8   overload_method_length  s    r   c                 C   s   |   S rC   )r   rb   r7   r7   r8   cache_overload_method_usecase  s    r   c                   C   s   t  S rC   rd   r7   r7   r7   r8   call_func1_nullary  s    r   c                 C   s   t | S rC   r   rb   r7   r7   r8   call_func1_unary  s    r   c                 C   s   t | S rC   r   rb   r7   r7   r8   len_usecase  s    r   c                 C   s   t |  d S rC   r   rb   r7   r7   r8   print_usecase  s    r   c                 C   s   | | S rC   r7   )rc   rv   r7   r7   r8   getitem_usecase  s    r   c                 C   s   t t | S rC   )r}   cossinrb   r7   r7   r8   npyufunc_usecase  s    r   c                 C   s   | j S rC   )_datarb   r7   r7   r8   get_data_usecase  s    r   c                 C   s   | j S rC   )_indexrb   r7   r7   r8   get_index_usecase  s    r   c                 C   s   | j S rC   )Zis_monotonic_increasingrb   r7   r7   r8   is_monotonic_usecase  s    r   c                 C   s
   t | |S rC   )r1   )dataindexr7   r7   r8   make_series_usecase  s    r   c                 C   s   |  ||S rC   )Zclip)rc   lohir7   r7   r8   clip_usecase  s    r   c                   C   s   t S rC   r}   r7   r7   r7   r8   return_non_boxable  s    r   c                  C   s   dd } | S )Nc                   S   s   t S rC   r   r7   r7   r7   r8   r     s    z(overload_return_non_boxable.<locals>.impr7   )r   r7   r7   r8   overload_return_non_boxable  s    r   c                 C   s   t  }|| S rC   )r   arange)szmodr7   r7   r8   non_boxable_ok_usecase  s    r   c                   C   s   t  S rC   )r   r7   r7   r7   r8   non_boxable_bad_usecase  s    r   c                 C   s   d S rC   r7   )fr7   r7   r8   mk_func_input  s    r   c                   @   s   e Zd Zdd ZdS )MkFuncTypingc                 C   s$   t |d tjstttjf| S Nr   )r;   r   MakeFunctionLiteralAssertionErrorr+   re   )r>   rm   kwsr7   r7   r8   generic  s    zMkFuncTyping.genericN)r4   r5   r6   r   r7   r7   r7   r8   r     s   r   c                   C   s   t dd  d S )Nc                 S   s   | S rC   r7   ar7   r7   r8   <lambda>      z#mk_func_test_impl.<locals>.<lambda>)r   r7   r7   r7   r8   mk_func_test_impl  s    r   c                   @   s   e Zd ZdS )MyClassNr3   r7   r7   r7   r8   r     s   r   c                       s4   e Zd Z fddZdd Zdd Zdd Z  ZS )	CallableTypeRefc                    s.   || _ i | _g | _tt| d| j  d S )Nzcallable_type_ref[{}])instance_typesig_to_impl_keycompiled_templatessuperr   __init__format)r>   r   	__class__r7   r8   r     s    zCallableTypeRef.__init__c              	   C   st   d }|j t|  D ]\}z|||}W n tk
r:   Y qX t|di }||kr|| | j|< | j|  qpq|S )NZ_compiled_overloads)Z
_functionstypeapply	Exceptiongetattrr   r   append)r>   r?   rm   r   Zres_sigtemplateZcompiled_ovldsr7   r7   r8   get_call_type  s    zCallableTypeRef.get_call_typec                 C   s   t | j }|dfS )NT)listr   keys)r>   Zsigsr7   r7   r8   get_call_signatures  s    z#CallableTypeRef.get_call_signaturesc                 C   s
   | j | S rC   )r   )r>   rl   r7   r7   r8   get_impl_key  s    zCallableTypeRef.get_impl_key)r4   r5   r6   r   r   r  r  __classcell__r7   r7   r   r8   r     s   r   c                   @   s   e Zd Zdd ZdS )CallableTypeModelc                 C   s   t j| || d S rC   )r   r[   r   )r>   ZdmmZfe_typer7   r7   r8   r     s    zCallableTypeModel.__init__N)r4   r5   r6   r   r7   r7   r7   r8   r    s   r  c                 C   s   |   S rC   )rO   )r?   rK   r   Zpyvalr7   r7   r8   constant_callable_typeref%  s    r  c                 C   s   t | trdd }|S d S )Nc                 S   s   dS )N   >[= r7   rR   r7   r7   r8   r   1  s    zoverload_np_exp.<locals>.impr   rR   r   r7   r7   r8   overload_np_exp-  s    
r
  c                   @   s8   e Zd ZdZdd Zdd Zdd Zdd	 Zd
d ZdS )TestLowLevelExtendingz4
    Test the low-level two-tier extension API.
    c                 C   sV   t }tdd|}| | d t}tdd|}| |d d | |dd d S )NTnopythonrI         2@      @)r   r   assertPreciseEqualr   r>   pyfunccfuncr7   r7   r8   
test_func1@  s    z TestLowLevelExtending.test_func1c                 C   sF   t }t|d}| | d t}t|tjf}| |dd d S )Nr7   rI   r  r  )r   r   r  entry_pointr   r   float64r>   r  Zcrr7   r7   r8   test_func1_isolatedI  s    
z)TestLowLevelExtending.test_func1_isolatedc                 C   s   |  tt | t d S rC   )assertIs
type_func1ri   assertIsNotNoner>   r7   r7   r8   !test_type_callable_keeps_functionQ  s    z7TestLowLevelExtending.test_type_callable_keeps_functionc                 C   s&   t }t|dtj}| | d d S )Nr7   g      E@)rM   r   r   r  r  r  r  r7   r7   r8   test_cast_mydummyU  s    z'TestLowLevelExtending.test_cast_mydummyc                 C   sX   t t}tj}tj}|  |  t|||dd}| t	dd |j
 D  dS )zFmake sure make_function is passed to typer class as a literal
        r7   Nc                 s   s   | ]}t |tjV  qd S rC   )r;   r   r   )r   r   r7   r7   r8   r   e  s   z=TestLowLevelExtending.test_mk_func_literal.<locals>.<genexpr>)r   Zrun_frontendr   r   Ztyping_contextZtarget_contextZrefreshr   
assertTrueanytypemapvalues)r>   Ztest_ir	typingctxZ	targetctxZ
typing_resr7   r7   r8   test_mk_func_literalZ  s    

z*TestLowLevelExtending.test_mk_func_literalN)	r4   r5   r6   __doc__r  r  r  r  r$  r7   r7   r7   r8   r  8  s   	r  c                   @   s`   e Zd ZdZdd Zdd Zdd Zdd	 Zd
d Zdd Z	dd Z
dd Zdd Zdd ZdS )TestPandasLikeze
    Test implementing a pandas-like Index object.
    Also stresses most of the high-level API.
    c                 C   s0   t td}tddt}| ||d d S )N   Tr  )r0   r}   r   r   r   r  )r>   r   r  r7   r7   r8   test_index_lenr  s    zTestPandasLike.test_index_lenc                 C   sh   t tdddg}tddt}| ||dd ||tdd }| |t  | t	|ddg d S )NrI      Tr  r/   )
r0   r}   rf   r   r   r  sliceassertIsInstanceassertEqualr   r>   r   r  iir7   r7   r8   test_index_getitemw  s    z!TestPandasLike.test_index_getitemc                 C   sV   t tdddg}tddt}||}| |t  | |jtt	|j dS )z7
        Check Numpy ufunc on an Index object.
        rI   r)  r*  Tr  N)
r0   r}   rf   r   r   r,  r  r   r   r   r.  r7   r7   r8   test_index_ufunc  s
    zTestPandasLike.test_index_ufuncc                 C   s<   t tdddg}tddt}||}| ||j d S )NrI   r)  r*  Tr  )r0   r}   rf   r   r   r  r   )r>   r   r  r   r7   r7   r8   test_index_get_data  s    z"TestPandasLike.test_index_get_datac                 C   s`   t ddt}dddgdfdddgdfg dffD ]*\}}tt|}||}| || q0d S )NTr  r)  rI      F)r   r   r0   r}   rf   r-  )r>   r  r"  expectedr   gotr7   r7   r8   test_index_is_monotonic  s    z&TestPandasLike.test_index_is_monotonicc                 C   sL   t tdddg}ttdddg|}tddt}| ||d d S 	Nro      r'        ?      @      @Tr  )r0   r}   rf   r1   r  r   r   r  )r>   r   sr  r7   r7   r8   test_series_len  s    zTestPandasLike.test_series_lenc                 C   s`   t tdddg}ttdddg|}tddt}||}| |t  | |j	|j	 d S r7  )
r0   r}   rf   r1   r  r   r   r,  r  r   )r>   r   r<  r  r5  r7   r7   r8   test_series_get_index  s    z$TestPandasLike.test_series_get_indexc                 C   s   t tdddg}ttdddg|}tddt}||}| |t | |jt  | 	|jj
|j
 | |jtt|j d	S )
z8
        Check Numpy ufunc on an Series object.
        rI   r)  r*  r/   ro   r'  Tr  N)r0   r}   rf   r1   int64r   r   r,  r   r  r   r  _valuesr   r   r>   r   r<  r  ssr7   r7   r8   test_series_ufunc  s    z TestPandasLike.test_series_ufuncc                 C   sz   t tdddg}tdddg}tddt}|||}| |t | |jt  | 	|jj
|j
 | 	|j| d S )	NrI   r)  r*  r9  r:  r;  Tr  )r0   r}   rf   r  r   r   r,  r1   r   r  r   r@  )r>   r   dr  r5  r7   r7   r8   test_series_constructor  s    
z&TestPandasLike.test_series_constructorc                 C   s   t tdddg}ttdddg|}tddt}||d	d
}| |t | |jt  | 	|jj
|j
 | |jtd	d
dg d S )NrI   r)  r*  r9  r:  r;  Tr  g?g      @)r0   r}   rf   r1   r  r   r   r,  r   r  r   r  r@  rA  r7   r7   r8   test_series_clip  s    zTestPandasLike.test_series_clipN)r4   r5   r6   r%  r(  r0  r1  r2  r6  r=  r>  rC  rE  rF  r7   r7   r7   r8   r&  l  s   

r&  c                   @   s   e Zd ZdZdd Zdd Zdd Zdd	 Zd
d Zdd Z	dd Z
dd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zd d! Zd"d# Zd$d% Zd&d' Zd(d) Zd*S )+TestHighLevelExtendingz+
    Test the high-level combined API.
    c              	      s   t }tdd|  fdd}|dddd |ddd |tdddgtd	d
dgtdddg tj$} tg tg tg  W 5 Q R X 	dt
|j dS )z>
        Test implementing a function with @overload.
        Tr  c                     s$   t | |} | |}|| d S rC   )r~   r  )rm   kwargsr4  r5  r  r>   r7   r8   check  s    

z0TestHighLevelExtending.test_where.<locals>.checkr'  r)  )rc   rz   r{   Fr/   ro   r8  r3  r   N)r   r   r}   Zbool_rf   assertRaisesr	   r   r?  assertInstr	exception)r>   r  rJ  raisesr7   rI  r8   
test_where  s     ( z!TestHighLevelExtending.test_wherec                 C   s8   t ddt}| |t d | |ddgd dS )zN
        Test re-implementing len() for a custom type with @overload.
        Tr  r   r8  r3  ro   N)r   r   r  r2   r>   r  r7   r7   r8   test_len  s    zTestHighLevelExtending.test_lenc              	   C   s@   t ddt}t " |t  | tj d W 5 Q R X dS )zP
        Test re-implementing print() for a custom type with @overload.
        Tr  zhello!
N)r   r   r   r2   r-  sysstdoutgetvaluerQ  r7   r7   r8   
test_print  s    
z!TestHighLevelExtending.test_printc                 C   sT   t }tdd|}| |ddd | |t t d | |t t d dS 	zW
        Test re-implementing operator.add() for a custom type with @overload.
        Tr  r/   ro   r'  rI   T   N)r   r   r  MyDummy2r2   r  r7   r7   r8   test_add_operator  s
    z(TestHighLevelExtending.test_add_operatorc                 C   sT   t }tdd|}| |ddd | |t t d | |t t d dS 	zY
        Test re-implementing '+' for a custom type via @overload(operator.add).
        Tr  r/   ro   r'  rI   rX  N)r   r   r  rY  r2   r  r7   r7   r8   test_add_binop  s
    z%TestHighLevelExtending.test_add_binopc                 C   sT   t }tdd|}| |ddd | |t t d | |t t d dS rW  )r   r   r  rY  r2   r  r7   r7   r8   test_iadd_operator  s
    z)TestHighLevelExtending.test_iadd_operatorc                 C   sT   t }tdd|}| |ddd | |t t d | |t t d dS r[  )r   r   r  rY  r2   r  r7   r7   r8   test_iadd_binop(  s
    z&TestHighLevelExtending.test_iadd_binopc                 C   s   t }tdd|}t }d }t <}z||d W n& tk
rX } z|}W 5 d }~X Y nX W 5 Q R X |d k	rp|| | d d S )NTr  A  zdel hello! 321
)r   r   r2   r   r   r-  rU  r>   r  r  rR   eoutexcr7   r7   r8   test_delitem6  s     z#TestHighLevelExtending.test_delitemc                 C   s*   t }tdd|}| |t dd d S )NTr  r_  i  )r   r   r  r2   r  r7   r7   r8   test_getitemF  s    z#TestHighLevelExtending.test_getitemc                 C   s   t }tdd|}t }d }t >}z||dd W n& tk
rZ } z|}W 5 d }~X Y nX W 5 Q R X |d k	rr|| | d d S )NTr  r_  r   z321 123
)r   r   r2   r   r   r-  rU  r`  r7   r7   r8   test_setitemK  s     z#TestHighLevelExtending.test_setitemc           	   	   C   sx   t ddt}d}||}t|}tj|| t ddt}| t}|  W 5 Q R X t|j	}d}| 
|| dS )zW
        Test overloading whose return value cannot be represented in CPython.
        Tr  
   zcannot convert native ModuleN)r   r   r}   ZtestingZassert_equalr   rK  	TypeErrorrM  rN  rL  )	r>   Zok_cfuncnr5  expectZ	bad_cfuncrO  errmsgZ	expectmsgr7   r7   r8   test_no_cpython_wrapper[  s    
z.TestHighLevelExtending.test_no_cpython_wrapperc              	   C   s   d'dd}d}d(dd}|  tj}||dd	d
d W 5 Q R X t|j}| || | d| | d| | d| d)dd}|  tj}||dd	d
d W 5 Q R X t|j}| || | d| | d| | d| d*dd}|  tj}||dd	d
d W 5 Q R X t|j}| || | d| | d|k | d| | d| ddlm}m	}	 |  tj}||dd	d
d W 5 Q R X t|j}| || | d| | d|k | d| |  tj}||	dd	d
d W 5 Q R X t|j}| || | d| | d|k | d| | d| d+dd}
|  tj}||
dd	d
d W 5 Q R X t|j}| || | d| | d|k | d| | d| d,dd }|  tj}||dd	d
d W 5 Q R X t|j}| || | d| | d|k | d!| d-d"d#}|  tj}||dd	d
d W 5 Q R X t|j}| || | d| | d$| d%d& }|  tj}||dd	d
d W 5 Q R X t|j}| || | d| | d| dS ).z}
        Tests that an overload which has a differing typing and implementing
        signature raises an exception.
        Nc                    s:   d	ddt d
 fdd	}tddfdd}|S )Nc                 S   s   d S rC   r7   r   brG   kwr7   r7   r8   
myoverloadu  s    zjTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling.<locals>.gen_ol.<locals>.myoverloadc                    s    S rC   r7   rm  )implr7   r8   _myoverload_implx  s    zpTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling.<locals>.gen_ol.<locals>._myoverload_implTr  c                    s    | |||d d S )Nro  r7   )r   rn  rG   rD  rp  r7   r8   foo|  s    zcTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling.<locals>.gen_ol.<locals>.foo)N)Nr   r   )rq  rr  ru  r7   )rq  rp  r8   gen_olt  s    
zVTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling.<locals>.gen_olz-Typing and implementation arguments differ in   c                 S   s   | dkrdS dS d S Nrg  r/   r7   rm  r7   r7   r8   impl1  s    zUTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling.<locals>.impl1r/   ro   r'  r8  zkeyword argument default valuesz<Parameter "kw=12">z<Parameter "kw=None">c                 S   s   | dkrdS dS d S ry  r7   )r   rn  rG   kwargr7   r7   r8   impl2  s    zUTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling.<locals>.impl2zkeyword argument namesz<Parameter "kwarg=None">c                 S   s   t dkrdS dS d S ry  r   )zrn  rG   ro  r7   r7   r8   impl3  s    zUTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling.<locals>.impl3zargument nameskeywordz<Parameter "a">z<Parameter "z">)impl4impl5zFirst difference: 'z'c                 S   s   | dkrdS dS d S ry  r7   )r   rn  rG   rD  ra  ro  r7   r7   r8   impl6  s    zUTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling.<locals>.impl6z<Parameter "d">z<Parameter "e">c                 S   s   | dkrdS dS d S ry  r7   )r   rn  ro  r7   r7   r8   impl7  s    zUTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling.<locals>.impl7z<Parameter "c">c                 S   s   | dkrdS dS d S ry  r7   )r   rn  rG   ro  Zextra_kwargr7   r7   r8   impl8  s    zUTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling.<locals>.impl8z<Parameter "extra_kwarg=None">c                 S   s   | dkrdS dS d S ry  r7   )r   rn  rG   r7   r7   r8   impl9  s    zUTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling.<locals>.impl9)N)rx  )N)N)N)N)NN)
rK  r	   r   rM  rN  rL  assertFalseoverload_usecasesr  r  )r>   rw  sentinelr{  ra  msgr}  r  r  r  r  r  r  r  r7   r7   r8   /test_typing_vs_impl_signature_mismatch_handlingn  s    















zFTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handlingc              	      s   ddd ddl m} t | tdd fdd	}| tj}|dd
 W 5 Q R X t|j}| 	d| | 	d| dS )z
        Tests that an overload which has a differing typing and implementing
        signature raises an exception and uses VAR_POSITIONAL (*args) in typing
        Nc                 S   s   d S rC   r7   r   ro  r7   r7   r8   rp    s    ziTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling_var_positional.<locals>.myoverloadr/   )var_positional_implTr  c                    s    | |dddS )N	      rs  r7   r   rn  rt  r7   r8   ru    s    zbTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling_var_positional.<locals>.foor3  z)VAR_POSITIONAL (e.g. *args) argument kindz-offending argument name is '*star_args_token')N)
r  r  r   r   rK  r	   r   rM  rN  rL  )r>   r  ru  ra  r  r7   rt  r8   >test_typing_vs_impl_signature_mismatch_handling_var_positional   s    

zUTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling_var_positionalc              	   C   s   ddd}dd }||ddd |  tj}||dd W 5 Q R X t|j}| d	| | d
| ddd}|  tj}||dd W 5 Q R X t|j}| d	| | d
| dS )zJ
        Tests that an overload which uses **kwargs (VAR_KEYWORD)
        Tc                    s4   ddd t  |d|  tdd fdd}|S )	Nc                 S   s   d S rC   r7   r  r7   r7   r8   rp    s    zvTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling_var_keyword.<locals>.gen_ol.<locals>.myoverloadstrictTr  c                    s    | ddS )Nr  rs  r7   r  rt  r7   r8   ru  "  s    zoTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling_var_keyword.<locals>.gen_ol.<locals>.foo)Nrv  )rq  r  ru  r7   rt  r8   rw    s
    
zbTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling_var_keyword.<locals>.gen_olc                 [   s   ddd}|S )Nrg  c                 S   s   | S rC   r7   r  r7   r7   r8   rq  *  s    zmTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling_var_keyword.<locals>.ol1.<locals>.impl)rg  r7   )r   r   rq  r7   r7   r8   ol1)  s    
z_TestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling_var_keyword.<locals>.ol1Fr/   ro   z1use of VAR_KEYWORD (e.g. **kwargs) is unsupportedz"offending argument name is '**kws'r   c                 S   s   dd }|S )Nc                 [   s   | S rC   r7   )r   r   r7   r7   r8   rq  8  s    zmTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling_var_keyword.<locals>.ol2.<locals>.implr7   )r   ro  rq  r7   r7   r8   ol27  s    z_TestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling_var_keyword.<locals>.ol2N)T)r   )rK  r	   r   rM  rN  rL  )r>   rw  r  ra  r  r  r7   r7   r8   ;test_typing_vs_impl_signature_mismatch_handling_var_keyword  s    



zRTestHighLevelExtending.test_typing_vs_impl_signature_mismatch_handling_var_keywordc                 C   s@   t tjdd	dd}tdd }td}| ||d d S )
Nru  rg  c                 S   s   ddd}|S )Nrg  c                 S   s   |S rC   r7   )r   a_kwargr7   r7   r8   rq  G  s    zQTestHighLevelExtending.test_overload_method_kwargs.<locals>.fooimpl.<locals>.impl)rg  r7   )r   r  rq  r7   r7   r8   fooimplE  s    
zCTestHighLevelExtending.test_overload_method_kwargs.<locals>.fooimplc                 S   s   |   |  d| j ddfS )N      )r  ru  Ar7   r7   r8   barL  s    z?TestHighLevelExtending.test_overload_method_kwargs.<locals>.barr3  )rg  r  r  )rg  )r   r   r   r   r}   r   r-  )r>   r  r  Zr7   r7   r8   test_overload_method_kwargsC  s    


z2TestHighLevelExtending.test_overload_method_kwargsc                 C   sF   t tjddd }tdd }td}|| | ||d d S )Nlitfooc                 S   s(   t |tjr$t |tjs$dd }|S d S )Nc                 S   s   |S rC   r7   )r   rF   r7   r7   r8   rq  ]  s    zXTestHighLevelExtending.test_overload_method_literal_unpack.<locals>.litfoo.<locals>.impl)r;   r   r   Literal)r   rF   rq  r7   r7   r8   r  V  s    zJTestHighLevelExtending.test_overload_method_literal_unpack.<locals>.litfooc                 S   s
   |  dS N  )r  r  r7   r7   r8   r  b  s    zGTestHighLevelExtending.test_overload_method_literal_unpack.<locals>.barr/   r  )r   r   r   r   r}   zerosr-  )r>   r  r  r  r7   r7   r8   #test_overload_method_literal_unpackT  s    



z:TestHighLevelExtending.test_overload_method_literal_unpackc                 C   s   t dd }| | d d S )Nc                   S   s
   t tS rC   )r}   exprB   r7   r7   r7   r8   testn  s    z8TestHighLevelExtending.test_overload_ufunc.<locals>.testr  )r   r-  )r>   r  r7   r7   r8   test_overload_ufuncj  s    
z*TestHighLevelExtending.test_overload_ufuncc                 C   s   t tddd }tdd }t }| ||ddd | ||ddd	d
 | ||ddd	dd tdd }| ||d | ||dddd | ||dddd | ||dddd d S )Nmethod_starargc                 W   s   dd }|S )Nc                 W   s
   |||fS rC   r7   )rR   rF   val2rm   r7   r7   r8   getw  s    z\TestHighLevelExtending.test_overload_method_stararg.<locals>._ov_method_stararg.<locals>.getr7   )rR   rF   r  rm   r  r7   r7   r8   _ov_method_starargu  s    zOTestHighLevelExtending.test_overload_method_stararg.<locals>._ov_method_starargc                 W   s
   | j | S rC   r  )rR   rm   r7   r7   r8   ru  |  s    z@TestHighLevelExtending.test_overload_method_stararg.<locals>.foor/   ro   r/   ro   r7   r'  r/   ro   r'  r8  r/   ro   r'  r8  c                 S   s(   |  dd|  ddd|  ddddfS )Nr/   ro   r'  r8  r  r  r7   r7   r8   r    s    
z@TestHighLevelExtending.test_overload_method_stararg.<locals>.bar)r  r  r  r  )r/   ro   )r  r  )r/   ro   )r  r'  )r8  r3  )r/   ro   )r  r   r9   r   r2   r-  )r>   r  ru  rR   r  r7   r7   r8   test_overload_method_starargt  s4    


    z3TestHighLevelExtending.test_overload_method_starargc              	      s   G dd dt j t ddd }t fdd}d}| ||t| td	d
 }| tj	}|| W 5 Q R X | 
dt|j d S )Nc                   @   s   e Zd ZdS )zATestHighLevelExtending.test_overload_classmethod.<locals>.MyArrayNr3   r7   r7   r7   r8   MyArray  s   r  array_allocc                 S   s   dd }|S )Nc                 S   s   t |}|S rC   r}   r   )clsnitemsr   r7   r7   r8   rq    s    
zVTestHighLevelExtending.test_overload_classmethod.<locals>.ol_array_alloc.<locals>.implr7   )r  r  rq  r7   r7   r8   ol_array_alloc  s    zHTestHighLevelExtending.test_overload_classmethod.<locals>.ol_array_allocc                    s
     | S rC   )r  r  r  r7   r8   ru    s    z=TestHighLevelExtending.test_overload_classmethod.<locals>.foor   c                 S   s   t j| S rC   )r   r   r  r  r7   r7   r8   no_classmethod_in_base  s    zPTestHighLevelExtending.test_overload_classmethod.<locals>.no_classmethod_in_basez"Unknown attribute 'array_alloc' of)r   r   r)   r   r  r}   r   rK  r	   r   rL  rM  rN  )r>   r  ru  r  r  rO  r7   r  r8   test_overload_classmethod  s    

z0TestHighLevelExtending.test_overload_classmethodc                 C   s\   t tdd }t tdd }tdd }d}d|d	  d
|d  f}| || | d S )Nc                 S   s   t | tjrdd }|S d S )Nc                 S   s   d|  S )N     @E@r7   rb   r7   r7   r8   rq    s    zeTestHighLevelExtending.test_overload_callable_typeref.<locals>.callable_type_call_ovld1.<locals>.impl)r;   r   r   rc   rq  r7   r7   r8   callable_type_call_ovld1  s    zWTestHighLevelExtending.test_overload_callable_typeref.<locals>.callable_type_call_ovld1c                 S   s   t | tjrdd }|S d S )Nc                 S   s   d|  S )N42.5r7   rb   r7   r7   r8   rq    s    zeTestHighLevelExtending.test_overload_callable_typeref.<locals>.callable_type_call_ovld2.<locals>.impl)r;   r   ZUnicodeTyper  r7   r7   r8   callable_type_call_ovld2  s    zWTestHighLevelExtending.test_overload_callable_typeref.<locals>.callable_type_call_ovld2c                 S   s   t | t |fS rC   )r   r  r7   r7   r8   ru    s    zBTestHighLevelExtending.test_overload_callable_typeref.<locals>.foo)r8  4r  r   r  r/   )r   r   r   r  )r>   r  r  ru  rm   r4  r7   r7   r8   test_overload_callable_typeref  s    


z5TestHighLevelExtending.test_overload_callable_typerefN)r4   r5   r6   r%  rP  rR  rV  rZ  r\  r]  r^  rd  re  rf  rl  r  r  r  r  r  r  r  r  r  r7   r7   r7   r8   rG    s,   	 ,
+ rG  c                 C   sD   | j | jd  }||kr td| j| jd  }||kr@tdd S )Nr   zcache not used)Z_cache_hitsZ
signaturesr   Z_cache_misses)r  Z
expect_hitZexpect_misseshitZmissr7   r7   r8   _assert_cache_stats  s    r  c                   @   s    e Zd ZdZdd Zdd ZdS )TestOverloadMethodCachingFc              	   C   s2   t | jj| _td| j |   W 5 Q R X d S )N	CACHE_DIR)r   r   r4   
_cache_dirr   run_caching_overload_methodr  r7   r7   r8   test_caching_overload_method  s    z6TestOverloadMethodCaching.test_caching_overload_methodc                 C   s   t dddt}| |t d t|dd |tf}dd | D }| t	|d zt
d}W n tk
r   t
}Y nX | }|jt|| jfd	}|  |t  |  | |jd |jdd
}| |d d S )NTr  cacher   r   r/   c                 S   s"   g | ]}| d rd|kr|qS )Zdeclarer   )
startswith)r   lnr7   r7   r8   
<listcomp>  s   
 zITestOverloadMethodCaching.run_caching_overload_method.<locals>.<listcomp>spawn)targetrm   )timeout)r   r   r  r2   r  Zinspect_llvmrD   
splitlinesr-  r   multiprocessingZget_contextAttributeErrorQueueProcessr  r  startputjoinexitcoder  )r>   r  ZllvmirZdeclsctxqpr   r7   r7   r8   r    s.    
 z5TestOverloadMethodCaching.run_caching_overload_methodN)r4   r5   r6   _numba_parallel_test_r  r  r7   r7   r7   r8   r    s   r  c              	   C   sP   t d|< |  }tdddt}||}| | t|dd W 5 Q R X dS )zH
    Used by TestOverloadMethodCaching.test_caching_overload_method
    r  Tr  r/   r   N)r   r  r   r   r  r  )r  	cache_dirr   r  r   r7   r7   r8   r    s    
r  c                   @   s4   e Zd Zdd Zdd Zdd Zdd Zd	d
 ZdS )TestIntrinsicc              	      s   t dd t dd  tddfdd}tdd fd	d
}| | d | t}|  W 5 Q R X | d|jj dS )z
        Verify that returning a None from codegen function is handled
        automatically for void functions, otherwise raise exception.
        c                 S   s   t t j}dd }||fS )Nc                 S   s   d S rC   r7   r?   rK   r+   rm   r7   r7   r8   codegen#  s    zBTestIntrinsic.test_void_return.<locals>.void_func.<locals>.codegenr   voidrf   r#  r   rl   r  r7   r7   r8   	void_func  s    z1TestIntrinsic.test_void_return.<locals>.void_funcc                 S   s   t t j}dd }||fS )Nc                 S   s   d S rC   r7   r  r7   r7   r8   r  -  s    zFTestIntrinsic.test_void_return.<locals>.non_void_func.<locals>.codegen)r   rf   r  r7   r7   r8   non_void_func)  s    z5TestIntrinsic.test_void_return.<locals>.non_void_funcTr  c                      s    d dS Nr/   r   r7   r7   )r  r7   r8   call_void_func2  s    z6TestIntrinsic.test_void_return.<locals>.call_void_funcc                      s    d dS r  r7   r7   )r  r7   r8   call_non_void_func7  s    z:TestIntrinsic.test_void_return.<locals>.call_non_void_funcr   znon-void function returns NoneN)r$   r   r-  rK  r   rL  rN  r  )r>   r  r  ra  r7   )r  r  r8   test_void_return  s    
	
zTestIntrinsic.test_void_returnc              	      s   ddl m}m}m}m} fdddd tddfd	d
}dd }|d|||}|| tdd fdd}tjdtj	d}	t
 }
||	 |
  }W 5 Q R X |
  ttt|	}|| dS )zV
        Usecase test: custom reinterpret cast to turn int values to pointers
        r   )	CFUNCTYPEPOINTERc_floatc_intc                    s&   t  tjstt fdd}|S )Nc                    s8    | tj t|tjr4 tj}dd }||fS d S )Nc                 S   s"   |\}|j }| |}|||S rC   )rk   Zget_value_typeZinttoptr)r?   rK   r+   rm   srcZrtypeZllrtyper7   r7   r8   r  T  s    
z_TestIntrinsic.test_ll_pointer_cast.<locals>.unsafe_caster.<locals>.unsafe_cast.<locals>.codegen)r,  r
   Contextr;   r   r   Zuintp)r#  r  rl   r  )result_typer>   r7   r8   unsafe_castM  s
    
zNTestIntrinsic.test_ll_pointer_cast.<locals>.unsafe_caster.<locals>.unsafe_cast)r;   r   CPointerr   r$   )r  r  r  )r  r8   unsafe_casterJ  s    z9TestIntrinsic.test_ll_pointer_cast.<locals>.unsafe_casterc                 S   s   t dd S )Nznot callable from pythonr`   r  r7   r7   r8   unsafe_get_ctypes_pointer`  s    zETestIntrinsic.test_ll_pointer_cast.<locals>.unsafe_get_ctypes_pointerFr  c                    s0   t | tjr,t| j  fdd}|S d S )Nc                    s    | j jdS )Nr  )ctypesr   )r   r  r7   r8   
array_implh  s    zdTestIntrinsic.test_ll_pointer_cast.<locals>.array_impl_unsafe_get_ctypes_pointer.<locals>.array_impl)r;   r   r   r  r   )Zarrtyper  )r  r  r8   $array_impl_unsafe_get_ctypes_pointerc  s    zPTestIntrinsic.test_ll_pointer_cast.<locals>.array_impl_unsafe_get_ctypes_pointerc                 S   s   t |D ]}t| |  qd S rC   )r   r   )ptrri  r   r7   r7   r8   my_c_fun_rawn  s    z8TestIntrinsic.test_ll_pointer_cast.<locals>.my_c_fun_rawNTr  c                    s   | } || j  d S rC   )r   )r   r  )my_c_funr  r7   r8   ru  w  s    z/TestIntrinsic.test_ll_pointer_cast.<locals>.foorg  )r   )r  r  r  r  r  r   r   r}   r   Zfloat32r   rU  r  closer   maprM  r-  )r>   r  r  r  r  r   r  Z	prototyperu  r   bufr5  rj  r7   )r  r>   r  r  r8   test_ll_pointer_castC  s"    

z"TestIntrinsic.test_ll_pointer_castc                    s   t dd  tdd fdd}| |dd tj}t|}t|}|d7 }| |t| t|}| |t| | |d|d t }| |t| t|}| 	 | | |t| dS )	z9
        Test serialization of intrinsic objects
        c                 S   s   dd }||}||fS )Nc                 S   s   |d S r   r7   r  r7   r7   r8   r    s    zCTestIntrinsic.test_serialization.<locals>.identity.<locals>.codegenr7   )r?   rc   r  rl   r7   r7   r8   identity  s    z2TestIntrinsic.test_serialization.<locals>.identityTr  c                    s    | S rC   r7   rb   r  r7   r8   ru    s    z-TestIntrinsic.test_serialization.<locals>.foor/   N)
r$   r   r-  r%   _memor   pickledumpsloadsr  )r>   ru  memo	memo_sizeZserialized_fooZfoo_rebuiltZserialized_identityZidentity_rebuiltr7   r	  r8   test_serialization  s$    




z TestIntrinsic.test_serializationc                 C   s   dd }t j}t|}t d|}| |j| t|}|d7 }| |t| ~| |t| t j	  |d8 }| |t| t
|}| |j| t
|}| |j|j dS )z3
        Test deserialization of intrinsic
        c                 S   s   dd }|||fS )Nc                 S   s   |d S r   r7   r  r7   r7   r8   r    s    zATestIntrinsic.test_deserialization.<locals>.defn.<locals>.codegenr7   )r?   rc   r  r7   r7   r8   defn  s    z0TestIntrinsic.test_deserialization.<locals>.defnru  r/   N)r%   r
  r   r  Z_defnr  r  r-  Z_recentclearr  ZassertIsNot)r>   r  r  r  originalZpickledZrebuiltsecondr7   r7   r8   test_deserialization  s"    




z"TestIntrinsic.test_deserializationc                 C   s`   t tddd}| d|j | d|j | d|j | dti|j | d|j d S )Nr   c                 S   s   t t j}dd }||fS )void_func docstringc                 S   s   d S rC   r7   r  r7   r7   r8   r    s    z@TestIntrinsic.test_docstring.<locals>.void_func.<locals>.codegenr  r  r7   r7   r8   r    s    z/TestIntrinsic.test_docstring.<locals>.void_funcznumba.tests.test_extendingr  r   r  )	r$   intr-  r5   r4   r6   ZassertDictEqual__annotations__r%  )r>   r  r7   r7   r8   test_docstring  s    
zTestIntrinsic.test_docstringN)r4   r5   r6   r  r  r  r  r  r7   r7   r7   r8   r    s
   *B.(r  c                   @   s   e Zd Zdd Zdd ZdS )TestRegisterJitablec                    sJ   t dd   fdd}tdd|}|dd}|dd}| || d S )	Nc                 S   s   | | S rC   r7   rc   r{   r7   r7   r8   ru    s    z.TestRegisterJitable.test_no_flags.<locals>.fooc                    s
    | |S rC   r7   r  r  r7   r8   r    s    z.TestRegisterJitable.test_no_flags.<locals>.barTr  r/   ro   )r&   r   r-  )r>   r  cbarrj  r5  r7   r  r8   test_no_flags  s    


z!TestRegisterJitable.test_no_flagsc              	      s   t dddd   fdd}| |d dd	d
g tdd|}| tj}|d
 W 5 Q R X d}| |t|j	 d S )NF)_nrtc                 S   s
   t | S rC   r  ri  r7   r7   r8   ru     s    z2TestRegisterJitable.test_flags_no_nrt.<locals>.fooc                    s    | S rC   r7   r  r  r7   r8   r    s    z2TestRegisterJitable.test_flags_no_nrt.<locals>.barr'  r   r/   ro   Tr  COnly accept returning of array passed into the function as argument)
r&   r-  tolistr   rK  r	   r   rL  rM  rN  )r>   r  r  rO  r  r7   r  r8   test_flags_no_nrt  s    
z%TestRegisterJitable.test_flags_no_nrtN)r4   r5   r6   r  r"  r7   r7   r7   r8   r    s   r  c                   @   sD   e Zd Zeedkddd Zdd Zeedkddd ZdS )	TestImportCythonFunctionNz&Only run if SciPy >= 0.19 is installedc                    sL   t dd}ttjtj}|| tdd fdd}| |dd d S )	Nscipy.special.cython_specialj0Tr  c                    s    | S rC   r7   rb   Z_j0r7   r8   r     r   z@TestImportCythonFunction.test_getting_function.<locals>.<lambda>r   r/   )r'   r  r  c_doubler   r-  )r>   addrZfunctyper%  r7   r&  r8   test_getting_function  s     z.TestImportCythonFunction.test_getting_functionc              	   C   sD   |  t}tdd W 5 Q R X d}t|t|j}| | d S )NZ
fakemoduleZfakefunctionzNo module named '?fakemodule'?)rK  ImportErrorr'   rematchrM  rN  r  )r>   rO  r  r,  r7   r7   r8   test_missing_module  s
    z,TestImportCythonFunction.test_missing_modulec              	   C   s:   |  t}tdd W 5 Q R X d}| |t|j d S )Nr$  ru  zINo function 'foo' found in __pyx_capi__ of 'scipy.special.cython_special')rK  r   r'   r-  rM  rN  )r>   rO  r  r7   r7   r8   test_missing_function&  s     z.TestImportCythonFunction.test_missing_function)	r4   r5   r6   unittestZskipIfscr)  r-  r.  r7   r7   r7   r8   r#    s
   
	r#  method_jit_option_check_nrtr  TZjit_optionsc                 C   s   dd }|S )Nc                 S   s
   t dS Nrg  r  r  r7   r7   r8   r   7  s    z+ov_method_jit_option_check_nrt.<locals>.impr7   r	  r7   r7   r8   ov_method_jit_option_check_nrt3  s    r4  method_jit_option_check_no_nrtFc                 C   s   dd }|S )Nc                 S   s
   t dS r3  r  r  r7   r7   r8   r   A  s    z.ov_method_jit_option_check_no_nrt.<locals>.impr7   r	  r7   r7   r8   !ov_method_jit_option_check_no_nrt=  s    r6  attr_jit_option_check_nrtc                 C   s   dd }|S )Nc                 S   s
   t dS r3  r  r  r7   r7   r8   r   K  s    z)ov_attr_jit_option_check_nrt.<locals>.impr7   r	  r7   r7   r8   ov_attr_jit_option_check_nrtG  s    r8  attr_jit_option_check_no_nrtc                 C   s   dd }|S )Nc                 S   s
   t dS r3  r  r  r7   r7   r8   r   U  s    z,ov_attr_jit_option_check_no_nrt.<locals>.impr7   r	  r7   r7   r8   ov_attr_jit_option_check_no_nrtQ  s    r:  c                   @   s4   e Zd Zdd Zdd Zdd Zdd Zd	d
 ZdS )TestJitOptionsNoNRTc              	   O   s<   d}|  tj}||| W 5 Q R X | |t|j d S )Nr   )rK  r	   r   rL  rM  rN  )r>   funcrm   rH  r  rO  r7   r7   r8   check_error_no_nrt^  s
    z&TestJitOptionsNoNRT.check_error_no_nrtc                    sX   dd  t  d|iddd }t fdd}|rJ| | td	 n
| | d S )
Nc                   S   s
   t dS r3  r  r7   r7   r7   r8   dummyi  s    z8TestJitOptionsNoNRT.no_nrt_overload_check.<locals>.dummyr  r2  c                  S   s   dd } | S )Nc                   S   s
   t dS r3  r  r7   r7   r7   r8   r>  n  s    zJTestJitOptionsNoNRT.no_nrt_overload_check.<locals>.ov_dummy.<locals>.dummyr7   r>  r7   r7   r8   ov_dummyl  s    z;TestJitOptionsNoNRT.no_nrt_overload_check.<locals>.ov_dummyc                      s     S rC   r7   r7   r?  r7   r8   ru  s  s    z6TestJitOptionsNoNRT.no_nrt_overload_check.<locals>.foorg  )r   r   r  r}   r   r=  )r>   flagr@  ru  r7   r?  r8   no_nrt_overload_checkh  s    
z)TestJitOptionsNoNRT.no_nrt_overload_checkc                 C   s   |  d |  d d S )NTF)rB  r  r7   r7   r8   test_overload_no_nrt|  s    
z(TestJitOptionsNoNRT.test_overload_no_nrtc                 C   s>   t dd }| |ttd t dd }| |t d S )Nc                 S   s   |   S rC   )r1  rb   r7   r7   r8   udt  s    z<TestJitOptionsNoNRT.test_overload_method_no_nrt.<locals>.udtrg  c                 S   s   |   S rC   )r5  rb   r7   r7   r8   rD    s    r   r  rB   r}   r   r=  r>   rD  r7   r7   r8   test_overload_method_no_nrt  s    

z/TestJitOptionsNoNRT.test_overload_method_no_nrtc                 C   s>   t dd }| |ttd t dd }| |t d S )Nc                 S   s   | j S rC   )r7  rb   r7   r7   r8   rD    s    z?TestJitOptionsNoNRT.test_overload_attribute_no_nrt.<locals>.udtrg  c                 S   s   | j S rC   )r9  rb   r7   r7   r8   rD    s    rE  rF  r7   r7   r8   test_overload_attribute_no_nrt  s    

z2TestJitOptionsNoNRT.test_overload_attribute_no_nrtN)r4   r5   r6   r=  rB  rC  rG  rH  r7   r7   r7   r8   r;  [  s
   
r;  c                       s<   e Zd Z fddZdd Zdd Zdd Zd	d
 Z  ZS )TestBoxingCallingJITc                    s0   t    td}|\| _| _| _|  | _d S )Nr^   )r   setUpr]   rU   rT   rW   dyn_type)r>   manyr   r7   r8   rJ    s    
zTestBoxingCallingJIT.setUpc                    sl   dd t  fddt| jfdd}t| jdd }td	d
 }|| j}| |   d S )Nr  r   c                    s    fdd}t ||}||fS )Nc                    s   |\}| || S rC   r   r   r?   rK   rl   rm   rF   magic_offsetr7   r8   rq    s    zKTestBoxingCallingJIT.test_unboxer_basic.<locals>.my_intrinsic.<locals>.implr+   r#  rF   rq  rl   rO  r7   r8   my_intrinsic  s    
z=TestBoxingCallingJIT.test_unboxer_basic.<locals>.my_intrinsicc                    sL   fdd}|j tj g}ttjtj}|j|||\}}t||dS )Nc                    s    | S rC   r7   rb   rS  r7   r8   bridge  s    zHTestBoxingCallingJIT.test_unboxer_basic.<locals>.unboxer.<locals>.bridgeis_error	r?   rJ   r   intpr+   Zvoidptrrw   call_jit_coder#   rQ   rR   rG   rU  rm   rl   rW  r   magic_tokenrS  r7   r8   unboxer  s
    z8TestBoxingCallingJIT.test_unboxer_basic.<locals>.unboxerc                 S   s   |j |tj}|j|S rC   rK   Zptrtointr   Zintp_trw   long_from_ssize_trQ   rF   rG   r   r7   r7   r8   boxer  s    z6TestBoxingCallingJIT.test_unboxer_basic.<locals>.boxerc                 S   s   | S rC   r7   rb   r7   r7   r8   passthru  s    z9TestBoxingCallingJIT.test_unboxer_basic.<locals>.passthrur$   r"   rU   r!   r   rK  r-  )r>   r^  rb  rc  rb  r7   rP  r]  rS  r8   test_unboxer_basic  s    	


z'TestBoxingCallingJIT.test_unboxer_basicc              	   C   sf   t | jdd }t| jdd }tdd }| t}|| j W 5 Q R X | dt|j	 d S )Nc                 S   sH   dd }|j tjdg}ttjtj}|j|||\}}t||dS )Nc                 S   s   | dkrt d| S )Nr   cannot be x > 0r   rb   r7   r7   r8   rU    s    zHTestBoxingCallingJIT.test_unboxer_raise.<locals>.unboxer.<locals>.bridger/   rV  rX  r[  r7   r7   r8   r^    s
    z8TestBoxingCallingJIT.test_unboxer_raise.<locals>.unboxerc                 S   s   |j |tj}|j|S rC   r_  ra  r7   r7   r8   rb    s    z6TestBoxingCallingJIT.test_unboxer_raise.<locals>.boxerc                 S   s   | S rC   r7   rb   r7   r7   r8   rc    s    z9TestBoxingCallingJIT.test_unboxer_raise.<locals>.passthrurg  
r"   rU   r!   r   rK  r   rK  rL  rM  rN  r>   r^  rb  rc  rO  r7   r7   r8   test_unboxer_raise  s    


 z'TestBoxingCallingJIT.test_unboxer_raisec                    sl   dd t  fddt| jdd }t| jfdd}td	d
 }|| j}| |   d S )Nr  i8  c                    s    fdd}t ||}||fS )Nc                    s   |\}| || S rC   rM  rN  rO  r7   r8   rq    s    zCTestBoxingCallingJIT.test_boxer.<locals>.my_intrinsic.<locals>.implrQ  rR  rO  r7   r8   rS    s    
z5TestBoxingCallingJIT.test_boxer.<locals>.my_intrinsicc                 S   s   t |j S rC   rN   rP   r7   r7   r8   r^    s    z0TestBoxingCallingJIT.test_boxer.<locals>.unboxerc                    sL   fdd}|j tj g}ttjtj}|j|||\}}|j|S )Nc                    s    | S rC   r7   rb   rT  r7   r8   rU    s    z>TestBoxingCallingJIT.test_boxer.<locals>.boxer.<locals>.bridge)r?   rJ   r   rY  r+   rw   rZ  r`  )rQ   rF   rG   rU  rm   rl   rW  r   r\  r7   r8   rb    s
    z.TestBoxingCallingJIT.test_boxer.<locals>.boxerc                 S   s   | S rC   r7   rb   r7   r7   r8   rc  	  s    z1TestBoxingCallingJIT.test_boxer.<locals>.passthrurd  )r>   r^  rb  rc  rr7   re  r8   
test_boxer  s    	



zTestBoxingCallingJIT.test_boxerc              	   C   sf   t | jdd }t| jdd }tdd }| t}|| j W 5 Q R X | dt|j	 d S )Nc                 S   s   t |j S rC   rN   rP   r7   r7   r8   r^    s    z6TestBoxingCallingJIT.test_boxer_raise.<locals>.unboxerc           
   	   S   s   dd }|j tjdg}ttjtj}|j|||\}}tj|j	|jj
dd}|j	|j	|  |j|}	|j	|	| W 5 Q R X |j	|S )Nc                 S   s   | dkrt d| S )Nr   cannot do x > 0rh  rb   r7   r7   r8   rU    s    zDTestBoxingCallingJIT.test_boxer_raise.<locals>.boxer.<locals>.bridger/   T)zfill)r?   rJ   r   rY  r+   rw   rZ  r   Zalloca_oncerK   ZpyobjZif_thennot_r`  storeload)
rQ   rF   rG   rU  rm   rl   rW  r   retvalrR   r7   r7   r8   rb    s    z4TestBoxingCallingJIT.test_boxer_raise.<locals>.boxerc                 S   s   | S rC   r7   rb   r7   r7   r8   rc  '  s    z7TestBoxingCallingJIT.test_boxer_raise.<locals>.passthrurn  ri  rj  r7   r7   r8   test_boxer_raise  s    


 z%TestBoxingCallingJIT.test_boxer_raise)	r4   r5   r6   rJ  rf  rk  rm  rt  r  r7   r7   r   r8   rI    s
   *%rI  c                 C   s   d S rC   r7   rb   r7   r7   r8   with_objmode_cache_ov_example2  s    ru  c                   @   sX   e Zd ZdZdZdd Zdd Zdd Zed	d
 Z	edd Z
edd Zdd ZdS )TestCachingOverloadObjmodezTTest caching of the use of overload implementations that use
    `with objmode`
    Fc                 C   s   t dtj d S )Nerror)warningssimplefilterr	   ZNumbaWarningr  r7   r7   r8   rJ  ?  s    z TestCachingOverloadObjmode.setUpc                 C   s   t   d S rC   )rx  resetwarningsr  r7   r7   r8   tearDownB  s    z#TestCachingOverloadObjmode.tearDownc              	      s   t | jj}td| dd fdd tt fdd}tdd	d
d }d}|d}| || tdd	|j}|d}| || W 5 Q R X d S )Nr  c                 S   s   t | |  }t j|S rC   )r}   r   ZlinalgZnorm)rc   r   r7   r7   r8   realworkI  s    zJTestCachingOverloadObjmode.test_caching_overload_objmode.<locals>.realworkc                    s    | S rC   r7   rb   )r|  r7   r8   python_codeN  s    zMTestCachingOverloadObjmode.test_caching_overload_objmode.<locals>.python_codec                    s    fdd}|S )Nc              	      s"   t dd  | }W 5 Q R X |S Nr  )r{   r   r  r}  r7   r8   rq  T  s    zqTestCachingOverloadObjmode.test_caching_overload_objmode.<locals>._ov_with_objmode_cache_ov_example.<locals>.implr7   r  r  r7   r8   !_ov_with_objmode_cache_ov_exampleR  s    zcTestCachingOverloadObjmode.test_caching_overload_objmode.<locals>._ov_with_objmode_cache_ov_exampleTr  c                 S   s   t | S rC   )ru  rb   r7   r7   r8   testcase[  s    zJTestCachingOverloadObjmode.test_caching_overload_objmode.<locals>.testcaser   )	r   r   r4   r   r   ru  r   r-  py_func)r>   r  r  r  rj  r5  Ztestcase_cachedr7   )r}  r|  r8   test_caching_overload_objmodeE  s    
z8TestCachingOverloadObjmode.test_caching_overload_objmodec                    s\   dd dd  t  fdd}tdd fd	d
}| }| }||krXtd|S )Nc                 S   s   t | | S rC   r}   sumr  r7   r7   r8   do_thisi  s    zGTestCachingOverloadObjmode.check_objmode_cache_ndarray.<locals>.do_thisc                 S   s   t | | S rC   r  r  r7   r7   r8   do_somethingl  s    zLTestCachingOverloadObjmode.check_objmode_cache_ndarray.<locals>.do_somethingc                    s    fdd}|S )Nc              	      s$   t dd  | |}W 5 Q R X |S r~  r  )r   rn  r{   r  r7   r8   _do_something_implq  s    zqTestCachingOverloadObjmode.check_objmode_cache_ndarray.<locals>.overload_do_something.<locals>._do_something_implr7   )r   rn  r  r  r7   r8   overload_do_somethingo  s    zUTestCachingOverloadObjmode.check_objmode_cache_ndarray.<locals>.overload_do_somethingTr  c                     s   t d} t d} | |S )Nr  r  r  )r  r7   r8   test_cachingw  s    

zLTestCachingOverloadObjmode.check_objmode_cache_ndarray.<locals>.test_cachingzincorrect result)r   r   r  r   )r  r  r  r5  rj  r7   )r  r  r8   check_objmode_cache_ndarrayg  s    z6TestCachingOverloadObjmode.check_objmode_cache_ndarrayc                 C   s   |    d S rC   )r  )r  r7   r7   r8   *populate_objmode_cache_ndarray_check_cache  s    zETestCachingOverloadObjmode.populate_objmode_cache_ndarray_check_cachec                 C   s<   |   }t|jjdkr tdt|jjdkr8tdd S )Nr   zunexpected cache misszunexpected missing cache hit)r  r   statsZcache_missesr   Z
cache_hits)r  Zdispr7   r7   r8   'check_objmode_cache_ndarray_check_cache  s
    zBTestCachingOverloadObjmode.check_objmode_cache_ndarray_check_cachec              	   C   sN   t | jj}td| t| j| t| j|}W 5 Q R X | |d d d S )Nr  r  r   )r   r   r4   r   r   r  r  r-  )r>   r  r   r7   r7   r8    test_check_objmode_cache_ndarray  s      z;TestCachingOverloadObjmode.test_check_objmode_cache_ndarrayN)r4   r5   r6   r%  r  rJ  r{  r  classmethodr  r  r  r  r7   r7   r7   r8   rv  8  s   "


rv  c                   @   s   e Zd Zdd Zdd ZdS )TestMiscc                 C   sn   dd }|  t| | tt| |  tt| |  ttdd| |  ttdd| d S )Nc                 S   s   d S rC   r7   rb   r7   r7   r8   ru    s    z$TestMisc.test_is_jitted.<locals>.fooT)parallelzvoid(float64[:])z(m))r  r(   r  r   r   r   )r>   ru  r7   r7   r8   test_is_jitted  s    zTestMisc.test_is_jittedc                 C   s@   t dd }t dd }| | |  | | |  d S )Nc                   S   s   t jdddjS )Nr     )r   
fill_valuer}   fullr   r7   r7   r7   r8   standard_order  s    z?TestMisc.test_overload_glue_arg_binding.<locals>.standard_orderc                   S   s   t jdddjS )Nr  r   )r  r   r  r7   r7   r7   r8   reversed_order  s    z?TestMisc.test_overload_glue_arg_binding.<locals>.reversed_order)r   r  r  )r>   r  r  r7   r7   r8   test_overload_glue_arg_binding  s    

z'TestMisc.test_overload_glue_arg_bindingN)r4   r5   r6   r  r  r7   r7   r7   r8   r    s   r  c                   @   s   e Zd Zdd Zdd ZdS )TestOverloadPreferLiteralc                    s   dd dd  dd }t dd| t  | tfd	d
}|d\}}}| |d | |d | |d t fdd}|d\}}}| |d | |d | |d d S )Nc                 S   s   d S rC   r7   rb   r7   r7   r8   
prefer_lit  s    z;TestOverloadPreferLiteral.test_overload.<locals>.prefer_litc                 S   s   d S rC   r7   rb   r7   r7   r8   non_lit  s    z8TestOverloadPreferLiteral.test_overload.<locals>.non_litc                 S   s>   t | tjr.| jdkr"dd }|S tdndd }|S d S )Nr/   c                 S   s   dS r  r7   rb   r7   r7   r8   rq    s    zATestOverloadPreferLiteral.test_overload.<locals>.ov.<locals>.implliteral valuec                 S   s   | d S Nd   r7   rb   r7   r7   r8   rq    s    r;   r   ZIntegerLiteralZliteral_valuer	   r   r  r7   r7   r8   ov  s    
z3TestOverloadPreferLiteral.test_overload.<locals>.ovTZprefer_literalc                    s    d d | fS Nr/   ro   r7   rb   )r  r7   r8   check_prefer_lit  s    zATestOverloadPreferLiteral.test_overload.<locals>.check_prefer_litr'  r     ,  c                    s    d d | fS r  r7   rb   )r  r7   r8   check_non_lit  s    z>TestOverloadPreferLiteral.test_overload.<locals>.check_non_litr  )r   r   r-  r>   r  r  r   rn  rG   r  r7   )r  r  r8   test_overload  s"    z'TestOverloadPreferLiteral.test_overloadc                 C   s   dd }t tddd| t tddd| tdd	 }|t d
\}}}| |d | |d | |d tdd }|t d
\}}}| |d | |d | |d d S )Nc                 S   s>   t |tjr.|jdkr"dd }|S tdndd }|S d S )Nr/   c                 S   s   dS r  r7   r>   rc   r7   r7   r8   rq    s    zHTestOverloadPreferLiteral.test_overload_method.<locals>.ov.<locals>.implr  c                 S   s   |d S r  r7   r  r7   r7   r8   rq    s    r  )r>   rc   rq  r7   r7   r8   r    s    
z:TestOverloadPreferLiteral.test_overload_method.<locals>.ovmethod_prefer_literalTr  method_non_literalFc                 S   s   |  d|  d|  |fS r  )r  r>  rc   r7   r7   r8   r    s    zHTestOverloadPreferLiteral.test_overload_method.<locals>.check_prefer_litr'  r  r  r  c                 S   s   |  d|  d|  |fS r  )r  r  r7   r7   r8   r    s    zETestOverloadPreferLiteral.test_overload_method.<locals>.check_non_litr  r  r  r7   r7   r8   test_overload_method  s6      

z.TestOverloadPreferLiteral.test_overload_methodN)r4   r5   r6   r  r  r7   r7   r7   r8   r    s   *r  __main__)N)rp   r   rS  r  r  r  rx  Zdistutils.versionr   r+  Znumpyr}   Znumbar   r   r   r   r   Z
numba.corer   r	   r
   r   r   Znumba.core.typed_passesr   Znumba.core.registryr   Znumba.core.compilerr   Znumba.core.imputilsr   Znumba.tests.supportr   r   r   r   r   r   Znumba.core.errorsr   r/  Znumba.extendingr   r   r   r   r   r   r   r   r    r!   r"   r#   r$   r%   r&   r'   r(   r)   Znumba.core.typing.templatesr*   r+   r,   r-   r.   Zpdlike_usecaser0   r1   Zscipy__version__r0  Zscipy.special.cython_specialspecialZcython_specialr*  rX   r2   rY   r9   rD   rB   rZ   rH   r<   rL   rM   r[   rS   r]   r   rY  Zmydummy_type_2r_   rd   ri   r  re   rn   rg   rs   rt   rx   r|   r~   r   r   r   r   r   r   r   delitemr   getitemr   setitemr   r   r   iaddr   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   Callabler   r  r  r  r
  r  r&  rG  r  r  r  r  r  r#  r4  r6  r8  r:  r;  rI  ru  rv  r  r  r4   mainr7   r7   r7   r8   <module>   sF   P






	





1

	

	
	



"


4a    	( Y#   
  
  
  
@ h_
