o
    ?Hh                     @   s   d dl mZ ddlZeejjd ZdaG dd dadd Z	G dd	 d	e
Zdd
dZdd Zdd ZdddZdd ZdS )   )_ccallback_c    Nc                   @   s   e Zd ZdS )CDataN)__name__
__module____qualname__ r   r   U/home/air/sanwanet/gpt-api/venv/lib/python3.10/site-packages/scipy/_lib/_ccallback.pyr   	   s    r   c                  C   sB   t d urd S zdd l} |  a t jaW d S  ty    da Y d S w )Nr   F)fficffiFFIr   ImportError)r   r   r   r	   _import_cffi   s   
r   c                   @   sn   e Zd ZdZdZdddZdd Zedd	 Zed
d Z	edd Z
dd ZedddZedddZdS )LowLevelCallablea  
    Low-level callback function.

    Some functions in SciPy take as arguments callback functions, which
    can either be python callables or low-level compiled functions. Using
    compiled callback functions can improve performance somewhat by
    avoiding wrapping data in Python objects.

    Such low-level functions in SciPy are wrapped in `LowLevelCallable`
    objects, which can be constructed from function pointers obtained from
    ctypes, cffi, Cython, or contained in Python `PyCapsule` objects.

    .. seealso::

       Functions accepting low-level callables:

       `scipy.integrate.quad`, `scipy.ndimage.generic_filter`,
       `scipy.ndimage.generic_filter1d`, `scipy.ndimage.geometric_transform`

       Usage examples:

       :ref:`ndimage-ccallbacks`, :ref:`quad-callbacks`

    Parameters
    ----------
    function : {PyCapsule, ctypes function pointer, cffi function pointer}
        Low-level callback function.
    user_data : {PyCapsule, ctypes void pointer, cffi void pointer}
        User data to pass on to the callback function.
    signature : str, optional
        Signature of the function. If omitted, determined from *function*,
        if possible.

    Attributes
    ----------
    function
        Callback function given.
    user_data
        User data given.
    signature
        Signature of the function.

    Methods
    -------
    from_cython
        Class method for constructing callables from Cython C-exported
        functions.

    Notes
    -----
    The argument ``function`` can be one of:

    - PyCapsule, whose name contains the C function signature
    - ctypes function pointer
    - cffi function pointer

    The signature of the low-level callback must match one of those expected
    by the routine it is passed to.

    If constructing low-level functions from a PyCapsule, the name of the
    capsule must be the corresponding signature, in the format::

        return_type (arg1_type, arg2_type, ...)

    For example::

        "void (double)"
        "double (double, int *, void *)"

    The context of a PyCapsule passed in as ``function`` is used as ``user_data``,
    if an explicit value for ``user_data`` was not given.

    r   Nc                 C   s    |  |||}t| |||fS N)_parse_callbacktuple__new__)clsfunction	user_data	signatureitemr   r   r	   r   h   s   zLowLevelCallable.__new__c                 C   s   d| j d| jdS )NzLowLevelCallable(, ))r   r   selfr   r   r	   __repr__n   s   zLowLevelCallable.__repr__c                 C      t | dS )Nr   r   __getitem__r   r   r   r	   r   q      zLowLevelCallable.functionc                 C   r   )N   r   r   r   r   r	   r   u   r!   zLowLevelCallable.user_datac                 C   s   t t| dS )Nr   )r   get_capsule_signaturer   r    r   r   r   r	   r   y   s   zLowLevelCallable.signaturec                 C   s   t  r   )
ValueError)r   idxr   r   r	   r    }   s   zLowLevelCallable.__getitem__c              
   C   sn   z|j | }W n) ty } zd}t||d}~w ty0 } zd|d}t||d}~ww | |||S )a  
        Create a low-level callback function from an exported Cython function.

        Parameters
        ----------
        module : module
            Cython module where the exported function resides
        name : str
            Name of the exported function
        user_data : {PyCapsule, ctypes void pointer, cffi void pointer}, optional
            User data to pass on to the callback function.
        signature : str, optional
            Signature of the function. If omitted, determined from *function*.

        z?Given module is not a Cython module with __pyx_capi__ attributeNzNo function z$ found in __pyx_capi__ of the module)__pyx_capi__AttributeErrorr$   KeyError)r   modulenamer   r   r   emessager   r   r	   from_cython   s   

zLowLevelCallable.from_cythonc                 C   s   t   t|trt|d}n&t|trt||\}}nt|tr)t||\}}nt	
|r1|}ntdt|tjr@t|}nt|trJt|}n|d u rQd}nt	
|rY|}ntdt	|||S )Nr   zMGiven input is not a callable or a low-level callable (pycapsule/ctypes/cffi)zNGiven user data is not a valid low-level void* pointer (pycapsule/ctypes/cffi))r   
isinstancer   r   r    
PyCFuncPtr_get_ctypes_funcr   _get_cffi_funcr   check_capsuler$   ctypesc_void_p_get_ctypes_data_get_cffi_dataget_raw_capsule)r   objr   r   funccontextr   r   r	   r      s(   







z LowLevelCallable._parse_callback)NN)r   r   r   __doc__	__slots__r   r   propertyr   r   r   r    classmethodr-   r   r   r   r   r	   r      s     K



r   c                 C   sp   t | t jj}|d u r4t| jd }t| jD ]\}}|dkr'|t|7 }q|dt| 7 }q|d7 }||fS )Nz (r   r   r   )r3   castr4   value_typename_from_ctypesrestype	enumerateargtypes)r9   r   func_ptrjargr   r   r	   r0      s   r0   c                 C   s~   | d u rdS | t ju rdS | j}d}|dr&|d7 }|dd  }|ds|dr1|dd  }|dkr=|d	d
|  7 }|S )Nvoidzvoid *r   LP_r      c_r"    *)r3   r4   r   
startswith)r   r*   pointer_levelr   r   r	   rA      s   



rA   c                 C   s   t | t jjS r   )r3   r?   r4   r@   datar   r   r	   r5      s   r5   c                 C   s4   t d| }|d u rt t | dd}||fS )N	uintptr_tz(*)rL   )r
   r?   getctypetypeofreplace)r9   r   rE   r   r   r	   r1      s   r1   c                 C   s   t d| S )NrR   )r
   r?   rP   r   r   r	   r6      r!   r6   r   ) r   r3   	CFUNCTYPEr4   	__bases__r/   r
   r   r   r   r   r0   rA   r5   r1   r6   r   r   r   r	   <module>   s     
%
	