o
    i                     @   s2  d dl Z d dlZd dlZd dlZd dlmZmZ d dlm	Z	m
Z
mZ d dlmZmZ d dlmZ d dlmZ d dlmZ d dlmZmZ d d	lmZmZmZmZ d d
lmZ d dlmZm Z m!Z!m"Z"m#Z#m$Z$m%Z%m&Z&m'Z'm(Z(m)Z) d dl*m+Z+ d dl,m-Z- d dl.Z.dd Z/dd Z0dd Z1dd Z2dd Z3dd Z4dd Z5dd Z6dd Z7d d! Z8d"d# Z9d$d% Z:e; Z<d&d' Z=ej>Z?G d(d) d)e Z@G d*d+ d+e ZAG d,d- d-eAZBG d.d/ d/eAZCd0d1 ZDd2d3 ZEG d4d5 d5ee ZFd6d7 ZGd8d9 ZHG d:d; d;ee ZIG d<d= d=eAZJG d>d? d?e ZKeLd@kre.M  dS dS )A    N)find_setupwithswith_lifting)bypass_contextcall_contextobjmode_context)FunctionIdentityByteCode)Interpreter)errors)
cpu_target)
compile_irDEFAULT_FLAGS)njittypeofobjmodetypes)overload)
MemoryLeakTestCasecaptured_stdoutskip_unless_scipy
linux_onlystrace_supportedstraceexpected_failure_py311expected_failure_py312expected_failure_py313expected_failure_py314)	PYVERSION)jitclassc                 C   s*   t | }t|d}t|}||}|S )N)func_id)r   from_functionr   r	   	interpret)funcr    bcinterpfunc_ir r'   Z/home/ubuntu/transcripts/venv/lib/python3.10/site-packages/numba/tests/test_withlifting.pyget_func_ir   s
   


r)   c                   C   sF   t d t t d t  W d    n1 sw   Y  t d d S )NABCprintr   br'   r'   r'   r(   lift1$   s   r0   c                  C   s   d} t d|  d} t t d|  | d7 } t  W d    n1 s"w   Y  | d7 } t t d|  t  | d7 } W d    n1 sDw   Y  | d7 } t d|  d S )N   r*   r+   d   r,   
   Dr-   xr'   r'   r(   lift2,   s    



r7   c               	   C   s   d} d}t d| | t0 t d t  | d7 } t t d |d7 }t  W d    n1 s0w   Y  W d    n1 s?w   Y  | d7 } |d7 }t d| | d S )Nr1   r2   r*   r+   r,   i r4   r-   r6   yr'   r'   r(   lift3=   s"   r:   c               
   C   s   d} t d|  | d7 } t7 t d t  | d7 } tdD ]}t t d t  | |7 } W d    n1 s7w   Y  qW d    n1 sGw   Y  t t d t  | r\| d9 } W d    n1 sfw   Y  | d7 } t d|  d S )	Nr   r*   r3   r+   r1   r,   r4   E)r.   r   r/   ranger6   ir'   r'   r(   lift4N   s2   

	r?   c                   C   s   t d d S )Nr*   r.   r'   r'   r'   r(   lift5d      rA   c                  C   sH   d} t d|  t | d7 } W d    n1 sw   Y  t d|  | S )Nr1   r*   r+   r.   r   r5   r'   r'   r(   	liftcall1h   s   


rD   c                  C   s~   d} t d|  t | d7 } W d    n1 sw   Y  t d|  t | d7 } W d    n1 s3w   Y  t d|  | S )Nr1   r*   r+   r3   r,   rC   r5   r'   r'   r(   	liftcall2q   s   




rE   c                  C   s   d} t d|  t | dkr| d7 } W d    n1 sw   Y  t d|  t tdD ]}| |7 } q-W d    n1 s>w   Y  t d|  | S )Nr1   r*   r   r+   r3   r,   )r.   r   r<   r=   r'   r'   r(   	liftcall3}   s   



rF   c                	   C   s^   t # t  W d    n1 sw   Y  W d    d S W d    d S 1 s(w   Y  d S N)r   r'   r'   r'   r(   	liftcall4   s   "rH   c               	   C   sb   t dD ]*} t t|  | dkrtd 	 W d     | S W d    n1 s)w   Y  q| S )Nr3      r*   )r<   r   r.   )r>   r'   r'   r(   	liftcall5   s   rJ   c                   C   *   t 	 W d    d S 1 sw   Y  d S rG   )undefined_global_varr'   r'   r'   r(   lift_undefiend      "rM   c                   C   rK   rG   )bogus_contextmanagerr'   r'   r'   r(   lift_invalid   rN   rP   c                   @   <   e Zd Zdd Zdd Zdd Zdd Zd	d
 Zdd ZdS )TestWithFindingc                 C   s(   t |}tt|d }| || d S Nr   )r)   lenr   assertEqual)selfr#   expect_countthe_irctr'   r'   r(   check_num_of_with   s   z!TestWithFinding.check_num_of_withc                 C      | j tdd d S Nr1   rW   )rZ   r0   rV   r'   r'   r(   
test_lift1      zTestWithFinding.test_lift1c                 C   r[   N   r]   )rZ   r7   r^   r'   r'   r(   
test_lift2   r`   zTestWithFinding.test_lift2c                 C   r[   r\   )rZ   r:   r^   r'   r'   r(   
test_lift3   r`   zTestWithFinding.test_lift3c                 C   r[   ra   )rZ   r?   r^   r'   r'   r(   
test_lift4   r`   zTestWithFinding.test_lift4c                 C   r[   )Nr   r]   )rZ   rA   r^   r'   r'   r(   
test_lift5   r`   zTestWithFinding.test_lift5N)	__name__
__module____qualname__rZ   r_   rc   rd   re   rf   r'   r'   r'   r(   rR      s    rR   c                       s.   e Zd Z fddZdd Zd	ddZ  ZS )
BaseTestWithLiftingc                    s(   t t|   tj| _tj| _t| _	d S rG   )
superrj   setUpr   typing_context	typingctxtarget_context	targetctxr   flagsr^   	__class__r'   r(   rl      s   
zBaseTestWithLifting.setUpc           	      C   s   t |}t|| j| j| ji d\}}| t|| | |}t }|	  W d    n1 s1w   Y  | |
 | d S Nlocals)r)   r   rn   rp   rq   rU   rT   r   r   entry_pointgetvalue)	rV   r#   rW   expected_stdoutrX   new_ir	extractedcresoutr'   r'   r(   check_extracted_with   s   


z(BaseTestWithLifting.check_extracted_withr'   Nc              	   C   s(   | j }| j}| j}t||||||i dS rt   )rn   rp   rq   r   )rV   rX   argsreturn_typern   rp   rq   r'   r'   r(   r      s   
zBaseTestWithLifting.compile_ir)r'   N)rg   rh   ri   rl   r~   r   __classcell__r'   r'   rr   r(   rj      s    rj   c                   @   s4   e Zd Zdd Zdd Zdd Zdd Zd	d
 ZdS )TestLiftByPassc                 C      | j tddd d S )Nr1   zA
C
rW   ry   )r~   r0   r^   r'   r'   r(   r_         
zTestLiftByPass.test_lift1c                 C   r   )Nrb   zA 1
D 3
r   )r~   r7   r^   r'   r'   r(   rc      r   zTestLiftByPass.test_lift2c                 C   r   )Nr1   zA 1 100
D 2 101
r   )r~   r:   r^   r'   r'   r(   rd      r   zTestLiftByPass.test_lift3c                 C   r   )Nrb   z	A 0
E 11
r   )r~   r?   r^   r'   r'   r(   re      r   zTestLiftByPass.test_lift4c                 C   r   )Nr   zA
r   )r~   rA   r^   r'   r'   r(   rf      r   zTestLiftByPass.test_lift5N)rg   rh   ri   r_   rc   rd   re   rf   r'   r'   r'   r(   r      s    r   c                   @   sL   e Zd Zdd Zdd Zdd Zdd Zd	d
 Zee	e
edd ZdS )TestLiftCallc                 C   sx   t |}t }|  W d   n1 sw   Y  t }|  W d   n1 s+w   Y  | | |  dS )z2Ensure same semantic with non-jitted code
        N)r   r   rU   rx   )rV   r#   jittedgotexpectr'   r'   r(   check_same_semantic   s   z TestLiftCall.check_same_semanticc                 C      | j tddd | t d S )Nr1   zA 1
B 2
r   )r~   rD   r   r^   r'   r'   r(   test_liftcall1     zTestLiftCall.test_liftcall1c                 C   r   )Nrb   zA 1
B 2
C 12
r   )r~   rE   r   r^   r'   r'   r(   test_liftcall2  r   zTestLiftCall.test_liftcall2c                 C   r   )Nrb   zA 1
B 2
C 47
r   )r~   rF   r   r^   r'   r'   r(   test_liftcall3  r   zTestLiftCall.test_liftcall3c                 C   sb   t jt jt jt jf}| |}tt  W d    n1 sw   Y  d}| |t	|j
 d S )Nz2compiler re-entrant to the same function signature)r
   TypingErrorNumbaRuntimeErrorNumbaValueErrorCompilerErrorassertRaisesr   rH   assertInstr	exception)rV   acceptraisesmsgr'   r'   r(   test_liftcall4  s   zTestLiftCall.test_liftcall4c                 C   r   )Nr1   z0
1
2
3
4
5
A
r   )r~   rJ   r   r^   r'   r'   r(   test_liftcall5  s   zTestLiftCall.test_liftcall5N)rg   rh   ri   r   r   r   r   r   r   r   r   r   r   r'   r'   r'   r(   r      s    
r   c                        fdd}|S )Nc                    X   |  tj} | g|R i | W d    n1 sw   Y  | dt|j d S )NzDoes not support list typer   r
   r   r   r   r   rV   r   kwargsr   fnr'   r(   core'     z+expected_failure_for_list_arg.<locals>.corer'   r   r   r'   r   r(   expected_failure_for_list_arg&     r   c                    r   )Nc                    r   )NzDoes not support function typer   r   r   r'   r(   r   0  r   z/expected_failure_for_function_arg.<locals>.corer'   r   r'   r   r(   !expected_failure_for_function_arg/  r   r   c                   @   s  e 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
edd Zdd Zedd Zdd Zedd Zdd Zdd Zdd  Zd!d" Zd#d$ Zd%d& Zed'd( Zd)d* Zd+d, Zd-d. Zd/d0 Zejd1d2 Zed3d4 Z d5d6 Z!e"d7d8 Z#e$e%e&e'd9d: Z(ejd;d< Z)d=d> Z*d?d@ Z+dAdB Z,dCdD Z-dEdF Z.dGdH Z/dIdJ Z0dKdL Z1dMdN Z2dOdP Z3dQdR Z4dSdT Z5dUdV Z6e7dWdX Z8dYdZ Z9d[d\ Z:d]d^ Z;d_d` Z<dadb Z=dcS )dTestLiftObjc                 C      t dtj d S Nerrorwarningssimplefilterr
   NumbaWarningr^   r'   r'   r(   rl   :  r`   zTestLiftObj.setUpc                 C      t   d S rG   r   resetwarningsr^   r'   r'   r(   tearDown=  rB   zTestLiftObj.tearDownc                 G   s   t |}t |}t|}t }|| }| }W d    n1 s$w   Y  |ttt| t }|| }	| }
W d    n1 sIw   Y  | 	||
 | 
||	 d S rG   )copydeepcopyr   r   rx   compiletuplemapr   rU   assertPreciseEqual)rV   pyfuncr   py_argsc_argscfuncstream
expect_res
expect_outgot_resgot_outr'   r'   r(   assert_equal_return_and_stdout@  s   



z*TestLiftObj.assert_equal_return_and_stdoutc                    s<   dd   fdd} fdd}|  |d |  |d d S )Nc                 S   s   t dd| d i d S )Nzival =ivalrb   r@   r   r'   r'   r(   barS     z0TestLiftObj.test_lift_objmode_basic.<locals>.barc                    sB   | d7 } t   |  W d    | d S 1 sw   Y  | d S Nr1   r   r   r   r'   r(   fooV  s   

z0TestLiftObj.test_lift_objmode_basic.<locals>.fooc                    sD   | d7 } t j  |  W d    | d S 1 sw   Y  | d S r   numbar   r   r   r'   r(   foo_nonglobal\  s   

z:TestLiftObj.test_lift_objmode_basic.<locals>.foo_nonglobal{   r   )rV   r   r   r'   r   r(   test_lift_objmode_basicR  s
   z#TestLiftObj.test_lift_objmode_basicc                    (   dd   fdd}d}|  || d S )Nc                 S   s   t d| d i | d9 } d S )Narrrb   r@   )r   r'   r'   r(   r   f  s   z3TestLiftObj.test_lift_objmode_array_in.<locals>.barc                    sL   t | t j}t  | W d    |d S 1 sw   Y  |d S r   )nparangeastypeint64r   )nelemr   r   r'   r(   r   k  s   

z3TestLiftObj.test_lift_objmode_array_in.<locals>.foor3   r   )rV   r   r   r'   r   r(   test_lift_objmode_array_ine  s   z&TestLiftObj.test_lift_objmode_array_inc                    r   )Nc                 S   s   t |  d S rG   r@   r9   r'   r'   r(   r   v  rB   z<TestLiftObj.test_lift_objmode_define_new_unused.<locals>.barc                    sF   t   d|  }t|} | W d    | S 1 sw   Y  | S Nrb   )r   r   r   )r6   r9   ar   r'   r(   r   y  s   


z<TestLiftObj.test_lift_objmode_define_new_unused.<locals>.foor   r   rV   r   argr'   r   r(   #test_lift_objmode_define_new_unusedu  s   z/TestLiftObj.test_lift_objmode_define_new_unusedc                    s@   dd   fdd} fdd}d}|  || |  || d S )Nc                 S      t |  d|  S r   r@   r5   r'   r'   r(   inverse     z<TestLiftObj.test_lift_objmode_return_simple.<locals>.inversec                    s@   t dd  | }W d    | |fS 1 sw   Y  | |fS Nfloat64r   r   r8   r   r'   r(   r     s   

z8TestLiftObj.test_lift_objmode_return_simple.<locals>.fooc                    sB   t jdd  | }W d    | |fS 1 sw   Y  | |fS r   r   r8   r   r'   r(   r     s   

zBTestLiftObj.test_lift_objmode_return_simple.<locals>.foo_nonglobalr   r   )rV   r   r   r   r'   r   r(   test_lift_objmode_return_simple  s   z+TestLiftObj.test_lift_objmode_return_simplec                    s6   dd   fdd}t jddt jd}| || d S )Nc                 S   r   r   r@   r5   r'   r'   r(   r     r   z;TestLiftObj.test_lift_objmode_return_array.<locals>.inversec                    sJ   t ddd  | }t|d }W d    n1 sw   Y  | ||fS )N
float64[:]r   )r9   zr   )r   intr6   r9   r   r   r'   r(   r     s
   
z7TestLiftObj.test_lift_objmode_return_array.<locals>.foor1   r3   dtype)r   r   r   r   r   r'   r   r(   test_lift_objmode_return_array  s   z*TestLiftObj.test_lift_objmode_return_arrayc                 C   s    dd }g d}|  || d S )Nc                 S   sp   t dd' t|  d| d< t|  g d|  }tdd |D }W d    | |fS 1 s/w   Y  | |fS )Nr   r      r   r1   rb      c                 S   s   g | ]}d | qS )r1   r'   ).0r>   r'   r'   r(   
<listcomp>  s    zITestLiftObj.test_lift_objmode_using_list.<locals>.foo.<locals>.<listcomp>)r   r.   r   asarrayr8   r'   r'   r(   r     s   
z5TestLiftObj.test_lift_objmode_using_list.<locals>.foor   r   r   r'   r'   r(   test_lift_objmode_using_list  s   	z(TestLiftObj.test_lift_objmode_using_listc                 C   s   dd }d}|  || d S )Nc                 S   s   t | D ]} q| r| d7 } tdd$ t|  | d8 } t|  t | D ]
}| |7 } t|  q#W d    | S 1 s9w   Y  | S )Nr1   intpr5   )r<   r   r.   r=   r'   r'   r(   r     s    

z4TestLiftObj.test_lift_objmode_var_redef.<locals>.foor   r   r   r'   r'   r(   test_lift_objmode_var_redef  s   z'TestLiftObj.test_lift_objmode_var_redefc                 C   s   dd }|  |g dd d S )Nc                 S   v   || d< t   t|  W d    n1 sw   Y  t   d| | d< t|  W d    | S 1 s4w   Y  | S r   r   r.   r6   r   r'   r'   r(   r        


z=TestLiftObj.test_case01_mutate_list_ahead_of_ctx.<locals>.foor      r   rV   r   r'   r'   r(   $test_case01_mutate_list_ahead_of_ctx  s   z0TestLiftObj.test_case01_mutate_list_ahead_of_ctxc                 C   s(   dd }t g d}| ||d d S )Nc                 S   r   r   r   r   r'   r'   r(   r     r   z>TestLiftObj.test_case02_mutate_array_ahead_of_ctx.<locals>.foor   r   r   arrayr   rV   r   r6   r'   r'   r(   %test_case02_mutate_array_ahead_of_ctx  s   z1TestLiftObj.test_case02_mutate_array_ahead_of_ctxc                 C   s   dd }|  |d d S )Nc                 S   f   t dd g d}W d    n1 sw   Y  t   d|d< W d    |S 1 s,w   Y  |S NzList(int64)r   r   r3   rb   r   r8   r'   r'   r(   r        


z6TestLiftObj.test_case03_create_and_mutate.<locals>.foor1   r   r   r'   r'   r(   test_case03_create_and_mutate  s   z)TestLiftObj.test_case03_create_and_mutatec                 C   h   dd }t g d}t|}| tj}|| W d    n1 s$w   Y  | dt|j d S )Nc                 S   s8   t dd t|  W d    | S 1 sw   Y  | S )Nr   kr   r5   r'   r'   r(   r        

z=TestLiftObj.test_case04_bogus_variable_type_info.<locals>.foor   z1Invalid type annotation on non-outgoing variables)	r   r  r   r   r
   r   r   r   r   rV   r   r6   cfoor   r'   r'   r(   $test_case04_bogus_variable_type_info  s   
z0TestLiftObj.test_case04_bogus_variable_type_infoc                 C   sf   dd }t g d}t|}| t}||}W d    n1 s#w   Y  | dt|j d S )Nc                 S   8   t dd | d }W d    |S 1 sw   Y  |S )Nr   r   y              ?r   r   r'   r'   r(   r     s   

z4TestLiftObj.test_case05_bogus_type_info.<locals>.foor   zXcan't unbox array from PyObject into native value.  The object maybe of a different type)r   r  r   r   	TypeErrorr   r   r   )rV   r   r6   r  r   r   r'   r'   r(   test_case05_bogus_type_info  s   
z'TestLiftObj.test_case05_bogus_type_infoc                 C   sZ   dd }|  tj}t|d W d    n1 sw   Y  d}| t|j| d S )Nc              	   S   sj   t  ( t   t|  W d    n1 sw   Y  W d    | S W d    | S 1 s.w   Y  | S rG   r   r5   r'   r'   r(   r     s   


z3TestLiftObj.test_case06_double_objmode.<locals>.foor   z@During: resolving callee type: type\(ObjModeLiftedWith\(<.*>\)\))r   r
   r   r   assertRegexr   r   )rV   r   r   patr'   r'   r(   test_case06_double_objmode  s   	z&TestLiftObj.test_case06_double_objmodec                 C   sx   dd }t g d}t|}| tj}|| W d    n1 s$w   Y  t|j}| d| | d| d S )Nc                 S   s<   t   d| i}d}W d    n1 sw   Y  | ||fS )Nr   r   r   )r6   tur'   r'   r(   r   )  s
   
z6TestLiftObj.test_case07_mystery_key_error.<locals>.foor   z;Missing type annotation on outgoing variable(s): ['t', 'u']z9Example code: with objmode(t='<add_type_as_string_here>'))	r   r  r   r   r
   r   r   r   r   )rV   r   r6   r  r   exstrr'   r'   r(   test_case07_mystery_key_error'  s   

z)TestLiftObj.test_case07_mystery_key_errorc                    sp   t    fdd}tg d}t|}| t}|| W d    n1 s(w   Y  | t|jd d S )Nc              	      s`   t t| D ]'}t  t|}| | }| |< t d  W d    n1 s(w   Y  q| S )N2)r<   rT   r   r   r.   )r6   r>   r
  vdr'   r(   r   A  s   z8TestLiftObj.test_case08_raise_from_external.<locals>.foor   z'2')	dictr   r  r   r   KeyErrorrU   r   r   r  r'   r  r(   test_case08_raise_from_external<  s   	
z+TestLiftObj.test_case08_raise_from_externalc                 C   r  )Nc                 S   s"   t   t 1 s
w   Y  | S rG   )r   
ValueErrorr5   r'   r'   r(   r   Q  s   z3TestLiftObj.test_case09_explicit_raise.<locals>.foor   zBunsupported control flow due to raise statements inside with block)	r   r  r   r   r
   r   r   r   r   r  r'   r'   r(   test_case09_explicit_raiseP  s   
z&TestLiftObj.test_case09_explicit_raisec                 C   &   dd }t g d}| || d S )Nc                 S   r  r  r   r8   r'   r'   r(   r   c  r  z;TestLiftObj.test_case10_mutate_across_contexts.<locals>.foor   r   r  r'   r'   r(   "test_case10_mutate_across_contexts`  s   z.TestLiftObj.test_case10_mutate_across_contextsc                 C   r#  )Nc                 S   sp   t dd tjg ddd}W d    n1 sw   Y  t   d|d< W d    |S 1 s1w   Y  |S )Nint64[:]r   r   r   r   r3   rb   )r   r   r   r8   r'   r'   r(   r   o  s   

zATestLiftObj.test_case10_mutate_array_across_contexts.<locals>.foor   r   r  r'   r'   r(   (test_case10_mutate_array_across_contextsm     z4TestLiftObj.test_case10_mutate_array_across_contextsc                 C   sf   dd }t g d}t|}| t}|| W d    n1 s#w   Y  | dt|j d S )Nc                 S   s4   t   dd }W d    | S 1 sw   Y  | S )Nc                 S      | d S r   r'   r   r'   r'   r(   r   ~     zLTestLiftObj.test_case11_define_function_in_context.<locals>.foo.<locals>.barr   r6   r   r'   r'   r(   r   |  s   

z?TestLiftObj.test_case11_define_function_in_context.<locals>.foor   z global name 'bar' is not defined)r   r  r   r   	NameErrorr   r   r   r  r'   r'   r(   &test_case11_define_function_in_contextz  s   
z2TestLiftObj.test_case11_define_function_in_contextc                    s2   dd   fdd}t g d}| || d S )Nc                 S   r(  r   r'   r   r'   r'   r(   r     r)  z>TestLiftObj.test_case12_njit_inside_a_objmode_ctx.<locals>.barc                    sJ   t dd t | d}W d    | | S 1 sw   Y  | | S )Nr%  r   r   )r   r   r   r8   r   r'   r(   r     s   
z>TestLiftObj.test_case12_njit_inside_a_objmode_ctx.<locals>.foor   r   r  r'   r   r(   %test_case12_njit_inside_a_objmode_ctx  s   z1TestLiftObj.test_case12_njit_inside_a_objmode_ctxc                 C   s6   dd }|t g d}t jt g d| d S )Nc                 S   s:   t dd | d7 } | W  d    S 1 sw   Y  d S )Nr%  r5   r1   r   r5   r'   r'   r(   r     s   $zCTestLiftObj.test_case14_return_direct_from_objmode_ctx.<locals>.foor   )rb   r   r   )r   r  testingassert_array_equal)rV   r   resultr'   r'   r(   *test_case14_return_direct_from_objmode_ctx  s   z6TestLiftObj.test_case14_return_direct_from_objmode_ctxc                 C   r#  )Nc                    s   d  fdd}|| d S )Nr3   c                    s>   t dd t|  |   W  d    S 1 sw   Y  d S )Nr%  r5   r   r5   jr'   r(   r     s   $zHTestLiftObj.test_case15_close_over_objmode_ctx.<locals>.foo.<locals>.barrb   r'   r*  r'   r2  r(   r     s   z;TestLiftObj.test_case15_close_over_objmode_ctx.<locals>.foor   r   r  r'   r'   r(   "test_case15_close_over_objmode_ctx  s   z.TestLiftObj.test_case15_close_over_objmode_ctxc                    s6   ddl m   fdd}tg d}| || d S )Nr   )sparsec                    sP   t dd t|   | }t|d }W d    |S 1 s!w   Y  |S )Nr   r	  )r   r   )r   r.   
csr_matrixr   r   )r6   spxr
  spr'   r(   r     s   

z>TestLiftObj.test_case16_scipy_call_in_objmode_ctx.<locals>.foor   )scipyr5  r   r  r   r  r'   r8  r(   %test_case16_scipy_call_in_objmode_ctx  s   	z1TestLiftObj.test_case16_scipy_call_in_objmode_ctxc                    s4   dd l   fddtg d}| | d S )Nr   c                    s6   t     W d    d S 1 sw   Y  d S rG   )r   disr5   r<  r   r'   r(   r     s   "z7TestLiftObj.test_case17_print_own_bytecode.<locals>.foor   )r<  r   r  r   )rV   r6   r'   r=  r(   test_case17_print_own_bytecode  s   z*TestLiftObj.test_case17_print_own_bytecodec                 C   s4   dd }t g d}tdd }| ||| d S )Nc                 S   s8   t   | |d  W d    d S 1 sw   Y  d S rS   r   )r#   r6   r'   r'   r(   r     s   "zCTestLiftObj.test_case18_njitfunc_passed_to_objmode_ctx.<locals>.foor   c                 S   r(  )NrI   r'   r  r'   r'   r(   <lambda>  s    zHTestLiftObj.test_case18_njitfunc_passed_to_objmode_ctx.<locals>.<lambda>)r   r  r   r   )rV   r   r6   r   r'   r'   r(   *test_case18_njitfunc_passed_to_objmode_ctx  s   z6TestLiftObj.test_case18_njitfunc_passed_to_objmode_ctxc                    sr    fdd |  tjtjf}t }|tg d W d    n1 s'w   Y  d}| |t|j	 d S )Nc                    sP   t   | dkr	 W d    dS W d    n1 sw   Y   | d }|S )Nr      r1   r   )r6   retr   r'   r(   r     s   z.TestLiftObj.test_case19_recursion.<locals>.foor   zUntyped global name 'foo')
r   r
   r   r   r   r   r  r   r   r   )rV   r   r  r   r'   rC  r(   test_case19_recursion  s   z!TestLiftObj.test_case19_recursionc                 C   r#  )Nc                 S   sV   t jd t j }tdd t j }W d    n1 s w   Y  | | | S Nr   r   r  r   randomseedrandr   r   r'   r'   r(   r     s   
z1TestLiftObj.test_case20_rng_works_ok.<locals>.foor   r   r  r'   r'   r(   test_case20_rng_works_ok  r'  z$TestLiftObj.test_case20_rng_works_okc                 C   r#  )Nc                 S   sb   t jd t j }tdd t jd t j }W d    n1 s&w   Y  | | | S rE  rF  r   r'   r'   r(   r     s   
z6TestLiftObj.test_case21_rng_seed_works_ok.<locals>.foor   r   r  r'   r'   r(   test_case21_rng_seed_works_ok  s   	z)TestLiftObj.test_case21_rng_seed_works_okc                    s:   dd  t  fdd}| | |  | tt d S )Nc                 S   s   t tt|  S rG   )r   r   listreversedtolistr5   r'   r'   r(   r     r   z'TestLiftObj.test_example01.<locals>.barc                     sF   t d} tdd |  |  }W d    |S 1 sw   Y  |S )NrI   zintp[:]r   )r   r   r   r8   r   r'   r(   r     s   

z'TestLiftObj.test_example01.<locals>.foo)r   r   py_funcassertIsr   r   r   r'   r   r(   test_example01   s
   zTestLiftObj.test_example01c                    s<   dd  t  dd }tj fdd}| | d d S )Nc                 S      d S rG   r'   )sr'   r'   r(   r        z1TestLiftObj.test_objmode_in_overload.<locals>.fooc                 S   s   dd }|S )Nc                 S   r  )Nr   r}   r   r   )rS  r}   r'   r'   r(   impl     

zHTestLiftObj.test_objmode_in_overload.<locals>.foo_overload.<locals>.implr'   )rS  rW  r'   r'   r(   foo_overload  s   z:TestLiftObj.test_objmode_in_overload.<locals>.foo_overloadc                      s    dS r   r'   r'   rC  r'   r(   f     z/TestLiftObj.test_objmode_in_overload.<locals>.fr   )r   r   r   rU   )rV   rY  rZ  r'   rC  r(   test_objmode_in_overload  s   
z$TestLiftObj.test_objmode_in_overloadc                 C   s.   t dd }| }| |t | |d d S )Nc                  S   4   t td d} W d    | S 1 sw   Y  | S Nval皙(@)r   gv_typer_  r'   r'   r(   
global_var#     
z8TestLiftObj.test_objmode_gv_variable.<locals>.global_var   )r   assertIsInstancer   rU   )rV   rc  rB  r'   r'   r(   test_objmode_gv_variable"  s
   
z$TestLiftObj.test_objmode_gv_variablec                 C   F   t dd }| tjd |  W d    d S 1 sw   Y  d S )Nc                  S   r]  )Nr_  r   )r   gv_type2r_  r'   r'   r(   rc  /  rd  z>TestLiftObj.test_objmode_gv_variable_error.<locals>.global_varzHError handling objmode argument 'val'. Global 'gv_type2' is not defined.r   assertRaisesRegexr
   r   )rV   rc  r'   r'   r(   test_objmode_gv_variable_error.  s   
"z*TestLiftObj.test_objmode_gv_variable_errorc              	   C   sx   t dd }t dd }||fD ])}| jt|d | }| |t | |d W d    n1 s4w   Y  qd S )Nc                  S   6   t tjd d} W d    | S 1 sw   Y  | S r^  )r   r   r   r_  r'   r'   r(   modattr1=     
z6TestLiftObj.test_objmode_gv_mod_attr.<locals>.modattr1c                  S   s8   t tjjd d} W d    | S 1 sw   Y  | S r^  )r   r   r   r   r_  r'   r'   r(   modattr2C  s   
z6TestLiftObj.test_objmode_gv_mod_attr.<locals>.modattr2r   re  )r   subTestr   rf  r   rU   )rV   rn  rp  r   rB  r'   r'   r(   test_objmode_gv_mod_attr<  s   

z$TestLiftObj.test_objmode_gv_mod_attrc                 C   rh  )Nc                  S   rm  r^  )r   r   THIS_DOES_NOT_EXISTr_  r'   r'   r(   moderrorQ  ro  z<TestLiftObj.test_objmode_gv_mod_attr_error.<locals>.moderrorzQError handling objmode argument 'val'. Getattr cannot be resolved at compile-timerj  rV   rt  r'   r'   r(   test_objmode_gv_mod_attr_errorP  s   
"z*TestLiftObj.test_objmode_gv_mod_attr_errorc                 C   rh  )Nc                  S   sF   t tjtjtjd d} d}d}W d    tS 1 sw   Y  tS )Nv1v2v3ra  )r   r   r   rs  float32r`  rw  r'   r'   r(   rt  ^  s   

zETestLiftObj.test_objmode_gv_mod_attr_error_multiple.<locals>.moderrorzPError handling objmode argument 'v2'. Getattr cannot be resolved at compile-timerj  ru  r'   r'   r(   'test_objmode_gv_mod_attr_error_multiple]  s   
"z3TestLiftObj.test_objmode_gv_mod_attr_error_multiplec                    sH   dd  t  dd }t fdd}| | tdtj d S )Nc                   S   rR  rG   r'   r'   r'   r'   r(   r   n  rT  z>TestLiftObj.test_objmode_closure_type_in_overload.<locals>.fooc                     s   t jd d    fdd} | S )Nc                     B   t  d tdtj} W d    | S 1 sw   Y  | S NrU  r3   r   r   r   r   r   rU  	shrubberyr'   r(   rW  t     
zUTestLiftObj.test_objmode_closure_type_in_overload.<locals>.foo_overload.<locals>.implr   r   rW  r'   r  r(   rY  q  s   zGTestLiftObj.test_objmode_closure_type_in_overload.<locals>.foo_overloadc                           S rG   r'   r'   rC  r'   r(   r   z     z>TestLiftObj.test_objmode_closure_type_in_overload.<locals>.barr3   )r   r   r   r   r   r   r   rV   rY  r   r'   rC  r(   %test_objmode_closure_type_in_overloadm  s   
 z1TestLiftObj.test_objmode_closure_type_in_overloadc                    sb   dd  t  dd }t fdd}| tjd |  W d    d S 1 s*w   Y  d S )Nc                   S   rR  rG   r'   r'   r'   r'   r(   r     rT  zDTestLiftObj.test_objmode_closure_type_in_overload_error.<locals>.fooc                     s    t jd d    fdd}  | S )Nc                     r}  r~  r  rU  r  r'   r(   rW    r  z[TestLiftObj.test_objmode_closure_type_in_overload_error.<locals>.foo_overload.<locals>.implr  r  r'   r  r(   rY    s   zMTestLiftObj.test_objmode_closure_type_in_overload_error.<locals>.foo_overloadc                      r  rG   r'   r'   rC  r'   r(   r     r  zDTestLiftObj.test_objmode_closure_type_in_overload_error.<locals>.barzIError handling objmode argument 'out'. Freevar 'shrubbery' is not defined)r   r   rk  r
   r   r  r'   rC  r(   +test_objmode_closure_type_in_overload_error  s   
"z7TestLiftObj.test_objmode_closure_type_in_overload_errorc                 C   rh  )Nc                  S   s4   t dd d} W d    tS 1 sw   Y  tS )Nrb   )badr1   )r   r`  rU  r'   r'   r(   rt    rd  z6TestLiftObj.test_objmode_invalid_use.<locals>.moderrorzError handling objmode argument 'bad'. The value must be a compile-time constant either as a non-local variable or a getattr expression that refers to a Numba type.rj  ru  r'   r'   r(   test_objmode_invalid_use  s   
"z$TestLiftObj.test_objmode_invalid_usec                    s`   t jd d   t fdd}| \}}}| |d | |d | |tdtj d S )Nc                     sR   t dt d d} | }tdtj}W d    n1 sw   Y  | ||fS )Nr   t1t2t3    :(ArI   )r   rb  r   r   r   int32r  array_tyr'   r(   r     s   
z5TestLiftObj.test_objmode_multi_type_args.<locals>.foor  i  rI   )r   r  r   r   r   r   r   )rV   r   r  r  r  r'   r  r(   test_objmode_multi_type_args  s   
z(TestLiftObj.test_objmode_multi_type_argsc                    s   dt jfdt jd d  fg}t|G dd dt d} |dd t fdd	}tfd
d}| }| |  | |	ddd t
jdt
jdd }| |j| d S )Nvaluer  c                   @   s4   e Zd Zdd Zedd Zdd Zedd Zd	S )
z.TestLiftObj.test_objmode_jitclass.<locals>.Bagc                 S   s   || _ tj|tjd| _d S )Nr   )r  r   zerosr{  r  )rV   r  r'   r'   r(   __init__  s   z7TestLiftObj.test_objmode_jitclass.<locals>.Bag.__init__c                 S   s   | j jS rG   )r  sizer^   r'   r'   r(   r    r[  z3TestLiftObj.test_objmode_jitclass.<locals>.Bag.sizec                 S   s(   t | jD ]}| j|  |7  < q| jS rG   )r<   r  r  )rV   r`  r>   r'   r'   r(   	increment  s   z8TestLiftObj.test_objmode_jitclass.<locals>.Bag.incrementc                 S   s   | | S rG   r'   r8   r'   r'   r(   add  r[  z2TestLiftObj.test_objmode_jitclass.<locals>.Bag.addN)	rg   rh   ri   r  propertyr  r  staticmethodr  r'   r'   r'   r(   Bag  s    
r     c                   S   rR  rG   r'   r'   r'   r'   r(   r     rT  z.TestLiftObj.test_objmode_jitclass.<locals>.fooc                     s   j   fdd} | S )Nc                     sB   t d  d} | d W d    | S 1 sw   Y  | S )NrU  r   r   )r   r  rU  )r  r  r'   r(   rW    s   
zETestLiftObj.test_objmode_jitclass.<locals>.foo_overload.<locals>.impl)_numba_type_r  )r  mybagr  r(   rY    s   z7TestLiftObj.test_objmode_jitclass.<locals>.foo_overloadc                      r  rG   r'   r'   rC  r'   r(   r     r  z.TestLiftObj.test_objmode_jitclass.<locals>.barrb   r   rI   r   r   )r   r  r{  r   objectr   r   rf  rU   r  r   r  r   r  )rV   specnrY  r   r   	exp_arrayr'   )r  r   r  r(   test_objmode_jitclass  s"   	z!TestLiftObj.test_objmode_jitclassc                 C   8   t dd | d }W d    |S 1 sw   Y  |S Nr   outputr3   rV  r6   r  r'   r'   r(   case_objmode_cache  r  zTestLiftObj.case_objmode_cachec                    sd   t g d t fdd}| tj}|  W d    n1 s"w   Y  | t|jd d S )Nr1   rb   r   r   rI   c                     s8   t  d g d} W d    | S 1 sw   Y  | S )NrU  r  rV  rU  ret_typer'   r(   test2  r  z6TestLiftObj.test_objmode_reflected_list.<locals>.test2zObjmode context failed. Argument 'out' is declared as an unsupported type: reflected list\(int(32|64)\)<iv=None>. Reflected types are not supported.r   r   r   r
   r   r  r   r   rV   r  r   r'   r  r(   test_objmode_reflected_list     z'TestLiftObj.test_objmode_reflected_listc                    sd   t h d t fdd}| tj}|  W d    n1 s"w   Y  | t|jd d S )N   r1   rb   r   r   rI   c                     s8   t  d h d} W d    | S 1 sw   Y  | S )Nr0  r  rV  r  r  r'   r(   r  
  r  z5TestLiftObj.test_objmode_reflected_set.<locals>.test2zObjmode context failed. Argument 'result' is declared as an unsupported type: reflected set\(int(32|64)\). Reflected types are not supported.r  r  r'   r  r(   test_objmode_reflected_set  r  z&TestLiftObj.test_objmode_reflected_setc                    sf   t t jt j t fdd}| t}|  W d    n1 s#w   Y  | dt|j	 d S )Nc                     s:   t  d ddd} W d    | S 1 sw   Y  | S )Nresr1   rb   )r*   r+   rV  r  r  r'   r(   test4  s   
z2TestLiftObj.test_objmode_typed_dict.<locals>.test4zFcan't unbox a <class 'dict'> as a <class 'numba.typed.typeddict.Dict'>)
r   DictTypeunicode_typer   r   r   r  r   r   r   rV   r  r   r'   r  r(   test_objmode_typed_dict  s   z#TestLiftObj.test_objmode_typed_dictc                    sb   t t j t fdd}| t}|  W d    n1 s!w   Y  | t|jd d S )Nc                     s8   t  d ddg} W d    | S 1 sw   Y  | S )Nr  r1   rb   rV  r  r  r'   r(   r  ,  r  z2TestLiftObj.test_objmode_typed_list.<locals>.test4zLcan't unbox a <class 'list'> as a (<class ')?numba.typed.typedlist.List('>)?)	r   ListTyper   r   r   r  r  r   r   r  r'   r  r(   test_objmode_typed_list*  s   z#TestLiftObj.test_objmode_typed_listc                 C   sB   t dd }tdtjd}||}||}| || d S )Nc                 S   s<   t jdd | d}W d    |S 1 sw   Y  |S )Nz
int64[::1]r   r   )r   r   viewr8   r'   r'   r(   r   =  s   
z1TestLiftObj.test_objmode_use_of_view.<locals>.foor1   r   )r   r   onesr   r  rO  r   )rV   r   r   expectedr   r'   r'   r(   test_objmode_use_of_view:  s   

z$TestLiftObj.test_objmode_use_of_viewN)>rg   rh   ri   rl   r   r   r   r   r   r   r   r   r   r   r   r  r  r  r  r  r  r   r"  r$  r&  r,  r-  r1  unittestexpectedFailurer4  r   r;  r>  r   r@  r   r   r   r   rD  rJ  rK  rQ  r\  rg  rl  rr  rv  r|  r  r  r  r  r  r  r  r  r  r  r  r  r'   r'   r'   r(   r   8  s~    


	



	
	
4
r   c                 C      | d S Nr3   r'   r5   r'   r'   r(   case_inner_pyfuncI  r)  r  c                 C   s8   t dd t| }W d    |S 1 sw   Y  |S Nr   r  )r   r  r  r'   r'   r(   r  M  rX  r  c                   @   rQ   )TestLiftObjCachingc                 C   r   r   r   r^   r'   r'   r(   rl   V  r`   zTestLiftObjCaching.setUpc                 C   r   rG   r   r^   r'   r'   r(   r   Y  rB   zTestLiftObjCaching.tearDownc                 C   sX   t dd|}| |dd t dd|}| |j | |dd | |j d S )NT)cacher   ra  )r   rU   assertFalse_cache_hits
assertTrue)rV   rO  firstsecondr'   r'   r(   check\  s   zTestLiftObjCaching.checkc                 C   s   dd }|  | d S )Nc                 S   r  r  rV  r  r'   r'   r(   r   f  rX  z=TestLiftObjCaching.test_objmode_caching_basic.<locals>.pyfuncr  rV   r   r'   r'   r(   test_objmode_caching_basice  s   z-TestLiftObjCaching.test_objmode_caching_basicc                    s"   dd   fdd}|  | d S )Nc                 S   r  r  r'   r5   r'   r'   r(   other_pyfuncn  r)  zNTestLiftObjCaching.test_objmode_caching_call_closure_bad.<locals>.other_pyfuncc                    s8   t dd  | }W d    |S 1 sw   Y  |S r  rV  r  r  r'   r(   r   q  rX  zHTestLiftObjCaching.test_objmode_caching_call_closure_bad.<locals>.pyfuncr  r  r'   r  r(   %test_objmode_caching_call_closure_badm  s   z8TestLiftObjCaching.test_objmode_caching_call_closure_badc                 C   s   |  t d S rG   )r  r  r^   r'   r'   r(   &test_objmode_caching_call_closure_goodx  s   z9TestLiftObjCaching.test_objmode_caching_call_closure_goodN)	rg   rh   ri   rl   r   r  r  r  r  r'   r'   r'   r(   r  S  s    	r  c                   @   s$   e Zd Zdd Zdd Zdd ZdS )TestBogusContextc                 C   b   t t}| tj}t|| j| j| ji d W d    n1 s!w   Y  | 	dt
|j d S )Nru   z*Undefined variable used as context manager)r)   rM   r   r
   r   r   rn   rp   rq   r   r   r   rV   rX   r   r'   r'   r(   test_undefined_global~     z&TestBogusContext.test_undefined_globalc                 C   r  )Nru   z"Unsupported context manager in use)r)   rP   r   r
   r   r   rn   rp   rq   r   r   r   r  r'   r'   r(   test_invalid  r  zTestBogusContext.test_invalidc                 C   s\   t dd }| tj}|  W d    n1 sw   Y  t|j}d}| || d S )Nc                  S   s*   t 	} W d    d S 1 sw   Y  d S rG   )r   )bpr'   r'   r(   r     s   "z;TestBogusContext.test_with_as_fails_gracefully.<locals>.foozGThe 'with (context manager) as (variable):' construct is not supported.)r   r   r
   UnsupportedBytecodeErrorr   r   r   )rV   r   r   excstrr   r'   r'   r(   test_with_as_fails_gracefully  s   

z.TestBogusContext.test_with_as_fails_gracefullyN)rg   rh   ri   r  r  r  r'   r'   r'   r(   r  |  s    r  c                   @   s"   e Zd ZdZeejdd ZdS )TestMiscFc                 C   s8   t  s| d dd }g d}t||}| | d S )Nzstrace support missingc                  S   s   t ddd } d S )Nzvoid()c                   S   s.   t  	 W d    d S 1 sw   Y  d S rG   r   r'   r'   r'   r(   rZ    s   
"zFTestMisc.test_no_fork_in_compilation.<locals>.force_compile.<locals>.f)r   )rZ  r'   r'   r(   force_compile  s   z;TestMisc.test_no_fork_in_compilation.<locals>.force_compile)forkcloneexecve)r   skipTestr   r  )rV   r  syscallsstrace_datar'   r'   r(   test_no_fork_in_compilation  s   	

z$TestMisc.test_no_fork_in_compilationN)rg   rh   ri   _numba_parallel_test_r   r   run_test_in_subprocessr  r'   r'   r'   r(   r    s
    r  __main__)Nr   r   numpyr   r   numba.core.transformsr   r   numba.core.withcontextsr   r   r   numba.core.bytecoder   r   numba.core.interpreterr	   
numba.corer
   numba.core.registryr   numba.core.compilerr   r   r   r   r   r   numba.core.extendingr   numba.tests.supportr   r   r   r   r   r   r   r   r   r   r   numba.core.utilsr   numba.experimentalr   r  r)   r0   r7   r:   r?   rA   rD   rE   rF   rH   rJ   rM   r  rO   rP   r   rb  rR   rj   r   r   r   r   r   r  r  r  r  r  rg   mainr'   r'   r'   r(   <module>   sj    4	
1		      )'
 