o
    0 i(                     @   s.  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( d dl)m*Z* d dl+m,Z, d dl-Z-dd Z.dd Z/dd Z0dd Z1dd Z2dd Z3dd Z4dd Z5dd Z6d d! Z7d"d# Z8d$d% Z9e: Z;d&d' Z<ej=Z>G d(d) d)e Z?G d*d+ d+e Z@G d,d- d-e@ZAG d.d/ d/e@ZBd0d1 ZCd2d3 ZDG d4d5 d5ee ZEd6d7 ZFd8d9 ZGG d:d; d;ee ZHG d<d= d=e@ZIG d>d? d?e ZJeKd@kre-L  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)	PYVERSION)jitclassc                 C   s*   t | }t|d}t|}||}|S )N)func_id)r   from_functionr   r	   Z	interpret)funcr   bcZinterpZfunc_ir r#   h/home/app/PaddleOCR-VL-test/.venv_paddleocr/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   r,   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    



r3   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 )Nr-   r.   r&   r'   r(   i r0   r)   r2   yr#   r#   r$   lift3;   s"   r6   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&   r/   r'   r-   r(   r0   E)r*   r   r+   ranger2   ir#   r#   r$   lift4L   s2   

	r;   c                   C   s   t d d S )Nr&   r*   r#   r#   r#   r$   lift5b      r=   c                  C   sH   d} t d|  t | d7 } W d    n1 sw   Y  t d|  | S )Nr-   r&   r'   r*   r   r1   r#   r#   r$   	liftcall1f   s   


r@   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 )Nr-   r&   r'   r/   r(   r?   r1   r#   r#   r$   	liftcall2o   s   




rA   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 )Nr-   r&   r   r'   r/   r(   )r*   r   r8   r9   r#   r#   r$   	liftcall3{   s   



rB   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   "rD   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 )Nr/      r&   )r8   r   r*   )r:   r#   r#   r$   	liftcall5   s   rF   c                   C   *   t 	 W d    d S 1 sw   Y  d S rC   )Zundefined_global_varr#   r#   r#   r$   lift_undefiend      "rH   c                   C   rG   rC   )bogus_contextmanagerr#   r#   r#   r$   lift_invalid   rI   rK   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 Nr-   rR   )rU   r,   rQ   r#   r#   r$   
test_lift1      zTestWithFinding.test_lift1c                 C   rV   N   rX   )rU   r3   rY   r#   r#   r$   
test_lift2   r[   zTestWithFinding.test_lift2c                 C   rV   rW   )rU   r6   rY   r#   r#   r$   
test_lift3   r[   zTestWithFinding.test_lift3c                 C   rV   r\   )rU   r;   rY   r#   r#   r$   
test_lift4   r[   zTestWithFinding.test_lift4c                 C   rV   )Nr   rX   )rU   r=   rY   r#   r#   r$   
test_lift5   r[   zTestWithFinding.test_lift5N)	__name__
__module____qualname__rU   rZ   r^   r_   r`   ra   r#   r#   r#   r$   rM      s    rM   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 rC   )
superre   setUpr   Ztyping_context	typingctxZtarget_context	targetctxr   flagsrY   	__class__r#   r$   rg      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   rh   ri   rj   rP   rO   r   r   entry_pointgetvalue)	rQ   r!   rR   expected_stdoutrS   Znew_irZ	extractedZcresoutr#   r#   r$   check_extracted_with   s   


z(BaseTestWithLifting.check_extracted_withr#   Nc              	   C   s(   | j }| j}| j}t||||||i dS rm   )rh   ri   rj   r   )rQ   rS   argsreturn_typerh   ri   rj   r#   r#   r$   r      s   
zBaseTestWithLifting.compile_ir)r#   N)rb   rc   rd   rg   rt   r   __classcell__r#   r#   rk   r$   re      s    re   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 )Nr-   zA
C
rR   rr   )rt   r,   rY   r#   r#   r$   rZ         
zTestLiftByPass.test_lift1c                 C   ry   )Nr]   zA 1
D 3
rz   )rt   r3   rY   r#   r#   r$   r^      r{   zTestLiftByPass.test_lift2c                 C   ry   )Nr-   zA 1 100
D 2 101
rz   )rt   r6   rY   r#   r#   r$   r_      r{   zTestLiftByPass.test_lift3c                 C   ry   )Nr]   z	A 0
E 11
rz   )rt   r;   rY   r#   r#   r$   r`      r{   zTestLiftByPass.test_lift4c                 C   ry   )Nr   zA
rz   )rt   r=   rY   r#   r#   r$   ra      r{   zTestLiftByPass.test_lift5N)rb   rc   rd   rZ   r^   r_   r`   ra   r#   r#   r#   r$   rx      s    rx   c                   @   sH   e Zd Zdd Zdd Zdd Zdd Zd	d
 Z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   rP   rq   )rQ   r!   Zjittedgotexpectr#   r#   r$   check_same_semantic   s   z TestLiftCall.check_same_semanticc                 C      | j tddd | t d S )Nr-   zA 1
B 2
rz   )rt   r@   r   rY   r#   r#   r$   test_liftcall1     zTestLiftCall.test_liftcall1c                 C   r   )Nr]   zA 1
B 2
C 12
rz   )rt   rA   r   rY   r#   r#   r$   test_liftcall2  r   zTestLiftCall.test_liftcall2c                 C   r   )Nr]   zA 1
B 2
C 47
rz   )rt   rB   r   rY   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
   TypingErrorZNumbaRuntimeErrorZNumbaValueErrorCompilerErrorassertRaisesr   rD   assertInstr	exception)rQ   acceptraisesmsgr#   r#   r$   test_liftcall4  s   zTestLiftCall.test_liftcall4c                 C   r   )Nr-   z0
1
2
3
4
5
A
rz   )rt   rF   r   rY   r#   r#   r$   test_liftcall5  s   zTestLiftCall.test_liftcall5N)rb   rc   rd   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   rQ   ru   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   -  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&d9d: Z'ejd;d< Z(d=d> Z)d?d@ Z*dAdB Z+dCdD Z,dEdF Z-dGdH Z.dIdJ Z/dKdL Z0dMdN Z1dOdP Z2dQdR Z3dSdT Z4dUdV Z5e6dWdX Z7dYdZ Z8d[d\ Z9d]d^ Z:d_d` Z;dadb Z<dcS )dTestLiftObjc                 C      t dtj d S Nerrorwarningssimplefilterr
   ZNumbaWarningrY   r#   r#   r$   rg   7  r[   zTestLiftObj.setUpc                 C      t   d S rC   r   resetwarningsrY   r#   r#   r$   tearDown:  r>   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 rC   )copydeepcopyr   r   rq   compiletuplemapr   rP   assertPreciseEqual)rQ   pyfuncru   Zpy_argsZc_argsZcfuncstreamZ
expect_resZ
expect_outZgot_resZ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 =ivalr]   r<   r   r#   r#   r$   barP     z0TestLiftObj.test_lift_objmode_basic.<locals>.barc                    sB   | d7 } t   |  W d    | d S 1 sw   Y  | d S Nr-   r   r   r   r#   r$   fooS  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_nonglobalY  s   

z:TestLiftObj.test_lift_objmode_basic.<locals>.foo_nonglobal{   r   )rQ   r   r   r#   r   r$   test_lift_objmode_basicO  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arrr]   r<   )r   r#   r#   r$   r   c  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   h  s   

z3TestLiftObj.test_lift_objmode_array_in.<locals>.foor/   r   )rQ   r   r   r#   r   r$   test_lift_objmode_array_inb  s   z&TestLiftObj.test_lift_objmode_array_inc                    r   )Nc                 S   s   t |  d S rC   r<   r5   r#   r#   r$   r   s  r>   z<TestLiftObj.test_lift_objmode_define_new_unused.<locals>.barc                    sF   t   d|  }t|} | W d    | S 1 sw   Y  | S Nr]   )r   r   r   )r2   r5   ar   r#   r$   r   v  s   


z<TestLiftObj.test_lift_objmode_define_new_unused.<locals>.foor   r   rQ   r   argr#   r   r$   #test_lift_objmode_define_new_unusedr  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<   r1   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   r4   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   r4   r   r#   r$   r     s   

zBTestLiftObj.test_lift_objmode_return_simple.<locals>.foo_nonglobalr   r   )rQ   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<   r1   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   )r5   zr   )r   intr2   r5   r   r   r#   r$   r     s
   
z7TestLiftObj.test_lift_objmode_return_array.<locals>.foor-   r/   Z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   r-   r]      c                 S   s   g | ]}d | qS )r-   r#   ).0r:   r#   r#   r$   
<listcomp>  s    zITestLiftObj.test_lift_objmode_using_list.<locals>.foo.<locals>.<listcomp>)r   r*   r   asarrayr4   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 )Nr-   intpr1   )r8   r   r*   r9   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*   r2   r   r#   r#   r$   r        


z=TestLiftObj.test_case01_mutate_list_ahead_of_ctx.<locals>.foor      r   rQ   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   rQ   r   r2   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   r/   r]   r   r4   r#   r#   r$   r        


z6TestLiftObj.test_case03_create_and_mutate.<locals>.foor-   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   r1   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   rQ   r   r2   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   )rQ   r   r2   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 rC   r   r1   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   )rQ   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   )r2   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   )rQ   r   r2   r   r   Z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)r8   rO   r   r   r*   )r2   r:   r   vdr#   r$   r   >  s   z8TestLiftObj.test_case08_raise_from_external.<locals>.foor   z'2')	dictr   r   r   r   KeyErrorrP   r   r   r   r#   r  r$   test_case08_raise_from_external9  s   	
z+TestLiftObj.test_case08_raise_from_externalc                 C   r   )Nc                 S   s"   t   t 1 s
w   Y  | S rC   )r   
ValueErrorr1   r#   r#   r$   r   N  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_raiseM  s   
z&TestLiftObj.test_case09_explicit_raisec                 C   &   dd }t g d}| || d S )Nc                 S   r   r   r   r4   r#   r#   r$   r   `  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   r/   r]   )r   r   r   r4   r#   r#   r$   r   l  s   

zATestLiftObj.test_case10_mutate_array_across_contexts.<locals>.foor   r   r   r#   r#   r$   (test_case10_mutate_array_across_contextsj     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   r2   r   r#   r#   r$   r   y  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_contextw  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   r4   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  r1   r-   r   r1   r#   r#   r$   r     s   $zCTestLiftObj.test_case14_return_direct_from_objmode_ctx.<locals>.foor   )r]   r   r   )r   r   testingZassert_array_equal)rQ   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 )Nr/   c                    s>   t dd t|  |   W  d    S 1 sw   Y  d S )Nr  r1   r   r1   jr#   r$   r     s   $zHTestLiftObj.test_case15_close_over_objmode_ctx.<locals>.foo.<locals>.barr]   r#   r  r#   r  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*   Z
csr_matrixr   r   )r2   Zspxr   spr#   r$   r     s   

z>TestLiftObj.test_case16_scipy_call_in_objmode_ctx.<locals>.foor   )Zscipyr  r   r   r   r   r#   r  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 rC   )r   disr1   r!  r   r#   r$   r     s   "z7TestLiftObj.test_case17_print_own_bytecode.<locals>.foor   )r!  r   r   r   )rQ   r2   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 rN   r   )r!   r2   r#   r#   r$   r     s   "zCTestLiftObj.test_case18_njitfunc_passed_to_objmode_ctx.<locals>.foor   c                 S   r  )NrE   r#   r   r#   r#   r$   <lambda>  s    zHTestLiftObj.test_case18_njitfunc_passed_to_objmode_ctx.<locals>.<lambda>)r   r   r   r   )rQ   r   r2   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      r-   r   )r2   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   )rQ   r   r   r   r#   r(  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seedZ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 r*  r+  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 rC   )r   r   listreversedtolistr1   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 )NrE   zintp[:]r   )r   r   r   r4   r   r#   r$   r     s   

z'TestLiftObj.test_example01.<locals>.foo)r   r   py_funcZ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 rC   r#   )sr#   r#   r$   r        z1TestLiftObj.test_objmode_in_overload.<locals>.fooc                 S   s   dd }|S )Nc                 S   r   )Nr   rs   r   r   )r6  rs   r#   r#   r$   impl     

zHTestLiftObj.test_objmode_in_overload.<locals>.foo_overload.<locals>.implr#   )r6  r:  r#   r#   r$   foo_overload  s   z:TestLiftObj.test_objmode_in_overload.<locals>.foo_overloadc                      s    dS r   r#   r#   r(  r#   r$   f     z/TestLiftObj.test_objmode_in_overload.<locals>.fr   )r   r   r   rP   )rQ   r<  r=  r#   r(  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_typerB  r#   r#   r$   
global_var     
z8TestLiftObj.test_objmode_gv_variable.<locals>.global_var   )r   assertIsInstancer   rP   )rQ   rF  r'  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@  )NrB  r   )r   Zgv_type2rB  r#   r#   r$   rF  +  rG  z>TestLiftObj.test_objmode_gv_variable_error.<locals>.global_varzHError handling objmode argument 'val'. Global 'gv_type2' is not defined.r   assertRaisesRegexr
   r   )rQ   rF  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 rA  )r   r   r   rB  r#   r#   r$   modattr19     
z6TestLiftObj.test_objmode_gv_mod_attr.<locals>.modattr1c                  S   s8   t tjjd d} W d    | S 1 sw   Y  | S rA  )r   r   r   r   rB  r#   r#   r$   modattr2?  s   
z6TestLiftObj.test_objmode_gv_mod_attr.<locals>.modattr2r   rH  )r   ZsubTestr   rI  r   rP   )rQ   rP  rR  r   r'  r#   r#   r$   test_objmode_gv_mod_attr8  s   

z$TestLiftObj.test_objmode_gv_mod_attrc                 C   rK  )Nc                  S   rO  rA  )r   r   THIS_DOES_NOT_EXISTrB  r#   r#   r$   moderrorM  rQ  z<TestLiftObj.test_objmode_gv_mod_attr_error.<locals>.moderrorzQError handling objmode argument 'val'. Getattr cannot be resolved at compile-timerL  rQ   rU  r#   r#   r$   test_objmode_gv_mod_attr_errorL  s   
"z*TestLiftObj.test_objmode_gv_mod_attr_errorc                 C   rK  )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v2Zv3rD  )r   r   r   rT  float32rC  rX  r#   r#   r$   rU  Z  s   

zETestLiftObj.test_objmode_gv_mod_attr_error_multiple.<locals>.moderrorzPError handling objmode argument 'v2'. Getattr cannot be resolved at compile-timerL  rV  r#   r#   r$   'test_objmode_gv_mod_attr_error_multipleY  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   r5  rC   r#   r#   r#   r#   r$   r   j  r7  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 Nr8  r/   r   r   r   r   r   r8  	shrubberyr#   r$   r:  p     
zUTestLiftObj.test_objmode_closure_type_in_overload.<locals>.foo_overload.<locals>.implr   r   r:  r#   r`  r$   r<  m  s   zGTestLiftObj.test_objmode_closure_type_in_overload.<locals>.foo_overloadc                           S rC   r#   r#   r(  r#   r$   r   v     z>TestLiftObj.test_objmode_closure_type_in_overload.<locals>.barr/   )r   r   r   r   r   r   r   rQ   r<  r   r#   r(  r$   %test_objmode_closure_type_in_overloadi  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   r5  rC   r#   r#   r#   r#   r$   r   }  r7  zDTestLiftObj.test_objmode_closure_type_in_overload_error.<locals>.fooc                     s    t jd d    fdd}  | S )Nc                     r]  r^  r_  r8  r`  r#   r$   r:    rb  z[TestLiftObj.test_objmode_closure_type_in_overload_error.<locals>.foo_overload.<locals>.implrc  rd  r#   r`  r$   r<    s   zMTestLiftObj.test_objmode_closure_type_in_overload_error.<locals>.foo_overloadc                      re  rC   r#   r#   r(  r#   r$   r     rf  zDTestLiftObj.test_objmode_closure_type_in_overload_error.<locals>.barzIError handling objmode argument 'out'. Freevar 'shrubbery' is not defined)r   r   rM  r
   r   rg  r#   r(  r$   +test_objmode_closure_type_in_overload_error|  s   
"z7TestLiftObj.test_objmode_closure_type_in_overload_errorc                 C   rK  )Nc                  S   s4   t dd d} W d    tS 1 sw   Y  tS )Nr]   )badr-   )r   rC  r8  r#   r#   r$   rU    rG  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.rL  rV  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    :(ArE   )r   rE  r   r   r   int32rl  Zarray_tyr#   r$   r     s   
z5TestLiftObj.test_objmode_multi_type_args.<locals>.foorp  i  rE   )r   rq  r   r   r   r   r   )rQ   r   rm  rn  ro  r#   rr  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   )rt  r   zerosr[  r   )rQ   rt  r#   r#   r$   __init__  s   z7TestLiftObj.test_objmode_jitclass.<locals>.Bag.__init__c                 S   s   | j jS rC   )r   sizerY   r#   r#   r$   rw    r>  z3TestLiftObj.test_objmode_jitclass.<locals>.Bag.sizec                 S   s(   t | jD ]}| j|  |7  < q| jS rC   )r8   rw  r   )rQ   rC  r:   r#   r#   r$   	increment  s   z8TestLiftObj.test_objmode_jitclass.<locals>.Bag.incrementc                 S   s   | | S rC   r#   r4   r#   r#   r$   add  r>  z2TestLiftObj.test_objmode_jitclass.<locals>.Bag.addN)	rb   rc   rd   rv  propertyrw  rx  staticmethodry  r#   r#   r#   r$   Bag  s    
r|     c                   S   r5  rC   r#   r#   r#   r#   r$   r     r7  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 )Nr8  r   r   )r   rx  r8  )r|  ra  r#   r$   r:    s   
zETestLiftObj.test_objmode_jitclass.<locals>.foo_overload.<locals>.impl)Z_numba_type_rd  )r|  mybagr`  r$   r<    s   z7TestLiftObj.test_objmode_jitclass.<locals>.foo_overloadc                      re  rC   r#   r#   r(  r#   r$   r     rf  z.TestLiftObj.test_objmode_jitclass.<locals>.barr]   r   rE   r   r   )r   rq  r[  r   objectr   r   rI  rP   ry  r   ru  r   r   )rQ   specnr<  r   r   Z	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   outputr/   r9  r2   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r-   r]   r   r   rE   c                     s8   t  d g d} W d    | S 1 sw   Y  | S )Nr8  r  r9  r8  Z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   rQ   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   r-   r]   r   r   rE   c                     s8   t  d h d} W d    | S 1 sw   Y  | S )Nr  r  r9  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resr-   r]   )r&   r'   r9  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   ZDictTypeZunicode_typer   r   r   r   r   r   r   rQ   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  r-   r]   r9  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   Z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   viewr4   r#   r#   r$   r   9  s   
z1TestLiftObj.test_objmode_use_of_view.<locals>.foor-   r   )r   r   Zonesr   r  r3  r   )rQ   r   r   expectedr}   r#   r#   r$   test_objmode_use_of_view6  s   

z$TestLiftObj.test_objmode_use_of_viewN)=rb   rc   rd   rg   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r  r	  r  r  r  r  r  r  unittestZexpectedFailurer  r   r   r#  r   r%  r   r   r   r)  r.  r/  r4  r?  rJ  rN  rS  rW  r\  rh  ri  rk  rs  r  r{  r  r  r  r  r  r  r#   r#   r#   r$   r   5  s|    


	



	
	
4
r   c                 C      | d S Nr/   r#   r1   r#   r#   r$   case_inner_pyfuncE  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  I  r;  r  c                   @   rL   )TestLiftObjCachingc                 C   r   r   r   rY   r#   r#   r$   rg   R  r[   zTestLiftObjCaching.setUpc                 C   r   rC   r   rY   r#   r#   r$   r   U  r>   zTestLiftObjCaching.tearDownc                 C   sX   t dd|}| |dd t dd|}| |j | |dd | |j d S )NT)cacher   rD  )r   rP   assertFalseZ_cache_hits
assertTrue)rQ   r3  firstsecondr#   r#   r$   checkX  s   zTestLiftObjCaching.checkc                 C   s   dd }|  | d S )Nc                 S   r  r  r9  r  r#   r#   r$   r   b  r;  z=TestLiftObjCaching.test_objmode_caching_basic.<locals>.pyfuncr  rQ   r   r#   r#   r$   test_objmode_caching_basica  s   z-TestLiftObjCaching.test_objmode_caching_basicc                    s"   dd   fdd}|  | d S )Nc                 S   r  r  r#   r1   r#   r#   r$   other_pyfuncj  r  zNTestLiftObjCaching.test_objmode_caching_call_closure_bad.<locals>.other_pyfuncc                    s8   t dd  | }W d    |S 1 sw   Y  |S r  r9  r  r  r#   r$   r   m  r;  zHTestLiftObjCaching.test_objmode_caching_call_closure_bad.<locals>.pyfuncr  r  r#   r  r$   %test_objmode_caching_call_closure_badi  s   z8TestLiftObjCaching.test_objmode_caching_call_closure_badc                 C   s   |  t d S rC   )r  r  rY   r#   r#   r$   &test_objmode_caching_call_closure_goodt  s   z9TestLiftObjCaching.test_objmode_caching_call_closure_goodN)	rb   rc   rd   rg   r   r  r  r  r  r#   r#   r#   r$   r  O  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 )Nrn   z*Undefined variable used as context manager)r%   rH   r   r
   r   r   rh   ri   rj   r   r   r   rQ   rS   r   r#   r#   r$   test_undefined_globaly     z&TestBogusContext.test_undefined_globalc                 C   r  )Nrn   z"Unsupported context manager in use)r%   rK   r   r
   r   r   rh   ri   rj   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 d	} W d    d S 1 sw   Y  d S )N )openr=  r#   r#   r$   r        
"z;TestBogusContext.test_with_as_fails_gracefully.<locals>.foozGThe 'with (context manager) as (variable):' construct is not supported.)r   r   r
   ZUnsupportedBytecodeErrorr   r   r   )rQ   r   r   Zexcstrr   r#   r#   r$   test_with_as_fails_gracefully  s   

z.TestBogusContext.test_with_as_fails_gracefullyN)rb   rc   rd   r  r  r  r#   r#   r#   r$   r  x  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 rC   r   r#   r#   r#   r$   r=    r  zFTestMisc.test_no_fork_in_compilation.<locals>.force_compile.<locals>.f)r   r  r#   r#   r$   force_compile  s   z;TestMisc.test_no_fork_in_compilation.<locals>.force_compile)forkcloneexecve)r   ZskipTestr   r  )rQ   r  ZsyscallsZstrace_datar#   r#   r$   test_no_fork_in_compilation  s   	

z$TestMisc.test_no_fork_in_compilationN)rb   rc   rd   Z_numba_parallel_test_r   r   Zrun_test_in_subprocessr  r#   r#   r#   r$   r    s
    r  __main__)Mr   r   numpyr   r   Znumba.core.transformsr   r   Znumba.core.withcontextsr   r   r   Znumba.core.bytecoder   r   Znumba.core.interpreterr	   Z
numba.corer
   Znumba.core.registryr   Znumba.core.compilerr   r   r   r   r   r   Znumba.core.extendingr   Znumba.tests.supportr   r   r   r   r   r   r   r   r   r   Znumba.core.utilsr   Znumba.experimentalr   r  r%   r,   r3   r6   r;   r=   r@   rA   rB   rD   rF   rH   r  rJ   rK   r   rE  rM   re   rx   r|   r   r   r   r  r  r  r  r  rb   mainr#   r#   r#   r$   <module>   sj    0	
0		      )(
 