U
    9%e %                     @   s   d dl Zd dlmZmZ d dlmZ d dlmZm	Z	m
Z
 d dlmZ d dlmZmZ d dlmZ d dlZe Zde_d	d
 Zdd Zdd Zdd ZG dd deejZG dd deejZG dd dejZG dd dejZedkre   dS )    N)compile_isolatedDEFAULT_FLAGS)SerialMixin)typeofcudanjit)float64)MemoryLeakMixinoverride_env_config)configTc                 C   s   | d S N
    ar   r   [/var/www/html/Darija-Ai-API/env/lib/python3.8/site-packages/numba/tests/test_boundscheck.pybasic_array_access   s    r   c                 C   s   | dd df S r   r   r   r   r   r   slice_array_access   s    r   c                 C   s   t dddg}| | S )N         nparrayxr   r   r   r   fancy_array_access   s    r   c                 C   s   t dddg}d| |< | S )Nr   r   r   r   r   r   r   r   r   fancy_array_modify   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 )TestBoundsCheckNoErrorc                 C   s   t j| _d t _d S Nr   BOUNDSCHECKold_boundscheckselfr   r   r   setUp$   s    zTestBoundsCheckNoError.setUpc              	   C   sR   t d}| t t| W 5 Q R X t|}tt|gtd}|j}|| d S N   )flags)	r   arangeassertRaises
IndexErrorr   r   r   r   entry_point)r$   r   atc_noboundschecknoboundscheckr   r   r   test_basic_array_boundscheck(   s    
z3TestBoundsCheckNoError.test_basic_array_boundscheckc           	   	   C   s   t d}t d}| t t| W 5 Q R X t| t|}td d  }tt|g|td}|j	}tt|g|t
d}|j	}|| || || d S N)r'   r'   )r'      return_typer(   )r   onesr*   r+   r   r   r   r   r   r,   BOUNDSCHECK_FLAGS	r$   r   br-   rtr.   r/   c_boundscheckboundscheckr   r   r   test_slice_array_boundscheck8   s(    

z3TestBoundsCheckNoError.test_slice_array_boundscheckc           	   	   C   s   t d}t d}| t t| W 5 Q R X t| t|}|jd d  }tt|g|td}|j	}tt|g|t
d}|j	}|| || || d S Nr      r3   )r   r)   r*   r+   r   r   dtyper   r   r,   r6   r7   r   r   r   test_fancy_indexing_boundscheckT   s(    

z6TestBoundsCheckNoError.test_fancy_indexing_boundscheckc                 C   s   | j t_d S r   r"   r   r!   r#   r   r   r   tearDownq   s    zTestBoundsCheckNoError.tearDownN)__name__
__module____qualname__r%   r0   r<   r@   rB   r   r   r   r   r   #   s
   r   c                   @   s6   e Zd Zdd Zee  ddd Zdd Z	dS )	TestNoCudaBoundsCheckc                 C   s   t j| _d t _d S r   r    r#   r   r   r   r%   v   s    zTestNoCudaBoundsCheck.setUpzNO CUDAc              	   C   s   |  t tjdddd }W 5 Q R X tjdddd }tdd	< tjd
d }td}td}tj	s|d || W 5 Q R X d S )NTr;   c                   S   s   d S r   r   r   r   r   r   func}   s    z<TestNoCudaBoundsCheck.test_no_cuda_boundscheck.<locals>.funcFc                   S   s   d S r   r   r   r   r   r   func3   s    z=TestNoCudaBoundsCheck.test_no_cuda_boundscheck.<locals>.func3NUMBA_BOUNDSCHECK1c                 S   s   | d |d< d S Nr   r   r   r   r   r   func2   s    z=TestNoCudaBoundsCheck.test_no_cuda_boundscheck.<locals>.func2)r   )r   r   )
r*   NotImplementedErrorr   Zjitr
   r   r5   Zzerosr   ZENABLE_CUDASIM)r$   rH   rI   rM   r   r   r   r   r   test_no_cuda_boundscheckz   s    





z.TestNoCudaBoundsCheck.test_no_cuda_boundscheckc                 C   s   | j t_d S r   rA   r#   r   r   r   rB      s    zTestNoCudaBoundsCheck.tearDownN)
rC   rD   rE   r%   unittestZskipIfr   Zis_availablerO   rB   r   r   r   r   rF   u   s   
rF   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S )TestBoundsCheckErrorc                 C   s   t j| _d t _d S r   r    r#   r   r   r   r%      s    zTestBoundsCheckError.setUpc              	   C   sh   t d}| t t| W 5 Q R X t|}tt|gtd}|j}| t || W 5 Q R X d S r&   )	r   r)   r*   r+   r   r   r   r6   r,   )r$   r   r-   r:   r;   r   r   r   r0      s    
z1TestBoundsCheckError.test_basic_array_boundscheckc              	   C   s   t d}t d}| t t| W 5 Q R X t| t|}td d  }tt|g|td}|j	}| t || W 5 Q R X d S r1   )
r   r5   r*   r+   r   r   r   r   r6   r,   r$   r   r8   r-   r9   r:   r;   r   r   r   r<      s    

z1TestBoundsCheckError.test_slice_array_boundscheckc              	   C   s   t d}t d}| t t| W 5 Q R X t| t|}|jd d  }tt|g|td}|j	}| t || W 5 Q R X d S r=   )
r   r)   r*   r+   r   r   r?   r   r6   r,   rR   r   r   r   r@      s    

z4TestBoundsCheckError.test_fancy_indexing_boundscheckc              	   C   s   t d}t d}| t t| W 5 Q R X t| t|}|jd d  }tt|g|td}|j	}| t || W 5 Q R X d S r=   )
r   r)   r*   r+   r   r   r?   r   r6   r,   rR   r   r   r   1test_fancy_indexing_with_modification_boundscheck   s    

zFTestBoundsCheckError.test_fancy_indexing_with_modification_boundscheckc                 C   s   | j t_d S r   rA   r#   r   r   r   rB      s    zTestBoundsCheckError.tearDownN)	rC   rD   rE   r%   r0   r<   r@   rS   rB   r   r   r   r   rQ      s   rQ   c                   @   s4   e Zd Zdd Zdd Zdd Zdd Zd	d
 ZdS )TestBoundsEnvironmentVariablec                 C   sT   t j| _d t _tdd }tdddd }tdddd	 }|| _|| _|| _d S )
Nc                 S   s   | d S rL   r   r   r   r   r   default   s    z4TestBoundsEnvironmentVariable.setUp.<locals>.defaultFrG   c                 S   s   | d S rL   r   rU   r   r   r   off   s    z0TestBoundsEnvironmentVariable.setUp.<locals>.offTc                 S   s   | d S rL   r   rU   r   r   r   on   s    z/TestBoundsEnvironmentVariable.setUp.<locals>.on)r   r!   r"   r   rV   rW   rX   )r$   rV   rW   rX   r   r   r   r%      s    


z#TestBoundsEnvironmentVariable.setUpc              
   C   sZ   t ddF tdg}| | | | | t | | W 5 Q R X W 5 Q R X d S )NrJ    r   )r
   r   r   rV   rW   r*   r+   rX   r$   r   r   r   r   test_boundscheck_unset  s    

z4TestBoundsEnvironmentVariable.test_boundscheck_unsetc              
   C   sZ   t ddF tdg}| t$ | | | | | | W 5 Q R X W 5 Q R X d S )NrJ   rK   r   )r
   r   r   r*   r+   rV   rW   rX   rZ   r   r   r   test_boundscheck_enabled  s    

z6TestBoundsEnvironmentVariable.test_boundscheck_enabledc              	   C   sD   t dd0 tdg}| | | | | | W 5 Q R X d S )NrJ   0r   )r
   r   r   rV   rW   rX   rZ   r   r   r   test_boundscheck_disabled  s
    

z7TestBoundsEnvironmentVariable.test_boundscheck_disabledc                 C   s   | j t_d S r   rA   r#   r   r   r   rB     s    z&TestBoundsEnvironmentVariable.tearDownN)rC   rD   rE   r%   r[   r\   r^   rB   r   r   r   r   rT      s
   		rT   __main__)!numpyr   Znumba.core.compilerr   r   Znumba.cuda.testingr   Znumbar   r   r   Znumba.core.typesr   Znumba.tests.supportr	   r
   Z
numba.corer   rP   copyr6   r;   r   r   r   r   ZTestCaser   rF   rQ   rT   rC   mainr   r   r   r   <module>   s&   R$T6