HEX
Server: Apache
System: Linux pdx1-shared-a1-38 6.6.104-grsec-jammy+ #3 SMP Tue Sep 16 00:28:11 UTC 2025 x86_64
User: mmickelson (3396398)
PHP: 8.1.31
Disabled: NONE
Upload Files
File: //lib/python3/dist-packages/numpy/compat/__pycache__/_inspect.cpython-310.pyc
o

6��a�@s�dZddlZddgZdd�Zdd�Zd	d
�Zd\ZZZZ	dd
�Z
dd�Zdd�Zdd�Z
e
fdd�Zdddedd�dd�dd�e
fdd�Zedd�dd�dd�e
fdd�ZdS)z�Subset of inspect module from upstream python

We use this instead of upstream because upstream inspect is slow to import, and
significantly contributes to numpy import times. Importing this copy has almost
no overhead.

�N�
getargspec�
formatargspeccC�t|tj�S)a�Return true if the object is an instance method.

    Instance method objects provide these attributes:
        __doc__         documentation string
        __name__        name with which this method was defined
        im_class        class object in which this method belongs
        im_func         function object containing implementation of method
        im_self         instance to which this method is bound, or None

    )�
isinstance�types�
MethodType��object�r
�7/usr/lib/python3/dist-packages/numpy/compat/_inspect.py�ismethod
srcCr)aReturn true if the object is a user-defined function.

    Function objects provide these attributes:
        __doc__         documentation string
        __name__        name with which this function was defined
        func_code       code object containing compiled function bytecode
        func_defaults   tuple of any default values for arguments
        func_doc        (same as __doc__)
        func_globals    global namespace in which this function was defined
        func_name       (same as __name__)

    )rr�FunctionTyperr
r
r�
isfunctions
rcCr)a�Return true if the object is a code object.

    Code objects provide these attributes:
        co_argcount     number of arguments (not including * or ** args)
        co_code         string of raw compiled bytecode
        co_consts       tuple of constants used in the bytecode
        co_filename     name of file in which this code object was created
        co_firstlineno  number of first line in Python source code
        co_flags        bitmap: 1=optimized | 2=newlocals | 4=*arg | 8=**arg
        co_lnotab       encoded mapping of line numbers to bytecode indices
        co_name         name with which this code object was defined
        co_names        tuple of names of local variables
        co_nlocals      number of local variables
        co_stacksize    virtual machine stack space required
        co_varnames     tuple of names of arguments and local variables
        
    )rr�CodeTyperr
r
r�iscode)sr)����cCs�t|�std��|j}|j}t|d|��}t|�D]}||dd�dvr*td��qd}|jt@r;|j|}|d}d}|jt@rG|j|}|||fS)aGet information about the arguments accepted by a code object.

    Three things are returned: (args, varargs, varkw), where 'args' is
    a list of argument names (possibly containing nested lists), and
    'varargs' and 'varkw' are the names of the * and ** arguments or None.

    zarg is not a code objectNr)��.z*tuple function arguments are not supported)	r�	TypeError�co_argcount�co_varnames�list�range�co_flags�
CO_VARARGS�CO_VARKEYWORDS)�co�nargs�names�args�i�varargs�varkwr
r
r�getargsAs"	�




r&cCs<t|�r|j}t|�std��t|j�\}}}||||jfS)amGet the names and default values of a function's arguments.

    A tuple of four things is returned: (args, varargs, varkw, defaults).
    'args' is a list of the argument names (it may contain nested lists).
    'varargs' and 'varkw' are the names of the * and ** arguments or None.
    'defaults' is an n-tuple of the default values of the last n arguments.

    zarg is not a Python function)r�__func__rrr&�__code__�__defaults__)�funcr"r$r%r
r
rr`s
cCst|j�\}}}||||jfS)aaGet information about arguments passed into a particular frame.

    A tuple of four things is returned: (args, varargs, varkw, locals).
    'args' is a list of the argument names (it may contain nested lists).
    'varargs' and 'varkw' are the names of the * and ** arguments or None.
    'locals' is the locals dictionary of the given frame.
    
    )r&�f_code�f_locals)�framer"r$r%r
r
r�getargvaluesqs	r.cCs.t|�dkrd|ddSdd�|�dS)Nr�(rz,)�, �))�len�join)�seqr
r
r�joinseq}sr5cs0t|�ttfvr���fdd�|D��S�|�S)z=Recursively walk a sequence, stringifying each element.

    c�g|]}t|����qSr
��strseq)�.0�_o��convertr3r
r�
<listcomp>��zstrseq.<locals>.<listcomp>)�typer�tuple)r	r<r3r
r;rr8�sr8cC�d|S�N�*r
��namer
r
r�<lambda>��rFcCrA�Nz**r
rDr
r
rrF�rGcC�dt|�S�N�=��repr��valuer
r
rrF��c	
Cs�g}	|rt|�t|�}
tt|��D]}t||||�}|r,||
kr,|||||
�}|	�|�q|dur=|	�||��|durH|	�||��dd�|	�dS)amFormat an argument spec from the 4 values returned by getargspec.

    The first four arguments are (args, varargs, varkw, defaults).  The
    other four arguments are the corresponding optional formatting functions
    that are called to turn names and values into strings.  The ninth
    argument is an optional function to format the sequence of arguments.

    Nr/r0r1)r2rr8�appendr3)
r"r$r%�defaults�	formatarg�
formatvarargs�formatvarkw�formatvaluer3�specs�firstdefaultr#�specr
r
rr�scCrArBr
rDr
r
rrF�rGcCrArHr
rDr
r
rrF�rGcCrIrJrLrNr
r
rrF�rPc	
sr|||fdd����fdd�|D�}	|r!|	�||�|||��|r0|	�||�|||��dd�|	�dS)alFormat an argument spec from the 4 values returned by getargvalues.

    The first four arguments are (args, varargs, varkw, locals).  The
    next four arguments are the corresponding optional formatting functions
    that are called to turn names and values into strings.  The ninth
    argument is an optional function to format the sequence of arguments.

    cSs||�|||�S)Nr
)rE�localsrSrVr
r
rr<�sz formatargvalues.<locals>.convertcr6r
r7)r9�argr;r
rr=�r>z#formatargvalues.<locals>.<listcomp>r/r0r1)rQr3)
r"r$r%rZrSrTrUrVr3rWr
r;r�formatargvalues�s
�r\)�__doc__r�__all__rrr�CO_OPTIMIZED�CO_NEWLOCALSrrr&rr.r5r8�strrr\r
r
r
r�<module>s2
	
��