Mini Kabibi Habibi

Current Path : C:/Users/ITO/AppData/Local/Programs/Python/Python314/Lib/__pycache__/
Upload File :
Current File : C:/Users/ITO/AppData/Local/Programs/Python/Python314/Lib/__pycache__/inspect.cpython-314.pyc

+
��h����@
�RtR�t.RNRNRNRNRNRNRNRNR	NR
NRNRNR
NRNRNRNRNRNRNRNRNRNRNRNRNRNRNRNRNRNRNR NR!NR"NR#NR$NR%NR&NR'NR(NR)NR*NR+NR,NR-NR.NR/NR0NR1NR2NR3NR4NR5NR6NR7NR8NR9NR:NR;NR<NR=NR>NR?NR@NRANRBNRCNRDNRENRFNRGNRHNRINRJNRKNRLNRMNRNNRONRPNRQNRRNRSNRTNRUNRVNRWNRXNRYNRZNR[NR\NR]NR^NR_NR`NRaNRbNRcNRdNReNRfNRgNRhNRiNRjNRkNt^RlIt^RmIHtHt^RnIHt^RlIt^RlI	t	^RlI
t^RlIt^RlI
t^RlIt^RlIt^RlIt^RlIt^RlIt^RlIt^RlIt^RlIt^RlIt^RlIt^RoIHt^RpIHt^RqIHtHt^RrIH t!]"!4t#]	PHPK4Fwt&t']&]#Rs]',&K	A&A'A#R�t(Rtt)Rut*Rvt+Rwt,Rxt-Ryt.]/!]Rz4'dR{t0MR|t0]/!]R}4'dR~t1MRt1R�t2R�t3R�t4]5!4t6R�t7R�t8R�t9R�t:R�t;R�t<R�t=R�t>R�t?R�t@R�tAR�tBR�tCR�tDR�tER�tFR�R�ltGR�R�ltH]!RR�4tIR�tJR�tKR�Rl/R�ltLR�tMR�tNR�tOR�tPR�tQR�tRR�tSR�tTR�R�ltU/tV/tWR�R�ltX!R�R]Y4tZR�t[R�t\!R�R]Y4t]!R�R4t^R�t_R�t`R�taR�tbR�R�ltc]!RR�4tdR�te]!RR�4tfR�tg]!RR�4thR�tiR�R�R�/R�lltjR�tk]lR�R�R�3R�ltmR�tnR�toR�tp]!RR�4tqR�tr]!R�R�4ts!R�R']s4ttR�tuR�tvERR�ltwR�tx]!R�ER]tP�,4tz!R�R]z4t{ERR�lt|ERR�lt}R�t~ERR�ltERR�lt�]5!4t�]�EPR�,EPt�]�EPR�,EPt�R�t�R�t�]EP!4R�4t�R�t�]�3R�lt�R!t�R"t�R#t�R t�R�t�R�t�Rt�R
t�Rt�Rt�R�t�R�t�Rt�Rt�Rt�Rt�R�t�R�t�]EP>]EP@]EPB]EPD3t�R�R�/R�lt�ERR�lt�R�t�R�t�R�t�R�t�ERR�lt�ERR�lt�ERR�]EPX/R�llt�R�t�R�R�R�R�R�RlR�RlR�R�R�]EPX/R�lt�!R�R�4t�!R�R�4t�!R�R�]EPd4t�]�EPht�]�EPlt�]�EPpt�]�EPtt�]�EPxt�!R�R$4t�!R�R	4t�!R�R%4t�R�R�R�RlR�RlR�R�R�]EPX/R�lt�!R�R
]EP�4t�R�t�]�R�8Xd
]�!4Rl#Rl#(aGet useful information from live Python objects.

This module encapsulates the interface provided by the internal special
attributes (co_*, im_*, tb_*, etc.) in a friendlier fashion.
It also provides some help for examining source code and class layout.

Here are some of the useful functions provided by this module:

    ismodule(), isclass(), ismethod(), ispackage(), isfunction(),
        isgeneratorfunction(), isgenerator(), istraceback(), isframe(),
        iscode(), isbuiltin(), isroutine() - check object types
    getmembers() - get members of an object that satisfy a given condition

    getfile(), getsourcefile(), getsource() - find an object's source code
    getdoc(), getcomments() - get documentation on an object
    getmodule() - determine the module that an object came from
    getclasstree() - arrange classes so as to represent their hierarchy

    getargvalues(), getcallargs() - get info about function arguments
    getfullargspec() - same, with support for Python 3 features
    formatargvalues() - format an argument spec
    getouterframes(), getinnerframes() - get info about frames
    currentframe() - get the current stack frame
    stack(), trace() - get info about frames on the stack or in a traceback

    signature() - get a Signature object for the callable
�AGEN_CLOSED�AGEN_CREATED�AGEN_RUNNING�AGEN_SUSPENDED�ArgInfo�	Arguments�	Attribute�BlockFinder�BoundArguments�BufferFlags�CORO_CLOSED�CORO_CREATED�CORO_RUNNING�CORO_SUSPENDED�CO_ASYNC_GENERATOR�CO_COROUTINE�CO_GENERATOR�CO_ITERABLE_COROUTINE�	CO_NESTED�CO_NEWLOCALS�	CO_NOFREE�CO_OPTIMIZED�
CO_VARARGS�CO_VARKEYWORDS�CO_HAS_DOCSTRING�	CO_METHOD�ClassFoundException�ClosureVars�
EndOfBlock�	FrameInfo�FullArgSpec�
GEN_CLOSED�GEN_CREATED�GEN_RUNNING�
GEN_SUSPENDED�	Parameter�	Signature�TPFLAGS_IS_ABSTRACT�	Traceback�classify_class_attrs�cleandoc�currentframe�
findsource�formatannotation�formatannotationrelativeto�formatargvalues�get_annotations�
getabsfile�getargs�getargvalues�getasyncgenlocals�getasyncgenstate�getattr_static�getblock�getcallargs�getclasstree�getclosurevars�getcomments�getcoroutinelocals�getcoroutinestate�getdoc�getfile�getframeinfo�getfullargspec�getgeneratorlocals�getgeneratorstate�getinnerframes�	getlineno�
getmembers�getmembers_static�	getmodule�
getmodulename�getmro�getouterframes�	getsource�
getsourcefile�getsourcelines�
indentsize�
isabstract�
isasyncgen�isasyncgenfunction�isawaitable�	isbuiltin�isclass�iscode�iscoroutine�iscoroutinefunction�isdatadescriptor�isframe�
isfunction�isgenerator�isgeneratorfunction�isgetsetdescriptor�ismemberdescriptor�ismethod�ismethoddescriptor�ismethodwrapper�ismodule�	ispackage�	isroutine�istraceback�markcoroutinefunction�	signature�stack�trace�unwrap�walktreeN)�Format�
ForwardRef)r0)�	iskeyword)�
attrgetter)�
namedtuple�OrderedDict)�ref�CO_c�6�\V\P4#)z&Return true if the object is a module.)�
isinstance�types�
ModuleType��objects&�CC:\Users\ITO\AppData\Local\Programs\Python\Python314\Lib\inspect.pyrcrc�����f�e�.�.�/�/�c�"�\V\4#)z%Return true if the object is a class.)rv�typerys&r{rUrU�s���f�d�#�#r}c�6�\V\P4#)z0Return true if the object is an instance method.)rvrw�
MethodTyperys&r{r`r`�r|r}c�@�\V4;'d
\VR4#)z'Return true if the object is a package.�__path__)rc�hasattrrys&r{rdrd�s���F��;�;���
� ;�;r}c��\V4'g#\V4'g\V4'dR#\V4p\	VR4;'d+\	VR4'*;'d\	VR4'*#)a�Return true if the object is a method descriptor.

But not if ismethod() or isclass() or isfunction() are true.

This is new in Python 2.2, and, for example, is true of int.__add__.
An object passing this test has a __get__ attribute, but not a
__set__ attribute or a __delete__ attribute. Beyond that, the set
of attributes varies; __name__ is usually sensible, and __doc__
often is.

Methods implemented via descriptors that also pass one of the other
tests return false from the ismethoddescriptor() test, simply because
the other tests promise more -- you can, e.g., count on having the
__func__ attribute (etc) when an object passes ismethod().F�__get__�__set__�
__delete__�rUr`r[rr��rz�tps& r{rara�sj���v���(�6�*�*�j��.@�.@��	
�f��B��B�	�"�
.�
.��B�	�*�*�
.�
.��B��-�-�/r}c���\V4'g#\V4'g\V4'dR#\V4p\	VR4;'g
\	VR4#)aiReturn true if the object is a data descriptor.

Data descriptors have a __set__ or a __delete__ attribute.  Examples are
properties (defined in Python) and getsets and members (defined in C).
Typically, data descriptors will also have __name__ and __doc__ attributes
(properties, getsets, and members have both of these attributes), but this
is not guaranteed.Fr�r�r�r�s& r{rYrY�sI���v���(�6�*�*�j��.@�.@��	
�f��B��2�y�!�>�>�W�R��%>�>r}�MemberDescriptorTypec�6�\V\P4#)�Return true if the object is a member descriptor.

Member descriptors are specialized descriptors defined in extension
modules.)rvrwr�rys&r{r_r_����
�&�%�"<�"<�=�=r}c��R#)r�F�rys&r{r_r_����
r}�GetSetDescriptorTypec�6�\V\P4#)�Return true if the object is a getset descriptor.

getset descriptors are specialized descriptors defined in extension
modules.)rvrwr�rys&r{r^r^�r�r}c��R#)r�Fr�rys&r{r^r^r�r}c�6�\V\P4#)a1Return 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
    __qualname__    qualified name of this function
    __module__      name of the module the function was defined in or None
    __code__        code object containing compiled function bytecode
    __defaults__    tuple of any default values for arguments
    __globals__     global namespace in which this function was defined
    __annotations__ dict of parameter annotations
    __kwdefaults__  dict of keyword only parameters with defaults
    __dict__        namespace which is supporting arbitrary function attributes
    __closure__     a tuple of cells or None
    __type_params__ tuple of type parameters)rvrw�FunctionTyperys&r{r[r[s�� �f�e�0�0�1�1r}c�,�\P!V4p\V4'dVPpK\P!V4p\V4'g\
V4'gR#\VPPV,4#)z�Return true if ``f`` is a function (or a method or functools.partial
wrapper wrapping a function or a functools.partialmethod wrapping a
function) whose code object has the given ``flag``
set in its flags.F)
�	functools�_unwrap_partialmethodr`�__func__�_unwrap_partialr[�_signature_is_functionlike�bool�__code__�co_flags)�f�flags&&r{�_has_code_flagr�sg��
	�'�'��*�A�
�1�+�+�
�J�J���!�!�!�$�A��q�M�M�7��:�:����
�
�#�#�d�*�+�+r}c�"�\V\4#)z�Return true if the object is a user-defined generator function.

Generator function objects provide the same attributes as functions.
See help(isfunction) for a list of attributes.)r�r��objs&r{r]r]*s��
�#�|�,�,r}c��\V4'dVPpK\P!V4p\	VRR4\
J#)�_is_coroutine_markerN)r`r�r�r��getattr�_is_coroutine_mark�r�s&r{�_has_coroutine_markr�4s:��
�1�+�+�
�J�J���!�!�!�$�A��1�,�d�3�7I�I�Ir}c�X�\VR4'd
VPp\VnV#)zE
Decorator to ensure callable is recognised as a coroutine function.
r�)r�r�r�r�)�funcs&r{rgrg:s'���t�Z� � ��}�}�� 2�D���Kr}c�H�\V\4;'g\V4#)z�Return true if the object is a coroutine function.

Coroutine functions are normally defined with "async def" syntax, but may
be marked via markcoroutinefunction.
)r�rr�r�s&r{rXrXCs���#�|�,�H�H�0C�C�0H�Hr}c�"�\V\4#)z�Return true if the object is an asynchronous generator function.

Asynchronous generator functions are defined with "async def"
syntax and have "yield" expressions in their body.
)r�rr�s&r{rRrRKs���#�1�2�2r}c�6�\V\P4#)z7Return true if the object is an asynchronous generator.)rvrw�AsyncGeneratorTyperys&r{rQrQSs���f�e�6�6�7�7r}c�6�\V\P4#)a�Return true if the object is a generator.

Generator objects provide these attributes:
    gi_code         code object
    gi_frame        frame object or possibly None once the generator has
                    been exhausted
    gi_running      set to 1 when generator is executing, 0 otherwise
    gi_yieldfrom    object being iterated by yield from or None

    __iter__()      defined to support iteration over container
    close()         raises a new GeneratorExit exception inside the
                    generator to terminate the iteration
    send()          resumes the generator and "sends" a value that becomes
                    the result of the current yield-expression
    throw()         used to raise an exception inside the generator)rvrw�
GeneratorTyperys&r{r\r\Ws�� �f�e�1�1�2�2r}c�6�\V\P4#)z)Return true if the object is a coroutine.)rvrw�
CoroutineTyperys&r{rWrWis���f�e�1�1�2�2r}c�6�\V\P4;'gy\V\P4;'d3\	VP
P\,4;'g%\V\PP4#)z?Return true if object can be passed to an ``await`` expression.)rvrwr�r�r��gi_coder�r�collections�abc�	Awaitablerys&r{rSrSmsu���v�u�2�2�3�
:�
:��v�u�2�2�3�
F�
F��V�^�^�,�,�/D�D�E�
:�
:�
�v�{���8�8�9�;r}c�6�\V\P4#)aNReturn true if the object is a traceback.

Traceback objects provide these attributes:
    tb_frame        frame object at this level
    tb_lasti        index of last attempted instruction in bytecode
    tb_lineno       current line number in Python source code
    tb_next         next inner traceback object (called by this level))rvrw�
TracebackTyperys&r{rfrfts���f�e�1�1�2�2r}c�6�\V\P4#)aReturn true if the object is a frame object.

Frame objects provide these attributes:
    f_back          next outer frame object (this frame's caller)
    f_builtins      built-in namespace seen by this frame
    f_code          code object being executed in this frame
    f_globals       global namespace seen by this frame
    f_lasti         index of last attempted instruction in bytecode
    f_lineno        current line number in Python source code
    f_locals        local namespace seen by this frame
    f_trace         tracing function for this frame, or None
    f_trace_lines   is a tracing event triggered for each source line?
    f_trace_opcodes are per-opcode events being requested?

    clear()          used to clear all references to local variables)rvrw�	FrameTyperys&r{rZrZ~s�� �f�e�o�o�.�.r}c�6�\V\P4#)a�Return true if the object is a code object.

Code objects provide these attributes:
    co_argcount         number of arguments (not including *, ** args
                        or keyword only arguments)
    co_code             string of raw compiled bytecode
    co_cellvars         tuple of names of cell variables
    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
                        | 16=nested | 32=generator | 64=nofree | 128=coroutine
                        | 256=iterable_coroutine | 512=async_generator
                        | 0x4000000=has_docstring
    co_freevars         tuple of names of free variables
    co_posonlyargcount  number of positional only arguments
    co_kwonlyargcount   number of keyword only arguments (not including ** 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 other than arguments and function locals
    co_nlocals          number of local variables
    co_stacksize        virtual machine stack space required
    co_varnames         tuple of names of arguments and local variables
    co_qualname         fully qualified function name

    co_lines()          returns an iterator that yields successive bytecode ranges
    co_positions()      returns an iterator of source code positions for each bytecode instruction
    replace()           returns a copy of the code object with a new values)rvrw�CodeTyperys&r{rVrV�s��:�f�e�n�n�-�-r}c�6�\V\P4#)aReturn true if the object is a built-in function or method.

Built-in functions and methods provide these attributes:
    __doc__         documentation string
    __name__        original name of this function or method
    __self__        instance to which a method is bound, or None)rvrw�BuiltinFunctionTyperys&r{rTrT�s���f�e�7�7�8�8r}c�6�\V\P4#)z.Return true if the object is a method wrapper.)rvrw�MethodWrapperTyperys&r{rbrb�s���f�e�5�5�6�6r}c���\V4;'gg\V4;'gT\V4;'gA\V4;'g.\	V4;'g\V\P4#)z<Return true if the object is any kind of function or method.)rTr[r`rarbrvr��_singledispatchmethod_getrys&r{rere�s����f��
G�
G��&�!�
G�
G����
G�
G�"�&�)�
G�
G��v�&�	
G�
G�
�&�)�"E�"E�F�Hr}c��\V\4'gR#VP\,'dR#\	\V4\
P4'gR#\VR4'dR#VPP4Fwr\VRR4'gKR#	VPF:p\VRR4F&p\WR4p\VRR4'gK$R#	K<	R#)z:Return true if the object is an abstract base class (ABC).FT�__abstractmethods__�__isabstractmethod__Nr�)rvr�	__flags__r'�
issubclassr��ABCMetar��__dict__�itemsr��	__bases__)rz�name�value�bases&   r{rPrP�s����f�d�#�#��
���-�-�-���d�6�l�C�K�K�0�0���v�,�-�-�����,�,�.����5�0�%�8�8��/�� � ���D�"7��<�D��F�$�/�E��u�4�e�<�<��=�!�
r}c���.p\4p\V4p\V4'dw\V4pVPFYpVP
P
4F8wr�\V	\P4'gK'VPV4K:	K[	MRpVFRp
V!W
4pW�9d\hT'dT!T4'dTPY�34TPT
4KT	VPRR7V# \dLzi;i \d5TF*pY�P
9gKTP
T
,pK�	K�i;i)c��V^,#)�r�)�pairs&r{�<lambda>�_getmembers.<locals>.<lambda>s��$�q�'r}��keyr�)�set�dirrUrJr�r�r�rvrw�DynamicClassAttribute�append�AttributeError�add�sort)rz�	predicate�getter�results�	processed�names�mror��k�vr�r�s&&&         r{�_getmembersr��s3���G���I���K�E��v����V�n��	��(�(�� �M�M�/�/�1�D�A�!�!�U�%@�%@�A�A����Q��2�)�����
	��6�'�E���$�$� ��I�e�,�,��N�N�C�<�(��
�
�c��)�*�L�L�)�L�*��N��5�	��	���	����-�-�'� �M�M�#�.�E����	�s6�AD�D�'D�D�D�E�E�E�Ec�"�\W\4#)z�Return all members of an object as (name, value) pairs sorted by name.
Optionally, only return members that satisfy a given predicate.)r�r��rzr�s&&r{rFrFs���v�'�2�2r}c�"�\W\4#)aReturn all members of an object as (name, value) pairs sorted by name
without triggering dynamic lookup via the descriptor protocol,
__getattr__ or __getattribute__. Optionally, only return members that
satisfy a given predicate.

Note: this function may not be able to retrieve all members
   that getmembers can fetch (like dynamically created attributes)
   and may find members that getmembers can't (like descriptors
   that raise AttributeError). It can also return descriptor objects
   instead of instance members in some cases.
)r�r6r�s&&r{rGrGs���v�.�9�9r}zname kind defining_class objectc	�6�\V4p\\V44p\;QJd.RV4FNK	5M
!RV44pV3V,pW2,p\V4pVFipVPP4FHwrx\
V\P4'gK'VPfK7VPV4KJ	Kk	.p	\4p
VEF�pRpRp
RpW�9d�VR8Xd\R4h\W4p
\V
RV4pW�9dPRpRpVFp\VVR4pVV
JgKTpK	VFpVPW4pTT
JgKTpK!	VeTpVF0pW�P9gKVPV,pW�9dTpM	VfK�V
eT
MTp\
V\ \P"34'dRpTpM\\
V\$\P&34'dRpTpM1\
V\(4'dRpTpM\+V4'dR	pMR
pV	P\-VVVV44V
P/V4EK�	V	# \dEK8i;i \dEL!i;i)aReturn list of attribute-descriptor tuples.

For each name in dir(cls), the return list contains a 4-tuple
with these elements:

    0. The name (a string).

    1. The kind of attribute this is, one of these strings:
           'class method'    created via classmethod()
           'static method'   created via staticmethod()
           'property'        created via property()
           'method'          any other flavor of method or descriptor
           'data'            not a method

    2. The class which defined this attribute (a class).

    3. The object as obtained by calling getattr; if this fails, or if the
       resulting object does not live anywhere in the class' mro (including
       metaclasses) then the object is looked up in the defining class's
       dict (found by walking the mro).

If one of the items in dir(cls) is stored in the metaclass it will now
be discovered and not have None be listed as the class in which it was
defined.  Any items whose home class cannot be discovered are skipped.
c3�J"�TFq\\39gKVx�K	R#5i�N)rrz)�.0�clss& r{�	<genexpr>�'classify_class_attrs.<locals>.<genexpr>9s���H�7�C�$���.G�C�C�7�s�#�
#Nr�z)__dict__ is special, don't want the proxy�__objclass__z
static methodzclass method�property�method�data)rJr�tupler�r�r�rvrwr��fgetr�r��	Exceptionr��__getattr__r��staticmethod�BuiltinMethodType�classmethod�ClassMethodDescriptorTyper�rerr�)r�r��metamro�class_bases�	all_basesr�r�r�r��resultr�r��homecls�get_obj�dict_obj�last_cls�srch_cls�srch_objr��kinds&                   r{r)r)s���6��+�C��T�#�Y��G��e�H�7�H�e�e�H�7�H�H�G��&�3�,�K��%�I���H�E����M�M�'�'�)�D�A��!�U�8�8�9�9�a�f�f�>P����Q��*���F���I���������� �
+��:�%�#�$O�P�P�!�#�,��"�'�>�7�C���-�#�G�#�H�$/��#*�8�T�4�#@��#�w�.�'/�H�%0�
%,��%�'/�';�';�C�'F�H�$�w�.�'/�H�
%,� �+�"*���D��}�}�$��=�=��.���)�"�G����?�
� �,�g�(���h��u�/F�/F� G�H�H�"�D��C�
��;��0O�0O�"P�
Q�
Q�!�D��C�
��(�
+�
+��D��C�
�s�^�^��D��D��
�
�i��d�G�S�9�:��
�
�d��I�J�M��C .�%�$�%��%�
��
�s$�7J	�I6�6J�J�	J�Jc��VP#)zHReturn tuple of base classes (including cls) in method resolution order.)�__mro__)r�s&r{rJrJ�s���;�;�r}�stopc�b�Tp\V4V/p\P!4p\V\4'gu\VR4'dcVeV!V4'dV#VPp\V4pWS9g\V4V8�d\RPV44hWV&K�V#)aPGet the object wrapped by *func*.

Follows the chain of :attr:`__wrapped__` attributes returning the last
object in the chain.

*stop* is an optional callback accepting an object in the wrapper chain
as its sole argument that allows the unwrapping to be terminated early if
the callback returns a true value. If the callback never returns a true
value, the last object in the chain is returned as usual. For example,
:func:`signature` uses this to stop unwrapping if any object in the
chain has a ``__signature__`` attribute defined.

:exc:`ValueError` is raised if a cycle is encountered.

 �__wrapped__z!wrapper loop when unwrapping {!r})
�id�sys�getrecursionlimitrvrr�r�len�
ValueError�format)r�rr��memo�recursion_limit�id_funcs&$    r{rkrk�s��� 	
�A�
�q�E�1�:�D��+�+�-�O���t�$�$���}�)E�)E����T�
�
���K������T�(���O��T��o�!=��@�G�G��J�K�K��W�
��Kr}c�t�VP4p\V4\VP44,
#)zBReturn the indent size, in spaces, at the start of a line of text.)�
expandtabsr�lstrip)�line�explines& r{rOrO�s)���o�o��G��w�<�#�g�n�n�.�/�/�/r}c���\PPVP4pVfR#VPPR4RRFp\
W4pK	\V4'gR#V#)N�.���)r�modules�get�
__module__�__qualname__�splitr�rU)r�r�r�s&  r{�
_findclassr*�s]��

�+�+�/�/�$�/�/�
*�C�
�{���!�!�'�'��,�S�b�1���c� ��2��3�<�<���Jr}c�R�\V4'd7VPF$pV\JgKVPpTfK"Tu#	R#\V4'djVPPpVPp\V4'd)\\WCR4R4VPJdTpEM�VPpEM�\V4'd/VPp\V4pVe\WS4VJdR#EMP\V4'dcVPpVPp\V4'd-VPR,V,VP8XdTpM�VPpM�\V\ 4'd8VPp\VP"4pVe\WS4VJdR#M�\%V4'g\'V4'dmVPpVP(p\WS4VJdR#\+V4'd2\VRR4p\V\,4'dW69d	Wc,#MR#VPF!p\W4PpTfKTu#	R# \dEKui;i \dKHi;i)Nr�r#�	__slots__)rUrrz�__doc__r�r`r��__name__�__self__r��	__class__r[r*rTr(rvr�r�rarYr�r_�dict)r�r��docr��selfr��slotss&      r{�_finddocr5�s ���s�|�|��K�K�D��6�!���,�,�C��?��J� ����}�}��|�|�$�$���|�|���D�M�M��G�D��-�z�:�c�l�l�J��C��.�.�C�	�C����|�|����o���;�'�#�,�C�7��8�	�3����|�|���|�|���D�M�M�����#�d�*�c�.>�.>�>��C��.�.�C�	�C��	"�	"��|�|������"���;�'�#�,�C�7��8�	�C�	 �	 �$4�S�$9�$9��|�|�������3��S�(���c�"�"��C��d�3�E��%��&�&�4�=��{�"�������	��$�%�-�-�C��?��J�
���k&�����b�	��	�s#�J�!J�J�J�J&�%J&c���VPpTf
\T4p\	T\
4'gR#\
T4# \dR#i;i \\3dR#i;i)z�Get the documentation string for an object.

All tabs are expanded to spaces.  To clean up docstrings that are
indented to line up with blocks of code, any whitespace than can be
uniformly removed from the second line onwards is removed.N)r-r�r5�	TypeErrorrv�strr*)rzr2s& r{r>r>sn����n�n���{�	��6�"�C��c�3�����C�=��������
�	�*�	��	�s"�A�A�A�A�A(�'A(c��VP4PR4p\PpVR,FDp\	VPR44pV'gK'\	V4V,
p\
W%4pKF	V'dV^,PR4V^&V\P8d*\^\	V44FpW,VRW&K	V'd"VR,'gVP4K)V'd#V^,'gVP^4K*RPV4#)z|Clean up indentation from docstrings.

Any whitespace that can be uniformly removed from the second line
onwards is removed.�
��NN� Nr$)
rr)r�maxsizerr�min�range�pop�join)r2�lines�marginr �content�indent�is&      r{r*r*s���

�N�N��"�"�4�(�E��[�[�F��b�	�	���d�k�k�#�&�'���7���Y��(�F���(�F�	�
���8�?�?�3�'��a��
������q�#�e�*�%�A��x���(�E�H�&���b�	�	�
�	�	��
��a���
�	�	�!���9�9�U��r}c�T�\V4'd:\VRR4'd
VP#\RP	V44h\V4'd�\
VR4'de\PPVP4p\VRR4'd
VP#VPR8Xd\R4h\RP	V44h\V4'd
VPp\V4'd
VPp\!V4'd
VP"p\%V4'd
VP&p\)V4'd
VP*#\RP	\-V4P.44h)	z@Work out which source or compiled file an object was defined in.�__file__Nz{!r} is a built-in moduler'�__main__�source code not availablez{!r} is a built-in classzVmodule, class, method, function, traceback, frame, or code object was expected, got {})rcr�rIr7rrUr�rr%r&r'�OSErrorr`r�r[r�rf�tb_framerZ�f_coderV�co_filenamerr.)rz�modules& r{r?r?1sA�������6�:�t�,�,��?�?�"��3�:�:�6�B�C�C��v����6�<�(�(��[�[�_�_�V�%6�%6�7�F��v�z�4�0�0����&�� � �J�.��9�:�:��2�9�9�&�A�B�B����������&��������6��������v�������
�f�~�~��!�!�!�
�7�7=�v���L�)�)�8+�,�,r}c�2�\PPV4p\PP4Uu.uFp\
V4)V3NK	ppVP4VF#wrBVPV4'gKVRVu#	R#uupi)z1Return the module name for a given file, or None.N)	�os�path�basename�	importlib�	machinery�all_suffixesrr��endswith)rS�fname�suffix�suffixes�neglens&    r{rIrIMs����G�G���T�"�E�#,�"5�"5�"B�"B�"D�F�"D���f�+��v�&�"D�
�F��M�M�O�"����>�>�&�!�!���&�>�!�#���
Fs�Bc�~a�\V4o\PPR,p\;QJdV3RlV4F'gKRM	RM!V3RlV44'dN\
PPS4^,\PP^,,oM�\;QJd7V3Rl\PP4F'gKRM,	RM(!V3Rl\PP44'dR#SPR4'dR#S\P9dS#\
PPS4'dS#\VS4p\VRR4eS#\\VR	R4R
R4eS#R#)z~Return the filename that can be used to locate an object's source.
Return None if no way can be identified to get the source.
:NNNc3�F<"�TFpSPV4x�K	R#5ir��rX�r��s�filenames& �r{r�� getsourcefile.<locals>.<genexpr>_s!����
?�)>�A�8���Q���)>���!TFc3�F<"�TFpSPV4x�K	R#5ir�r_r`s& �r{r�rcbs&����
9�7�'(�X�
�
�q�
!�
!�7�rdN�.fwork�
__loader__�__spec__�loader)r?rUrV�BYTECODE_SUFFIXES�anyrRrS�splitext�SOURCE_SUFFIXES�EXTENSION_SUFFIXESrX�	linecache�cache�existsrHr�)rz�all_bytecode_suffixesrPrbs&  @r{rMrMYsF����v��H�%�/�/�A�A�!�D��
�s�
?�)>�
?�s�s�s�
?�)>�
?�?�?��G�G�$�$�X�.�q�1��'�'�7�7��:�;��	��
9��$�$�7�7�
9����
9��$�$�7�7�
9�
9�
9��	�	�	�8�	$�	$���9�?�?�"���	�w�w�~�~�h�����
�v�x�
(�F��v�|�T�*�6���	����T�2�H�d�	C�	O���
Pr}c��Vf\V4;'g\V4p\PP	\PPV44#)z�Return an absolute path to the source or compiled file for an object.

The idea is for each object to have a unique origin, so this routine
normalizes the result as much as possible.)rMr?rRrS�normcase�abspath)rz�	_filenames&&r{r1r1usB��
��!�&�)�<�<�W�V�_�	�
�7�7���B�G�G�O�O�I�6�7�7r}c�8�\V4'dV#\VR4'd*\PP	VP
4#Ve6V\9d+\PP	\V,4#\W4pT\9d+\PP	\T,4#\PP4P4F�wr4\T4'gK\TR4'gK,TPpT\P	TR48XdKUT\T&\T4pTP;\T&\\P P#T4&K�	T\9d+\PP	\T,4#\PR,p\TR4'gR#\Y`P4'd\%Y`P4pYpJdT#\PR,p\Y�P4'd\%Y�P4p	Y�JdT#R#R# \\3dR#i;i)zAReturn the module an object was defined in, or None if not found.r'NrIrJr.�builtins)rcr�rr%r&r'�
modulesbyfiler1r7�FileNotFoundError�copyr�rI�_filesbymodnamer.rRrS�realpathr�)
rzrv�file�modnamerPr��main�
mainobject�builtin�
builtinobjects
&&        r{rHrH�s��������
��v�|�$�$��{�{���v�0�0�1�1����m�!;��{�{���}�Y�7�8�8���&�,���}���{�{���}�T�2�3�3��;�;�+�+�-�3�3�5����F�����
� ;� ;����A��O�'�'���6�6��'(�O�G�$��6�"�A�(.���
7�M�!��}���� � ��#� %�6��}���{�{���}�T�2�3�3��;�;�z�"�D��6�:�&�&���t�_�_�%�%��T�?�?�3�
����K��k�k�*�%�G��w���(�(�����9�
��"��N�#�)��;
�(�)����s�	J�J�Jc��]tRtRtRtR#)ri�r�N�r.r'r(�__firstlineno__�__static_attributes__r�r}r{rr�s��r}c� �\V4pV'd\P!V4M[\V4pVP	R4'd/VPR4'dVPR4'd\
R4h\W4pV'ds\P!WP4pV'gJVP	R4'd3\VR4'd!\P!VP4pM\P!V4pV'g\
R4h\V4'dV^3#\V4'd9\V4R,^,
pT\%T48�d\
R4hY43#\'V4'd
VP(p\+V4'd
VPp\-V4'd
VP.p\1V4'd
VP2p\5V4'dO\VR	4'g\
R
4hVP6^,
pV\%V48�d\
R4hW43#\
R4h \ \"3d
\
R4hi;i)aRReturn the entire source file and starting line number for an object.

The argument may be a module, class, method, function, traceback, frame,
or code object.  The source code is returned as a list of all the lines
in the file and the line number indexes a line in that list.  An OSError
is raised if the source code cannot be retrieved.�<�>rfrKr�zcould not get source coder�zlineno is out of bounds�co_firstlinenoz"could not find function definitionzcould not find code object)rMro�
checkcacher?�
startswithrXrLrH�getlinesr�r��_getlines_from_coder�rcrU�varsr7�KeyErrorrr`r�r[rfrMrZrNrVr�)rzr~rPrC�lnums&    r{r,r,�s����� �D�����T�"��v�������%�%�$�-�-��*<�*<�$�-�-�PX�BY�BY��5�6�6�
�v�
$�F�
��"�"�4���9�������-�-�'�&�*�2M�2M��1�1�&�/�/�B�E���"�"�4�(����1�2�2������a�x���v���	7���<� 1�2�Q�6�D��3�u�:���3�4�4��{�����������&��������6��������v�������
�f�~�~��v�/�0�0��>�?�?��$�$�q�(���3�u�:���3�4�4��{��
�.�
/�/��+�8�$�	7��5�6�6�	7�s�I0�0J
c�Z�\V4wr\T4'd�^pT'dT^,R,R8Xd^pT\	T48d'Y,P4R9dT^,pK6T\	T48d�Y,R,R8Xdj.pTpT\	T48dEY,R,R8Xd1TP
Y,P44T^,pKTRPT4#R#R#T^8�Ed�\Y,4pT^,
pT^8�Ed`Y,P4R,R8XEd;\Y,4T8XEd"Y,P4P4.pT^8�d�T^,
pY,P4P4pTR,R8XdT\Y,4T8Xd>T.TR&T^,
pT^8dM&Y,P4P4pKaT'd$T^,P4R8Xd.TR&K+T'd$TR	,P4R8Xd.TR	R%K+RPT4#R#R#R#R# \\3dR#i;i)
zoGet lines of comments immediately preceding an object's source code.

Returns None when source can't be found.
N:N�Nz#!��#:Nr<N:Nr�N)r�r�r$)r,rLr7rcr�stripr�rrBrOr)rzrCr��start�comments�endrF�comments&       r{r;r;�s1��
� ��(����������U�1�X�b�\�T�)�1�5��c�%�j� �U�\�%7�%7�%9�Y�%F��A�I�E��3�u�:��%�,�r�"2�c�"9��H��C���E�
�"�u�z�"�~��'<�����
� 5� 5� 7�8��A�g���7�7�8�$�$�
#:��
����E�K�(���Q�h���!�8��
�)�)�+�B�/�3�6��u�z�"�f�,��
�-�-�/�6�6�8�9�H��Q�w��A�g���*�/�/�1�8�8�:���b�k�S�(�Z��
�-C�v�-M�$+�9�H�R�L���'�C��Q�w��#�j�3�3�5�<�<�>�G��x��{�0�0�2�c�9�!�����x��|�1�1�3�s�:� "����
��7�7�8�$�$�
-�7�8�
��%
�Y�����s�
J�J*�)J*c��]tRtRtRtR#)rir�Nr�r�r}r{rrs��Tr}c�0a�]tRtRtoRtRtRtRtVtR#)r	iz@Provide a tokeneater() method to detect the end of a code block.c�h�^VnRVnRVnRVnRVn^VnRVnR#)r�FN)rF�islambda�started�passline�indecorator�last�	body_col0�r3s&r{�__init__�BlockFinder.__init__!s4�������
������
� �����	���r}c�
�VP'gGVP'g5VR8Xd	RVnMVR9dVR8XdRVnRVnRVnR#V\P
8XdKRVnV^,VnVP'd\hVP'd
RVnR#R#VP'dR#V\P8XdPVPf!VP'dV^,Vn	VP^,Vn
RVnR#V\P8Xd2VP^,
Vn
VP^8:d\hR#V\P8Xd;VPe+V^,VP8�dV^,VnR#R#R#VP^8Xd.V\P\P39d\hR#R#)�@T�lambdaFN)�def�classr�)r�r�r�r��tokenize�NEWLINEr�r�INDENTr�rF�DEDENT�COMMENT�NL)r3r�token�srowcol�erowcolr s&&&&&&r{�
tokeneater�BlockFinder.tokeneater*s����|�|�|�D�$4�$4�$4���|�#'�� ��4�4��H�$�$(�D�M�#��� �D�M�
�X�%�%�
%�!�D�M���
�D�I��}�}�}� � �����#(�� � �
�]�]�]��
�X�_�_�
$��~�~�%�$�,�,�,�!(������+�+��/�D�K� �D�M�
�X�_�_�
$��+�+��/�D�K��{�{�a�� � � �
�X�%�%�
%��~�~�)�g�a�j�D�N�N�.J�#�A�J��	�/K�)��[�[�A�
�$�x�/?�/?����.M�"M���#N�
r})r�r�rFr�r�r�r�N)	r.r'r(r�r-r�r�r��__classdictcell__��
__classdict__s@r{r	r	s����J��)�)r}c��\4p\P!\V4P4pVFpVP
!V!K	TRTP# \\3dL"\d`pRTP9dTRhXvrVTP
!\P.TO5!Rp?Lk \\3dRp?L�i;iRp?ii;i)z@Extract the block of code at the top of the given list of lines.�	unmatchedN)r	r��generate_tokens�iter�__next__r�r�IndentationError�SyntaxError�msgr�r�)rC�blockfinder�tokens�_token�e�_�_token_infos&      r{r7r7Us����-�K�
��)�)�$�u�+�*>�*>�?���F��"�"�F�+���"�+�"�"�#�#��
�(�)�
�����a�e�e�#���� ���	��"�"�8�#3�#3�B�k�B�B���,�-�	��	��
�sB�AA�C�0C�9C�:C�"B9�9C�
C�C�C�Cc��\V4p\V4wr\V4'd
VPp\	V4'g-\V4'd VPPR8XdV^3#\WR4V^,3#)a�Return a list of source lines and starting line number for an object.

The argument may be a module, class, method, function, traceback, frame,
or code object.  The source code is returned as a list of the lines
corresponding to the object and the line number indicates where in the
original source file the first line of code was found.  An OSError is
raised if the source code cannot be retrieved.z<module>N)	rkr,rfrMrcrZrN�co_namer7�rzrCr�s&  r{rNrNhsu���F�^�F��V�$�K�E��6�������	����	����V�]�]�2�2�j�@��a�x����e��%�t�a�x�/�/r}c�>�\V4wrRPV4#)z�Return the text of the source code for an object.

The argument may be a module, class, method, function, traceback, frame,
or code object.  The source code is returned as a single string.  An
OSError is raised if the source code cannot be retrieved.r�)rNrBr�s&  r{rLrL}s��!��(�K�E�
�7�7�5�>�r}c���.pVP\RR4R7VFHpVPWDP34WA9gK'VP\	W,W44KJ	V#)z-Recursive helper function for getclasstree().r'r.r�)r�rpr�r�rl)�classes�children�parentr��cs&&&  r{rlrl�sZ���G��L�L�Z��j�9�L�:�
������;�;�'�(��=��N�N�8�H�K��=�>���Nr}Fc�z�/p.pVF�pVP'dWVPFDpWR9d.W%&WBV,9dW%,PV4V'gK;WP9gKCKg	KkWC9gKsVPV4K�	VFpWP9gKVPV4K	\W2R4#)a�Arrange the given list of classes into a hierarchy of nested lists.

Where a nested list appears, it contains classes derived from the class
whose entry immediately precedes the list.  Each entry is a 2-tuple
containing a class and a tuple of its base classes.  If the 'unique'
argument is true, exactly one entry appears in the returned structure
for each class in the given list.  Otherwise, classes using multiple
inheritance and their descendants will appear multiple times.N)r�r�rl)r��uniquer��rootsr�r�s&&    r{r9r9�s����H��E�
���;�;�;��+�+���)�')�H�$��V�,�,��$�+�+�A�.��6�f�/��&��^��L�L��O����� ��L�L�� ���E�T�*�*r}zargs, varargs, varkwc���\V4'g\RPV44hVPpVPpVP
p\
VRV4p\
WW#,4pW#,
pRpVP\,'dVPV,pV^,pRpVP\,'dVPV,p\WE,Wg4#)a
Get information about the arguments accepted by a code object.

Three things are returned: (args, varargs, varkw), where
'args' is the list of argument names. Keyword-only arguments are
appended. 'varargs' and 'varkw' are the names of the * and **
arguments or None.z{!r} is not a code objectN)rVr7r�co_varnames�co_argcount�co_kwonlyargcount�listr�rrr)�cor��nargs�nkwargs�args�
kwonlyargs�varargs�varkws&       r{r2r2�s����"�:�:��3�:�:�2�>�?�?��N�N�E��N�N�E��"�"�G���f�u�
��D��e�%�-�0�1�J�	��E��G�	�{�{�Z����.�.��'����	���E�	�{�{�^�#�#����u�%���T�&��7�7r}zGargs, varargs, varkw, defaults, kwonlyargs, kwonlydefaults, annotationsc	���\VRR\RR7p.pRpRp.p.p/pRp	/p
TPTP
JdTPTR&TPP4EF6pTPpTPp
T\Jd@TPT
4TPTP
JdY�P3,
p	M�T\Jd@TPT
4TPTP
JdY�P3,
p	M]T\JdT
pMPT\Jd;TPT
4TPTP
JdTPY�&MT\ JdT
pTP"TP
JgEK(TP"Y�&EK9	T
'gRp
T	'gRp	\%Yc,YET	YzT4# \dp\R4ThRp?ii;i)a�Get the names and default values of a callable object's parameters.

A tuple of seven things is returned:
(args, varargs, varkw, defaults, kwonlyargs, kwonlydefaults, annotations).
'args' is a list of the parameter names.
'varargs' and 'varkw' are the names of the * and ** parameters or None.
'defaults' is an n-tuple of the default values of the last n parameters.
'kwonlyargs' is a list of keyword-only parameter names.
'kwonlydefaults' is a dictionary mapping names from kwonlyargs to defaults.
'annotations' is a dictionary mapping parameter names to annotations.

Notable differences from inspect.signature():
  - the "self" parameter is always reported, even for bound methods
  - wrapper chains defined by __wrapped__ *not* unwrapped automatically
F)�follow_wrapper_chains�skip_bound_arg�sigcls�eval_strzunsupported callableN�returnr�)�_signature_from_callabler&r�r7�return_annotation�empty�
parameters�valuesrr��_POSITIONAL_ONLYr��default�_POSITIONAL_OR_KEYWORD�_VAR_POSITIONAL�
_KEYWORD_ONLY�_VAR_KEYWORD�
annotationr )r��sig�exr�r�r��posonlyargsr��annotations�defaults�
kwdefaults�paramrr�s&             r{rArA�s��� 8�"'�t�=B�6;�.7�05�	7���D��G��E��K��J��K��H��J�
���C�I�I�-� #� 5� 5��H�����&�&�(���z�z���z�z���#�#����t�$��}�}�E�K�K�/��]�]�,�,���
�+�
+��K�K����}�}�E�K�K�/��]�]�,�,���
�_�
$��G�
�]�
"����d�#��}�}�E�K�K�/�#(�=�=�
� ��
�\�
!��E����5�;�;�.� %� 0� 0�K��-)�0��
�����{�)�7�8�!�{�<�<��g�8�
�.�/�R�7��8�s�G
�
G)�G$�$G)zargs varargs keywords localsc�^�\VP4wrp\WW0P4#)a)Get 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.
'varargs' and 'varkw' are the names of the * and ** arguments or None.
'locals' is the locals dictionary of the given frame.)r2rNr�f_locals)�framer�r�r�s&   r{r3r3+s(��#�5�<�<�0��D�5��4�%���8�8r}�quote_annotation_stringsTc��V'g\V\4'dV#\VRR4R8Xd%Rp\P!RV\V44#\V\P4'd\V4#\V\4'dDVPRV39d
VP#VPR,VP,#\V\4'd
VP#\V4#)r'N�typingc�D�VP4pVPR4#)ztyping.)�group�removeprefix)�match�texts& r{�repl�formatannotation.<locals>.repl9s���;�;�=�D��$�$�Y�/�/r}z[\w\.]+rxr#)
rvr8r��re�sub�reprrw�GenericAliasrr'r(rn�__forward_arg__)r��base_moduler�rs&&$ r{r-r-5s���#�
�:�s�(C�(C����z�<��.�(�:�	0��v�v�j�$��Z�(8�9�9��*�e�0�0�1�1��:����*�d�#�#�� � �Z��$=�=��*�*�*��$�$�S�(��)@�)@�@�@��*�j�)�)��)�)�)��
��r}c�.a�\VRR4oV3RlpV#)r'Nc�<�\VS4#r�)r-)r�rPs&�r{�_formatannotation�5formatannotationrelativeto.<locals>._formatannotationIs����
�F�3�3r})r�)rzrrPs& @r{r.r.Gs���
�V�\�4�
0�F�4��r}c��RV,#)�*r��r�s&r{r�r�Ps��s�T�zr}c��RV,#)�**r�rs&r{r�r�Qs��T�D�[r}c�&�R\V4,#)�=)r	)r�s&r{r�r�Rs
��c�D��K�.?r}c��VWG3Rlp.p	\\V44F p
V	PV!W
,44K"	V'd+V	PV!V4V!W1,4,4V'd+V	PV!V4V!W2,4,4RRPV	4,R,#)aVFormat 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.c�8�V!V4V!W,4,#r�r�)r��locals�	formatarg�formatvalues&&&&r{�convert� formatargvalues.<locals>.convertYs������V�\�!:�:�:r}�(�, �))r@rr�rB)r�r�r�rr�
formatvarargs�formatvarkwrr�specsrGs&&&&&&&&   r{r/r/Ns���$�#�;�
�E�
�3�t�9�
��
���W�T�W�%�&���
���]�7�+�k�&�/�.J�J�K��
���[��'�+�f�m�*D�D�E�����5�!�!�C�'�'r}c�j�VUu.uFqDV9gK\V4NK	pp\V4pV^8XdV^,pMHV^8XdRP!V!pM0RP!VR
R!pVR
R1RPV4V,p\	RYV'dRMRV^8XdRMR	V3,4huupi)r<z	{} and {}z, {} and {}Nr z*%s() missing %i required %s argument%s: %s�
positional�keyword-onlyr�ra���)r	rrrBr7)	�f_name�argnames�posr�r�r��missingra�tails	&&&&     r{�_missing_argumentsr.es���$,�C�H�D�F�0B�Z�T�$�Z�H�E�C��%�j�G��!�|��!�H��	�A������&���#�#�U�2�3�Z�0���"�#�J��I�I�e��t�#��
�@��&)�l�~�#�q�L�b�c�1�6�6�7�7��
Ds
�B0�B0c
���\V4V,
p\VUu.uF
q�V9gKVNK	up4p	V'dV^8gp
RV3,pMAV'dRp
RV\V43,pM"\V4^8gp
\\V44pRpV	'd Rp
Y�^8wdRMRT	V	^8wdRMR3,p\RYV
'dRMRY\V^8XdV	'gR3,4hR	3,4huupi)
r<zat least %dTz
from %d to %dr�z7 positional argument%s (and %d keyword-only argument%s)raz5%s() takes %s positional argument%s but %d%s %s given�was�were)rr8r7)r)r��kwonlyr��defcount�givenr��atleast�arg�kwonly_given�pluralr��
kwonly_sigr�s&&&&&&&       r{�	_too_manyr:us���$�i�(�"�G��v�?�v������v�?�@�L���A����w�j�(��	�����#�d�)� 4�4���T��a����#�d�)�n���J��G���Q�J�S�B��$0�A�$5�S�2�?�?�
�
�K�
��#�R���q�j��U�
C�C�D�D�;A�
C�C�D�D��@s
�C4�C4c	�4�\V4pVwrErgr�p
VPp/p\V4'd#VPeVP3V,p\	V4p
\	V4pV'd\	V4M^p\W�4p\
V4FpVV,W�V,&K	V'd\VVR4W�&\WH,4pV'd/W�&VP4FRwppVV9d(V'g\V:RV:24hVW�,V&K4VV9d\V:RV:24hVVV&KT	W�8�dV'g\W�W�VW�4W�8d_VRW�,
pVFpVV9gK\VVRV4K	\WNV,
R4FwppVV9gKVV,VV&K	^pVF2pVV9gKV	'dVV	9dV	V,VV&K)V^,
pK4	V'd\W�RV4V#)z�Get the mapping of arguments to values.

A dict is returned, with keys the function argument names (including the
names of the * and ** arguments, if any), and values the respective bound
values from 'positional' and 'named'.Nz&() got an unexpected keyword argument z$() got multiple values for argument TF)rAr.r`r/rr?r@r�r�r�r7r:r.�	enumerate)r�r&�named�specr�r�r�r�r��kwonlydefaults�annr)�	arg2value�num_pos�num_args�num_defaults�nrG�possible_kwargs�kwr��reqr6r,�kwargs"*,                      r{r8r8�s
���$��D�FJ�C�D�5�J��
�]�]�F��I���~�~�$�-�-�3��m�m�%�
�2�
��*�o�G��4�y�H�$,�3�x�=�!�L��G��A�
�1�X��'��]�	�q�'����"�:�a�b�>�2�	���$�+�,�O���	���[�[�]�	��E�
�_�$���!'��!-�.�.�#(�I��R� ��
��?��#�R�)�*�
*��	�"�
�#���'��&�
�\��	'����+�H�+�,���C��)�#�"�6�3��i�@�� ���%<�%=� >�?�F�A�s��)�#�!)�!��	�#��@��G����	�!��%�>�"9�#1�%�#8�	�%� ��1������6�u�i�@��r}z"nonlocals globals builtins unboundc��\V4'd
VPp\V4'g\RP	V44hVP
pVPf/pM=\VPVP4UUu/uFwr4W4PbK	pppVPpVPR\P4p\V4'd
VPp/p/p\4p	\4p
\ P"!V4FOpVP$pVP&p
VR8XdV	P)V
4K5VR8XgK>V
P)V
4KQ	V
Fp
W],W}&K	\-W'W�4#uuppi \*d4Ym,Y�&K= \*dT	P)T
4K]i;ii;i)a
Get the mapping of free variables to their current values.

Returns a named tuple of dicts mapping the current nonlocal, global
and builtin references as seen by the body of the function. A final
set of unbound names that could not be resolved is also provided.
�{!r} is not a Python function�__builtins__�	LOAD_ATTR�LOAD_GLOBAL)r`r�r[r7rr��__closure__�zip�co_freevars�
cell_contents�__globals__r&rxr�rcr��dis�get_instructions�opname�argvalr�r�r)r��code�
nonlocal_vars�var�cell�	global_ns�
builtin_ns�global_vars�builtin_vars�
unbound_names�global_names�instructionrVr�s&             r{r:r:�s�����~�~��}�}���d����7�>�>�t�D�E�E��=�=�D������
�!��!1�!1�4�3C�3C�D�	�D�	��
�$�$�$�D�	�	�� � �I����~�x�/@�/@�A�J��
����(�(�
��K��L��E�M��5�L��+�+�D�1���#�#���!�!���[� ����d�#�
�}�
$����T�"�
2���	(� )��K����}�#�4�4��?	��2�	(�
(�%/�%5��"���
(��!�!�$�'�'�
(��	(�s0�	F
�3
F�G�
F,�,G
�G�G
�
G�
_Tracebackz+filename lineno function code_context indexc�@aa�]tRtRtoRR/V3RlltRtRtVtV;t#)r(i�	positionsNc�6<�\SV`WW#WE4pWgnV#r���super�__new__re)	r�rb�lineno�function�code_context�indexre�instancer0s	&&&&&&$ �r{ri�Traceback.__new__s ����7�?�3�&�L�X��&���r}c��RPVPVPVPVPVP
VP4#)zcTraceback(filename={!r}, lineno={!r}, function={!r}, code_context={!r}, index={!r}, positions={!r}))rrbrjrkrlrmrer�s&r{�__repr__�Traceback.__repr__	s@��@�@F���
�
�t�{�{�D�M�M�4�;L�;L��
�
�D�N�N�A,�	-r}r��	r.r'r(r�rirqr�r��
__classcell__�r0r�s@@r{r(r(s�����SW��
-�-r}c�Z�VPPVPr!\W4#r�)rMrN�tb_lasti�_get_code_position)�tbrX�instruction_indexs&  r{�_get_code_position_from_tbr{s#�� �k�k�0�0�"�+�+�
��d�6�6r}c��V^8dR#VP4p\\P!W!^,R44#)r�N)NNNN)�co_positions�next�	itertools�islice)rXrz�
positions_gens&& r{rxrxs;���1��'�'��%�%�'�M��	� � ��Q�0F��M�N�Nr}c��\V4'd%\V4pVPpVPpM,VPp\VPVP4pV^,fW.VR,O5vrMV.VO5vrV^,p\V4'g\RPV44h\V4;'g\V4pV^8�dgV^,
V^,,
p\V4wrg\^\V\!V4V,
44pWeWQ,pV^,
V,
pMR;rh\%WCVPP&VV\(P*!V!R7# \"dR;rhLFi;i)aGet information about a frame or traceback object.

A tuple of five things is returned: the filename, the line number of
the current line, the function name, a list of lines of context from
the source code, and the index of the current line within that list.
The optional second argument specifies the number of lines of context
to return, which are centered around the current line.Nr;z'{!r} is not a frame or traceback object)re)rfr{�	tb_linenorM�f_linenorxrN�f_lastirZr7rrMr?r,�maxr?rrLr(r�rT�	Positions)	r��contextrerjrbr�rCr�rms	&&       r{r@r@si���5���.�u�5�	�������������&�u�|�|�U�]�]�C�	���|��"�;�Y�r�]�;���	�"�/�Y�/���
�q�\�F��5�>�>��A�H�H��O�P�P��U�#�5�5�w�u�~�H���{���
�W�a�Z�'��	'�$�U�+�K�E���3�u�c�%�j�7�&:�;�<�E���
�.�E��Q�J��&�E�����X�u�|�|�';�';�U��c�m�m�Y�&?�A�A���	!� � �E�E�	!�s�4
E;�;F�Fc��VP#)zCGet the line number from a frame object, allowing for optimization.)r��r�s&r{rErEEs���>�>�r}�
_FrameInfoc�@aa�]tRtRtoRR/V3RlltRtRtVtV;t#)riKreNc	�8<�\S	V`WW#WEV4pWxnV#r�rg)
r�r�rbrjrkrlrmrernr0s
&&&&&&&$ �r{ri�FrameInfo.__new__Ls#����7�?�3�x��Y^�_��&���r}c	��RPVPVPVPVPVP
VPVP4#)zoFrameInfo(frame={!r}, filename={!r}, lineno={!r}, function={!r}, code_context={!r}, index={!r}, positions={!r}))rr�rbrjrkrlrmrer�s&r{rq�FrameInfo.__repr__QsG��@�@F���
�
�D�M�M�4�;�;��
�
��!�!�4�:�:�t�~�~�A?�	@r}r�rsrus@@r{rrKs�����Z^��
@�@r}c��.pV'dH\W4pV3V,pVP\VRVP/4VPpKOV#)z�Get a list of records for a frame and all higher (calling) frames.

Each record contains a frame object, filename, line number, function
name, a list of lines of context, and index within the context.re)r@r�rre�f_back)r�r��	framelist�traceback_info�	frameinfos&&   r{rKrKWsO��
�I�
�%�e�5���H�~�-�	�����I�R��9Q�9Q�R�S������r}c��.pV'dR\W4pVP3V,pVP\VRVP/4VP
pKYV#)z�Get a list of records for a traceback's frame and all lower frames.

Each record contains a frame object, filename, line number, function
name, a list of lines of context, and index within the context.re)r@rMr�rre�tb_next)ryr�r�r�r�s&&   r{rDrDdsS��
�I�
�%�b�2���[�[�N�^�3�	�����I�R��9Q�9Q�R�S�
�Z�Z���r}c�^�\\R4'd\P!^4#R#)z?Return the frame of the caller or None if this is not possible.�	_getframeN)r�rr�r�r}r{r+r+qs"��&�s�K�8�8�3�=�=���B�d�Br}c�B�\\P!^4V4#)z@Return a list of records for the stack above the caller's frame.)rKrr�)r�s&r{ririus���#�-�-��*�G�4�4r}c�f�\P!4pVfRMVPp\W 4#)zCReturn a list of records for the stack below the current exception.N)r�	exception�
__traceback__rD)r��excrys&  r{rjrjys)��

�-�-�/�C����#�"3�"3�B��"�&�&r}rr�c��/p\PVR4p\P	W!\
4# \dL'i;i�r�)rz�__getattribute__r�r1r&�	_sentinel)r��attr�
instance_dicts&& r{�_check_instancer��sE���M�
��/�/��Z�@�
��8�8�M��3�3���
��
�s�4�A�Ac��\V4FFp\\V44\JgK!WP9gK3VPV,u#	\#r�)�_static_getmro�_shadowed_dictrr�r�)�klassr��entrys&& r{�_check_classr��sB����&���$�u�+�&�)�3����8N��>�>�$�'�'�'��r}c���VFipV!4p\V4pRV9gKVR,p\V4\PJd$VPR8XdVP
VJdKgVu#	\#r�)�_get_dunder_dict_of_classrrwr�r.r�r�)�weakref_mro�
weakref_entryr��dunder_dict�
class_dicts*    r{�%_shadowed_dict_from_weakref_mro_tupler��sn��$�
����/��6����$�$�Z�0�J���$��(B�(B�B��'�'�:�5��+�+�u�4�!�!�%��r}c�b�\\V4Uu.uFp\V4NK	up!#uupir�)r�r��make_weakref)r�r�s& r{r�r��s2��1�+9�%�+@�	A�+@�%�,�u�
�+@�	A����	As�,c���\p\V4p\\V49dATp\V4pV\Jg\V4\P
Jd\
W4pMTp\WQ4pV\JddV\JdZ\\V4R4\Jd=\\V4R4\Jg\\V4R4\JdV#V\JdV#V\JdV#WJd_\\V44FFp\\V44\JgK!WP9gK3VPV,u#	V\JdV#\V4h)a�Retrieve attributes without triggering dynamic lookup via the
descriptor protocol,  __getattr__ or __getattribute__.

Note: this function may not be able to retrieve all attributes
that getattr can fetch (like dynamically created attributes)
and may find attributes that getattr can't (like descriptors
that raise AttributeError). It can also return descriptor objects
instead of instance members in some cases. See the
documentation for details.
r�r�r�)
r�rr�r�rwr�r�r�r�r�)	r�r�r��instance_result�objtyper��	dict_attr�klass_resultr�s	&&&      r{r6r6�s+�� �O��3�i�G��>�'�*�*���"�5�)�	���"���O�u�9�9�9�-�c�8�O������,�L��i�'�L�	�,I���\�*�I�6�i�G���l�+�Y�7�y�H��D��.��=�Y�N����i�'����9�$���
�|�#�D��K�0�E��t�E�{�+�y�8��N�N�*��~�~�d�+�+�1��i����
��
�r}c��VP'd\#VP'd\#VPf\
#\#)aGet current state of a generator-iterator.

Possible states are:
  GEN_CREATED: Waiting to start execution.
  GEN_RUNNING: Currently being executed by the interpreter.
  GEN_SUSPENDED: Currently suspended at a yield expression.
  GEN_CLOSED: Execution has completed.
)�
gi_runningr#�gi_suspendedr$�gi_framer!r")�	generators&r{rCrC�s@�����������������!����r}c��\V4'g\RPV44h\VRR4pVeVPP
#/#)z�
Get the mapping of generator local variables to their current values.

A dict is returned, with the keys the local variable names and values the
bound values.z{!r} is not a Python generatorr�N)r\r7rr�r�r�)r�r�s& r{rBrBsQ���y�!�!��8�?�?�	�J�K�K��I�z�4�0�E����!�!�*�*�*��	r}c��VP'd\#VP'd\#VPf\
#\#)aGet current state of a coroutine object.

Possible states are:
  CORO_CREATED: Waiting to start execution.
  CORO_RUNNING: Currently being executed by the interpreter.
  CORO_SUSPENDED: Currently suspended at an await expression.
  CORO_CLOSED: Execution has completed.
)�
cr_runningr�cr_suspendedr�cr_framerr
)�	coroutines&r{r=r=s@�����������������!����r}c�@�\VRR4pVe
VP#/#)z�
Get the mapping of coroutine local variables to their current values.

A dict is returned, with the keys the local variable names and values the
bound values.r�N)r�r�)r�r�s& r{r<r<,s'��
�I�z�4�0�E����~�~���	r}c��VP'd\#VP'd\#VPf\
#\#)aGet current state of an asynchronous generator object.

Possible states are:
  AGEN_CREATED: Waiting to start execution.
  AGEN_RUNNING: Currently being executed by the interpreter.
  AGEN_SUSPENDED: Currently suspended at a yield expression.
  AGEN_CLOSED: Execution has completed.
)�
ag_runningr�ag_suspendedr�ag_framerr)�agens&r{r5r5As;���������������}�}�����r}c��\V4'g\V:R24h\VRR4pVeVPP#/#)z�
Get the mapping of asynchronous generator local variables to their current
values.

A dict is returned, with the keys the local variable names and values the
bound values.z  is not a Python async generatorr�N)rQr7r�r�r�)r�r�s& r{r4r4SsK���d����4�(�"B�C�D�D��D�*�d�+�E����}�}�%�%�%��	r}r�c��VR8Xd\WR4pM\WR4pVfR#V'd\VRR7p\V\4'dR#VR8wd"\W04pV'd\VRR7pV#)z~Private helper. Checks if ``cls`` has an attribute
named ``method_name`` and returns it only if it is a
pure python function.
riNc�@�\VR4;'g\V4#��
__signature__)r��_signature_is_builtin��ms&r{r��4_signature_get_user_defined_method.<locals>.<lambda>}s"��G�A��,G�->�->�%:�1�%=�->r}�rc��\VR4#r�)r�r�s&r{r�r��s��w�q�/�/Jr})r�r6rkrv�_NonUserDefinedCallables�_descriptor_get)r��method_namer��meths&&$ r{�"_signature_get_user_defined_methodr�ps{��
�i���s��.���c��5���|����d�#>�@���$�0�1�1���i���t�)�� ��$�%J�K�D��Kr}c��VPp\VP44pVP;'gR	pVP;'g/pV'd	W%,pVP
!V/VBpRp
TP4EF�wr�TPT,p
TP\JdAT
\PJdTP\R7YK&MTP!T4KnTP\"JdeY�9dRp
TPT
R7YK&MGT
\PJd!TP\\R7pY�T&MTP!T4K�TP\$JdTPT
R7YK&T
'gEKTP\JgQhTP\"Jd5YK,P\$R7pY�T&TP)T4EKwTP\$\*39dTP)T4EK�TP\,JgEK�TP!TP.4EK�	TPTP14R7# \d#pRPT4p	\T	4ThRp?ii;i \&dEL-i;i)
z�Private helper to calculate how 'wrapped_sig' signature will
look like after applying a 'functools.partial' object (or alike)
on it.
z+partial object {!r} has incorrect argumentsNF)r�T)rr��r�r�r�)r�rrr�r��keywords�bind_partialr7rr�	argumentsrr�r��Placeholder�replace�_emptyrAr�r�r��move_to_endr�r�r�r�)�wrapped_sig�partial�
extra_args�
old_params�
new_params�partial_args�partial_keywords�bar�r��transform_to_kwonly�
param_namer��	arg_value�	new_params&&&            r{�_signature_get_partialr��s_���'�'�J��Z�-�-�/�0�J��<�<�%�%�2�L��'�'�-�-�2���!�0��&�
�
%�
%�|�
H�7G�
H�� ��'�-�-�/��
�2	J����Z�0�I��z�z�-�-�
�	� 5� 5�5�-2�]�]�6�]�-J�J�*��N�N�:�.���z�z�3�3��1�+/�'�-2�]�]�9�]�-M�J�*�!�I�$9�$9�9�$)�M�M�!1�$*�%2�%�	�2;�:�.�"���z�2���z�z�]�*�).���y��)I�
�&����:�:�%5�5�5�5��z�z�3�3�&�2�:�:�
�:�N�	�)2�:�&��&�&�z�2����
�|�<�<��&�&�z�2�����.����u�z�z�*�0�B���*�*;�*;�*=��>�>��O�&�;�B�B�7�K����o�2�%��&���	��	�s*�#J�J4�J1�J,�,J1�4K�Kc�\�\VPP44pV'd#V^,P\\
39d\
R4hV^,PpV\\39dVR,pMV\Jd\
R4hVPVR7#)zOPrivate helper to transform signatures for unbound
functions to bound methods.
zinvalid method signaturer;zinvalid argument typer�)r�r�r�rr�r�rr�r�r�r�)r��paramsrs&  r{�_signature_bound_methodr��s���
�3�>�>�(�(�*�
+�F��V�A�Y�^�^��m�'D�D��3�4�4��!�9�>�>�D��&�(8�9�9�������&��4�5�5��;�;�&�;�)�)r}c��\V4;'gD\V4;'g1\V\4;'gV\J;'g	V\
J#)zpPrivate helper to test if `obj` is a callable that might
support Argument Clinic's __text_signature__ protocol.
)rTrarvr�rrzr�s&r{r�r��s]��
�c�N�
)�
)��s�#�
)�
)��s�4�5�
)�
)�
�4�K�
)�
)��&�=�*r}c��\V4'd\V4'dR#\VRR4p\VRR4p\VR\4p\VR\4p\	V\
P4;'dY\	V\4;'dAVRJ;'g\	V\4;'dVRJ;'g\	V\4#)z�Private helper to test if `obj` is a duck type of FunctionType.
A good example of such objects are functions compiled with
Cython, which have all attributes that a pure Python function
would have, but have their code statically compiled.
Fr.Nr��__defaults__�__kwdefaults__)
�callablerUr��_voidrvrwr�r8r�r1)r�r�rXr�r�s&    r{r�r�
s����C�=�=�G�C�L�L���3�
�D�)�D��3�
�D�)�D��s�N�E�2�H���.��6�J��t�U�^�^�,�
A�
A��t�S�!�
A�
A�
��
�
<�
<��H�e�!<�
A�
A��4�
�
?�
?�:�j�$�#?�Br}c���V'gVR3#RpVPR4Uu.uFq"'gKVPR4NK	pp\V4Pp\P!V4p.pVP
p^p\Pp	\Pp
\V4pVP\P8XgQhVF`pVPVPr�W�8XdV
R8Xd
V^,
pW�8XdV
R8XdVeQhTpKGV!V
4V
R8XgKXV!R4Kb	RPV4P4PRR4pW�3#uupi)a-
Private helper function. Takes a signature in Argument Clinic's
extended signature format.

Returns a tuple of two things:
  * that signature re-rendered in standard Python syntax, and
  * the index of the "self" parameter (generally 0), or None if
    the function does not have a "self" parameter.
Nr:�ascii�,�$r=r�)r)�encoder�r�r�r�r��OP�
ERRORTOKENr~r�ENCODING�stringrBr�r�)rh�self_parameter�lrCr��token_streamrr��current_parameterrr�trr�clean_signatures&              r{�"_signature_strip_non_python_syntaxr
$sF����$����N�(1����(=�C�(=�1��
�Q�X�X�g�
�(=�E�C��U��$�$�I��$�$�Y�/�L�
�D�
�+�+�C���	���B��!�!�J�	
�\��A��6�6�X�&�&�&�&�&�
���v�v�q�x�x�f��:���}�!�Q�&�!��J�V�s�]�!�)�)�)�.�N���F���c�M���H���g�g�d�m�)�)�+�3�3�D�"�=�O��*�*��?
Ds
�	E&�E&c� aaaaaaaaaa�VPo\V4wrERV,R,p\P!V4p\V\P4'g\RPS44hVP^,p.oSPoRp/o\SRR4p	V	'g\SRR4p
\V
RR4p	V	'd5\PPV	R4pV'd
VPo\PP!4oRoVV3Rlo!V3R	lR
\P"4oS3VVVVVVV3Rllp\%VP&P(4\%VP&P&4,pV\%VP&P*4,
p
\,P.!\,P0!RV
4VP&P*4pSP2o\5VP&P(V4FwppV!VV4K	SP6o\5VP&P&V4FwppV!VV4K	VP&P8'd*SP:oV!VP&P8S4SP<o\5VP&P>VP&P@4FwppV!VV4K	VP&PB'd*SPDoV!VP&PBS4VeyS'gQh\SRR4pVRJp\GV4pV'd#V'g	V'dSPI^4M(S^,PKSP2R
7pVS^&V!SVPR7# \dRpEL�i;i)z\Private helper to parse content of '__text_signature__'
and return a Signature based on it.
zdef fooz: passN�"{!r} builtin has invalid signaturer'r�c��\V\P4'gQhVPe\	R4hVP#)Nz'Annotations are not currently supported)rv�astr6r�r)�nodes&r{�
parse_name�&_signature_fromstr.<locals>.parse_name{s8���$����(�(�(�(��?�?�&��F�G�G��x�x�r}c�&<�\VS4p\T\\
\\\\R434'd\P!T4#\h \d&\TS4pLk \d\hi;ii;ir�)�eval�	NameErrorrrvr8�int�float�bytesr�rr�Constant)rar��module_dict�sys_module_dicts& ��r{�
wrap_value�&_signature_fromstr.<locals>.wrap_value�s����	!���K�(�E��e�c�3��u�d�D��J�G�H�H��<�<��&�&�����	!�
!��Q��0����
!� � �
!��	!�s�A � B�,A:�:B�Bc�@<a�]tRtRtoV3RltV3RltRtRtVtR#)�,_signature_fromstr.<locals>.RewriteSymbolicsi�c�d<�.pTp\V\P4'd*VPVP4VP
pKI\V\P4'g\hVPVP4RP\V44pS!V4#)r#)rvrrr�r�r��NamerrrB�reversed)r3r�arEr�rs&&   �r{�visit_Attribute�<_signature_fromstr.<locals>.RewriteSymbolics.visit_Attribute�sz����A��A��Q��
�
�.�.������� ��G�G���a����*�*� � �
�H�H�Q�T�T�N��H�H�X�a�[�)�E��e�$�$r}c�<�\VP\P4'g\	4hS!VP
4#r�)rv�ctxr�Loadrr)r3rrs&&�r{�
visit_Name�7_signature_fromstr.<locals>.RewriteSymbolics.visit_Name�s/����d�h�h����1�1� �l�"��d�g�g�&�&r}c�(�VPVP4pVPVP4p\V\P
4'd!\V\P
4'g\h\VP\P4'd2\P
!VPVP,4#\VP\P4'd2\P
!VPVP,
4#\VP\P4'd2\P
!VPVP,4#\hr�)�visit�left�rightrvrrr�op�Addr��Sub�BitOr)r3rr,r-s&&  r{�visit_BinOp�8_signature_fromstr.<locals>.RewriteSymbolics.visit_BinOp�s����:�:�d�i�i�(�D��J�J�t�z�z�*�E��d�C�L�L�1�1��E�3�<�<�9X�9X� � ��$�'�'�3�7�7�+�+��|�|�D�J�J����$<�=�=��D�G�G�S�W�W�-�-��|�|�D�J�J����$<�=�=��D�G�G�S�Y�Y�/�/��|�|�D�J�J����$<�=�=��r}r�N)	r.r'r(r�r#r(r2r�r�)r�rs@�r{�RewriteSymbolicsr�s����
	%�	'�

	�
	r}r4c	� <�S
!V4pV'd8V\Jd.S!4PV4p\P!V4pS	P
S!VSVSR74R# \d\	RPS44Rhi;i)rN�r�r�)r�r+r�literal_evalrrr�)�	name_node�default_noder�r�r%r4r�rr�r�rs&&& �������r{�p�_signature_fromstr.<locals>.p�s�����)�$���L��6�
]�/�1�7�7��E���*�*�<�8��	���)�D�$��E�R�S���
]� �!E�!L�!L�S�!Q�R�X\�\�
]�s�,A&�&'B
r/r��r�)&�_parameter_clsr
r�parser�rv�Modulerr�bodyr�r�rr%r&r�r{�NodeTransformerrr�r�r�r�chain�repeat�POSITIONAL_ONLYrP�POSITIONAL_OR_KEYWORD�vararg�VAR_POSITIONAL�KEYWORD_ONLYr��kw_defaultsrI�VAR_KEYWORDrcrAr�)r�r�rar�r	r�programrPr��module_name�objclassr:�total_non_kw_args�required_non_kw_argsr�r�r��_self�self_isbound�
self_ismoduler%r4r�rrr�rrrs&f&&                @@@@@@@@@r{�_signature_fromstrrSVs�����"�"�I�&H��&K�#�O��/�)�H�4�G�����7�#���f�c�j�j�)�)��=�D�D�S�I�J�J����A��A��J��O�O�E�
�F��K��#�|�T�2�K���3���5���h��d�;���������d�3��� �/�/�K��k�k�&�&�(�O����3�.�.��B,1�T�T��A�F�F�.�.�/�#�a�f�f�k�k�2B�B��,�s�1�6�6�?�?�/C�C�����y�/�/��6J�K�Q�V�V�_�_�]�H��$�$�D��q�v�v�1�1�8�<���w�	�$���=��*�*�D��q�v�v�{�{�H�5���w�	�$���6�	�v�v�}�}�}��'�'��	�!�&�&�-�-����!�!�D��Q�V�V�.�.����0B�0B�C�
��g�	�$���D�	�v�v�|�|�|��$�$��	�!�&�&�,�,����!���z���Z��.���D�(�� ���
��]�n��N�N�1���1�
�%�%�9�+D�+D�%�E�A��J�q�M��z�S�Y�Y�7�7��I�����s�O<�<
P
�P
c���\V4'g\RPV44h\VRR4pV'g\	RPV44h\WW24#)z@Private helper function to get signature for
builtin callables.
z%{!r} is not a Python builtin function�__text_signature__Nz#no signature found for builtin {!r})r�r7rr�rrS)r�r�r�ras&&& r{�_signature_from_builtinrV�sb��
!��&�&��#�#)�6�$�<�1�	1�	��*�D�1�A���>�E�E�d�K�L�L��c��;�;r}�annotation_formatc
��Rp\V4'g/\V4'dRpM\RPV44h\	VRR4pV'd
\WW�4#VPp	VPp
V
PpV
PpV
Pp
VRVpV
PpW�W�,p\WWEVR7pVPpVPpV'd
\V4pM^p.pVV,
pT
pVRVFZpV'd\ M\"pVP%V\&4pVP)V	!VVVR74V'gKQV^,pK\	\+VVR4FewppV'd\ M\"pVP%V\&4pVP)V	!VVVVV,R74V'gK\V^,pKg	V
P,\.,'dDW�V,,pVP%V\&4pVP)V	!VV\0R74VFXp\&pVeVP%V\&4pVP%V\&4pVP)V	!VV\2VR74KZ	V
P,\4,'dlW�,pV
P,\.,'d
V^,
pVV,pVP%V\&4pVP)V	!VV\6R74V!VVP%R	\&4VR
7#)zCPrivate helper: constructs Signature for the given python function.FTrKrUN)�globalsrr�r)r�r)r�rr�r�)r��__validate_parameters__)r[r�r7rr�rSr=r�r�r��co_posonlyargcountr�r0r�r�rr�r�r&r�r�r<r�rr�r�rr�)r�r�r�rYrr�rW�is_duck_functionrar%�	func_code�	pos_count�	arg_names�
posonly_countr&�keyword_only_count�keyword_onlyr�r�r��pos_default_countr��non_default_count�posonly_leftr�rr��offsetr�rms&&&&&&$                       r{�_signature_from_functionrg�s��
���d���%�d�+�+�#���;�B�B�4�H�I�I���*�D�1�A��!�#�Q�?�?��"�"�I��
�
�I��%�%�I��%�%�I��0�0�M��:�I�&�J�"�4�4���y�'E�F�L�!�$��):�<�K�� � �H��$�$�J����M�����J�!�$5�5�� �L��-�-�.��#/��5K�� �_�_�T�6�2�
����)�D�Z�)-�/�	0��<��A��L�
/�"�*�->�-?�"@�A����#/��5K�� �_�_�T�6�2�
����)�D�Z�)-�,4�V�,<�>�	?��<��A��L�B����J�&�&��%7�7�8�� �_�_�T�6�2�
����)�D�Z�)8�:�	;������!� �n�n�T�6�2�G� �_�_�T�6�2�
����)�D�Z�)6�,3�5�	6�
����N�*�*��.�����
�*�*��Q�J�E����� �_�_�T�6�2�
����)�D�Z�)5�7�	8�
�z�!,����6�!B�'7�9�9r}c��\V4'dV#\\V4R\4pV\JdV#V!W\V44#)r�)rUr�rr�)�
descriptorr�r&s&& r{r�r�Z	sE���z�����
�$�z�"�I�y�
9�C�
�i�����z��S�	�*�*r}r�rYrr�c�V
�\P!\VVVVVVVR7p\V4'g\	RPV44h\
V\P4'd(V!VP4p	V'd\V	4#V	#V'd7\VRR7p\
V\P4'd	V!V4#VPp	V	e3\
V	\4'g\	RPV	44hV	#VPp
\
V
\P 4'Ed
V!V
P"4p\%W�R4p	\'VP(P+44^,pVP,\.P0JdV	#\'V	P(P+44p
V
'dW�^,JgQhV
P2P5\P64'd!VP9\.P:R7pV3V
,pV	P9VR7#\
V\P4'dV!VP"4p\%W�4#\=V4'g\?V4'd\AW`VW4VVR	7#\CV4'd\EW`VR
7#\
V\F4'Ed�\I\GV4RVR7pVe	V!V4#\IVR
VR7p\IVRVR7pVPJFXpVe1R
VPL9d V!V4p	V'd\V	4p	V	u#VfK=RVPL9gKPV!V4u#	VPJRRF'pVPNpV'd\QVVV4u#K)	\FVPJ9d�VPRpVPTpV'd\V4p\V4pV\VPRJd*V\VPTJdVPY\V4#\[RPV44hMO\]\GV4RR4pVe6VPNpV'd
\QW`V4#\_W�4pV!V4#\[RPV44h \dEL�i;i \dEL�i;i \dEKji;i \dLqi;i)zIPrivate helper function to get signature for arbitrary
callable objects.
)r�r�rYrr�r�rWz{!r} is not a callable objectc�^�\VR4;'g\V\P4#r�)r�rvrwr�r�s&r{r��*_signature_from_callable.<locals>.<lambda>�	s-��'�!�_�*E�+C�+C�#-�a��1A�1A�#B�+Cr}r�Nz1unexpected object {!r} in __signature__ attributer�r�)r�rYrr�rW)r��__call__)r�rir�z(no signature found for builtin type {!r}z+callable {!r} is not supported by signaturer�r$)0r�r�r�r�r7rrvrwr�r�r�rkr�r&r��__partialmethod__�
partialmethodr�r�r�r�r�rr%rGr��countr�r�rDr[r�rgr�rVrr�rr�rUrSr�rirz�
from_callablerr6r�)r�r�r�rYrr�r�rW�_get_signature_ofr�ror��first_wrapped_param�
sig_paramsr��call�new�initr��text_sig�obj_init�obj_news&$$$$$$$              r{r�r�c	s���"�)�)�*B�6K�/=�(/�'-�'-�)1�2C�E���C�=�=��7�>�>�s�C�D�D��#�u�'�'�(�(� ����-���*�3�/�/��J���S�!C�E���c�5�+�+�,�,�%�S�)�)�
������?��c�9�-�-�� � &��s��-�-��J��:��-�-�
��m�Y�%<�%<�=�=�,�M�,>�,>�?�K�(��W�M�C�"'��(>�(>�(E�(E�(G�"H��"K��"�'�'�9�+C�+C�C��
�"�3�>�>�#8�#8�#:�;�
�&�+�a�=�@�B�A�!�%�%�+�+�I�,A�,A�B�B�*=�*E�*E�&�6�6�+F�+8�'�1�3�j�@�
��{�{�j�{�9�9�5>�8�#�y�(�(�)�)�'����1��%�k�7�7��#���4�S�9�9�(��7E�07�QY�:K�M�	M�
�S�!�!�&�v�6D�F�	F��#�t���
2���I��"7�
��
��$�T�*�*�1���"7�
��
2���"7�
���K�K�D���9��
�
�#=�'��,��!�1�#�6�C��
��!�j�D�M�M�&A�(��.�.� ��K�K���$�D�
F��2�2���.�f�d�H�E�E��%�*�s�{�{�"��|�|�H��k�k�G�$�!�(�+�� ��/���6�?�?�*�w�&�.�.�/H��+�+�F�3�3� �>�E�E�c�J�L�L�#�"�d�3�i��T�:����
E��1�1���-�f�8�D�D��"�4�-�D�$�T�*�*�
�B�I�I�#�N�
O�O��o�
��
���
��
��F"�
��
��@"�
��
�sH�S#�S5�0T�T�#S2�1S2�5T�T�T�T�T(�'T(c��]tRtRtRtRtR#)r�i.
z1A private marker - used in Parameter & Signature.r�N�r.r'r(r�r-r�r�r}r{r�r�.
s��;r}r�c��]tRtRtRtRtR#)r�i2
z6Marker object for Signature.empty and Parameter.empty.r�Nr|r�r}r{r�r�2
s��@r}r�c�@a�]tRtRtoRtRtRtRtRtRt	Rt
R	tVtR
#)�_ParameterKindi6
zpositional-onlyzpositional or keywordzvariadic positionalr'zvariadic keywordc�r�\VP4p\PW4pW#nWnV#r�)r�__members__rri�_value_�description)r�r�r��members&&  r{ri�_ParameterKind.__new__=
s.���C�O�O�$�����S�(����(���
r}c��VP#r�rr�s&r{�__str__�_ParameterKind.__str__D
s���y�y�r}r�N)
r.r'r(r�rDrErGrHrJrir�r�r�r�s@r{rr6
s.����'�O�3��*�N�!�L�$�K���r}rc��a�]tRtRtoRtRt]t]t	]
t]t
]t]tR]R]/RltRtRt]R4t]R	4t]R
4t]R4tR]R
]R]R]/RltRtRR/Rlt]tRtRt Rt!Rt"Vt#R#)r%iN
a�Represents a parameter in a function signature.

Has the following public attributes:

* name : str
    The name of the parameter as a string.
* default : object
    The default value for the parameter if specified.  If the
    parameter has no default value, this attribute is set to
    `Parameter.empty`.
* annotation
    The annotation for the parameter if specified.  If the
    parameter has no annotation, this attribute is set to
    `Parameter.empty`.
* kind : str
    Describes how argument values are bound to the parameter.
    Possible values: `Parameter.POSITIONAL_ONLY`,
    `Parameter.POSITIONAL_OR_KEYWORD`, `Parameter.VAR_POSITIONAL`,
    `Parameter.KEYWORD_ONLY`, `Parameter.VAR_KEYWORD`.
r�r�c���\V4VnT\JdNTP\\
39d3RpTP
TPP4p\T4hY0nY@n	T\Jd\R4h\T\4'g0RP
\T4P4p\T4hT^,R8Xd�TR,P4'dkTP\ 8wd3RpTP
TPP4p\T4h\"TnRP
TR,4p\%T4;'dTP\"JpT'gTP'4'g\R	P
T44hYnR
# \d\RT:R24hi;i)zvalue z is not a valid Parameter.kindz({} parameters cannot have default valuesz*name is a required attribute for Parameterzname must be a str, not a {}r#r;zLimplicit arguments must be passed as positional or keyword arguments, not {}z
implicit{}z"{!r} is not a valid parameter nameN)r�_kindrr�r�r�rr��_default�_annotationrvr8rr.r7�isdigitr�r�ro�isidentifier�_name)r3r�rr�r�r��
is_keywords&&&$$  r{r��Parameter.__init__n
s���	N�'��-�D�J��&� ��z�z�o�|�<�<�@���j�j����!7�!7�8�� ��o�%��
�%���6�>��I�J�J��$��$�$�0�7�7��T�
�8K�8K�L�C��C�.� ���7�c�>�d�2�h�.�.�0�0�
�z�z�3�3�>���j�j����!7�!7�8�� ��o�%�)�D�J��&�&�t�B�x�0�D��t�_�K�K����;K�)K�
��T�.�.�0�0��A�H�H��N�O�O��
��M�	N��v�d�X�-K�L�M�M�	N�s�G	�	G%c�z�\V4VPVP3RVPRVP/3#�r�r�)rr�r�r�r�r�s&r{�
__reduce__�Parameter.__reduce__�
s<���T�
����T�Z�Z�(��T�]�]��� 0� 0�2�3�	3r}c�>�VR,VnVR,VnR#)r�r�Nr��r3�states&&r{�__setstate__�Parameter.__setstate__�
s���j�)��
� ��/��r}c��VP#r�)r�r�s&r{r��Parameter.name�
����z�z�r}c��VP#r�)r�r�s&r{r��Parameter.default�
s���}�}�r}c��VP#r�)r�r�s&r{r��Parameter.annotation�
������r}c��VP#r�)r�r�s&r{r�Parameter.kind�
r�r}r�rc���V\Jd
VPpV\Jd
VPpV\Jd
VPpV\Jd
VPp\V4!WWCR7#)z+Creates a customized copy of the Parameter.r6)r�r�r�r�r�r)r3r�rr�r�s&$$$$r{r��Parameter.replace�
sY���5�=��:�:�D��5�=��:�:�D�����)�)�J��e���m�m�G��D�z�$�g�M�Mr}c�"�VP4#r�)�_formatr�s&r{r��Parameter.__str__�
s���|�|�~�r}r�Tc���VPpVPpVP\Jd)\	VPVR7pRPW44pVP\Jd`VP\Jd'RPV\VP44pM%RPV\VP44pV\8XdRV,pV#V\8Xd
RV,pV#)�r�z{}: {}z{} = {}z{}={}rr)
rr�r�r�r-rr�r	r�r�)r3r�r�	formattedr�s&$   r{r��Parameter._format�
s����y�y���J�J�	����6�)�)�$�*:�*:�C[�]�J� ���	�>�I��=�=��&����v�-�%�,�,�Y��T�]�]�8K�L�	�#�N�N�9�d�4�=�=�6I�J�	��?�"��i��I����\�
!��y�(�I��r}c�N�RPVPPV4#)z	<{} "{}">�rr0r.r�s&r{rq�Parameter.__repr__�
s���!�!�$�.�.�"9�"9�4�@�@r}c�p�\VPVPVPVP34#r�)�hashr�r�r�r�r�s&r{�__hash__�Parameter.__hash__�
s(���T�Z�Z����T�-=�-=�t�}�}�M�N�Nr}c�@�WJdR#\V\4'g\#VPVP8H;'d\VPVP8H;'d;VP
VP
8H;'dVPVP8H#�T)rvr%�NotImplementedr�r�r�r��r3�others&&r{�__eq__�Parameter.__eq__�
s����=���%��+�+�!�!��
�
�e�k�k�)�6�6��
�
�e�k�k�)�6�6��
�
����/�6�6�� � �E�$5�$5�5�	7r})r�r�r�r�N)r�r�r�r�)$r.r'r(r�r-r,r�rDr�rEr�rGr�rHr�rJr�r�r�r�r�r�r�r�r�rr�r�r�r��__replace__rqr�r�r�r�r�s@r{r%r%N
s������*>�I�.�O�4��-�N�+�L�*�K��E�)�f�)��)�V3�0���������� �� �����N�e�N�%�N� �N�*/�N�$��$��.�K�A�O�7�7r}c�|a�]tRtRtoRtRtRt]R4t]R4t	]R4t
RtRtR	t
R
tRtRtVtR
#)r
i�
a�Result of `Signature.bind` call.  Holds the mapping of arguments
to the function's parameters.

Has the following public attributes:

* arguments : dict
    An ordered mutable mapping of parameters' names to arguments' values.
    Does not contain arguments' default values.
* signature : Signature
    The Signature object that created this instance.
* args : tuple
    Tuple of positional arguments values.
* kwargs : dict
    Dict of keyword arguments values.
c��W nWnR#r�)r��
_signature)r3rhr�s&&&r{r��BoundArguments.__init__s��"��#�r}c��VP#r�)r�r�s&r{rh�BoundArguments.signature	s�����r}c�p�.pVPPP4Fowr#VP\\
39dMQVPV,pVP\8XdVPV4K^VPV4Kq	\V4# \dKi;ir�)r�r�r�rr�r�r�r��extendr�r�r�)r3r�r�r�r6s&    r{r��BoundArguments.args
s�����!%���!;�!;�!A�!A�!C��J��z�z�l�M�:�:��
%��n�n�Z�0���:�:��0��K�K��$��K�K��$�!"D�$�T�{����
��
�s�
B%�%B5�4B5c��/pRpVPPP4F�wr4V'g3VP\\
39dRpMW0P9dRpK?V'gKIVPV,pVP\8XdVPV4K�WQV&K�	V# \dK�i;i)FT)	r�r�r�rr�r�r��updater�)r3�kwargs�kwargs_startedr�r�r6s&     r{r��BoundArguments.kwargs$s�������!%���!;�!;�!A�!A�!C��J�!��:�:�,�
�!>�>�%)�N�!���7�)-�� �!��

-��n�n�Z�0���:�:��-��M�M�#�&�*-�:�&�-"D�0�
���
��
�s�3B8�8C�Cc��VPp.pVPPP4Fwr4VP	W1V,34K!	\V4VnR# \
diTP\JdTPpM1TP\JdRpMTP\Jd/pMK�TP	Y534K�i;i)z�Set default values for missing arguments.

For variable-positional arguments (*args) the default is an
empty tuple.

For variable-keyword arguments (**kwargs) the default is an
empty dict.
Nr�)r�r�r�r�r�r�r�r�rr�r�r1)r3r��
new_argumentsr�r��vals&     r{�apply_defaults�BoundArguments.apply_defaultsBs����N�N�	��
��?�?�5�5�;�;�=�K�D�

2��$�$�d�d�O�%<�=�>��m�,�����
2��=�=��.��-�-�C��Z�Z�?�2��C��Z�Z�<�/��C���$�$�d�[�1�
2�s�A(�(AC�C�Cc��WJdR#\V\4'g\#VPVP8H;'dVPVP8H#r�)rvr
r�rhr�r�s&&r{r��BoundArguments.__eq__^sL���=���%��0�0�!�!����%�/�/�1�2�2����%�/�/�1�	3r}c�>�VR,VnVR,VnR#)r�r�N�r�r�r�s&&r{r��BoundArguments.__setstate__fs����-����{�+��r}c�6�RVPRVP/#r�r�r�s&r{�__getstate__�BoundArguments.__getstate__js���d�o�o�{�D�N�N�K�Kr}c��.pVPP4F%wr#VPRPW#44K'	RPVPP
RP
V44#)z{}={!r}z	<{} ({})>r )r�r�r�rr0r.rB)r3r�r6r�s&   r{rq�BoundArguments.__repr__ms\�����.�.�.�.�0�J�C��K�K�	�(�(��4�5�1��!�!�$�.�.�"9�"9�4�9�9�T�?�K�Kr}r�N)r�r��__weakref__)r.r'r(r�r-r,r�r�rhr�r�r�r�r�r�rqr�r�r�s@r{r
r
�
ss����� ;�I�$���������,����:-�83�,�L�L�Lr}c�a�]tRtRtoRtR"t]t]t	]
tR#R]
RR/Rllt]
RRR	RR
RRRR
]P/Rl4t]R4t]R4tR]R]/Rlt]tRtRtRtRR/RltRtRtRtRtRtRt RRRR/R lt!R!t"Vt#R#)$r&ita�A Signature object represents the overall signature of a function.
It stores a Parameter object for each parameter accepted by the
function, as well as information specific to the function itself.

A Signature object has the following public attributes and methods:

* parameters : OrderedDict
    An ordered mapping of parameters' names to the corresponding
    Parameter objects (keyword-only arguments are in the same order
    as listed in `code.co_varnames`).
* return_annotation : object
    The annotation for the return type of the function if specified.
    If the function has no annotation for its return type, this
    attribute is set to `Signature.empty`.
* bind(*args, **kwargs) -> BoundArguments
    Creates a mapping from positional and keyword arguments to
    parameters.
* bind_partial(*args, **kwargs) -> BoundArguments
    Creates a partial mapping from positional and keyword arguments
    to parameters (simulating 'functools.partial' behavior.)
Nr�rZTc���Vf
\4pEMBV'Ed(\4p\pRp\4pVEFpVPp	VPp
V	\
\39d3W�9dRV	PR2p\V4hVPV	4W�8d4RpVPVPV	P4p\V4hW�8�dT	pV	\\39d-VP\JdV'dRp\V4hMRpW�9dRPV
4p\V4hW�V
&EK	M\R	V44p\P!V4VnW nR#)
ztConstructs Signature from the given list of Parameter
objects and 'return_annotation'.  All arguments are optional.
NFzmore than one z
 parameterz7wrong parameter order: {} parameter before {} parameterz-non-default argument follows default argumentTzduplicate parameter name: {!r}c3�<"�TFqPV3x�K	R#5ir�r�r�r�s& r{r��%Signature.__init__.<locals>.<genexpr>�s���$Q�j�U�j�j�%�%8�j�s�)rrr�r�rr�r�r�r�rr�rr�r�r�rw�MappingProxyType�_parameters�_return_annotation)r3r�r�rZr��top_kind�seen_default�seen_var_parametersr�rr�r�s&&$$        r{r��Signature.__init__�s^���� �]�F�&�&�$���+��$��&)�e�#�'�E� �:�:�D� �:�:�D����>�>��6�$2�4�3C�3C�2D�J�"O�C�",�S�/�1�+�/�/��5���(��"�j�j��)=�)=�)-�)9�)9�;��(��o�-���#'��� 0�2H�I�I� �=�=�F�2�+�'1��&0��o� 5� ,�,0�L��~�>�E�E�d�K��(��o�-�#(�4�L�M(�P%�$Q�j�$Q�Q�� �1�1�&�9���"3�r}�follow_wrappedrYrr�FrWc
�"�\WVW4VVR7#)z3Constructs Signature for the given callable object.)r�r�rYrr�rW)r�)r�r�r�rYrr�rWs&&$$$$$r{rq�Signature.from_callable�s!��
(��>L�07�QY�:K�M�	Mr}c��VP#r�)r�r�s&r{r��Signature.parameters�r�r}c��VP#r��r�r�s&r{r��Signature.return_annotation�s���&�&�&r}r�c��V\JdVPP4pV\Jd
VPp\	V4!VVR7#)z�Creates a customized copy of the Signature.
Pass 'parameters' and/or 'return_annotation' arguments
to override them in the new copy.
r<)r�r�r�r�r)r3r�r�s&$$r{r��Signature.replace�sH��������/�/�1�J���%� $� 7� 7���D�z�*�,=�?�	?r}c�v�\;QJd,.RVPP44FNK	5M%!RVPP444pVPP4Uu/uF'pVP\8XgKVP
VbK)	ppWVP3#uupi)c3�T"�TFpVP\8wgKVx�K 	R#5ir�)rr�r�s& r{r��(Signature._hash_basis.<locals>.<genexpr>�s%���=�*B�� %�
�
�m� ;��u�*B�s�(�
()r�r�r�rr�r�r�)r3r�r��
kwo_paramss&   r{�_hash_basis�Signature._hash_basis�s�����=�$�/�/�*@�*@�*B�=���=�$�/�/�*@�*@�*B�=�=��6:�_�_�5K�5K�5M�H�5M�E�+0�:�:��+F�(�e�j�j�%�'�5M�
�H��4�#9�#9�9�9��Hs�9B6�B6c�t�VP4wrp\VP44p\WV34#r�)r��	frozensetr�r�)r3r�r�r�s&   r{r��Signature.__hash__�s:��04�0@�0@�0B�-��-��z�0�0�2�3�
��V�):�;�<�<r}c��WJdR#\V\4'g\#VP4VP48H#r�)rvr&r�r�r�s&&r{r��Signature.__eq__�s:���=���%��+�+�!�!����!�U�%6�%6�%8�8�8r}r�c	��/p\VPP44pRp\V4p.p\V4p	\V4p
V
P\
\39d
\R4RhV
P\8Xd-V	.pVPV4\V4WJP&M\V
PV9d<V
P\8wd'\RPV
PR74RhW�V
P&K�Rp\$P&!We4FUp
V
P\
8XdT
pKV
P\8XdK3V
PpVP)V4p	W�V&KW	V'dzVeW$VP&MfV'd2\RPRP-R
V44R74h\RP\\V44R74hVP/W4# \d\R4Rhi;i \Ed0\T4p
T
P\8XdEKOT
PT9daT
P\8XdET
P\ JdRT
P:2p\T4hTP#T
4EK�T
3pEK�T
P\
8XgT
P\ JdT
3pEK�T'dT
3pEK�T
P\8XdRp
MRp
RpTPT
PT
R	7p\T4Rh \dEKTi;ii;i \*d[T'gNT
P\8wd5T
P\ Jd\R
PTR74RhEK�EK�EK�i;i)z#Private method. Don't use directly.ztoo many positional argumentsNz$multiple values for argument {arg!r})r6z-missing a required positional-only argument: z
 keyword-onlyr�z-missing a required{argtype} argument: {arg!r})r6�argtypez$missing a required argument: {arg!r}zGgot some positional-only arguments passed as keyword arguments: {arg!r}r c3�:"�TFpVPx�K	R#5ir�rr�s& r{r��"Signature._bind.<locals>.<genexpr>�s���&�)A��"�J�J�)A�s�z*got an unexpected keyword argument {arg!r}r�)r�r�r�r~rr�r�r7r�r�r�r�r�r�
StopIterationr�r�r�rrBrAr�rB�_bound_arguments_cls)r3r�r�r�r�r��
parameters_ex�arg_vals�pos_only_param_in_kwargs�arg_valr�r�r�r��kwargs_paramr�s&&&$            r{�_bind�Signature._binds����	��$�/�/�0�0�2�3�
��
���:��#%� ��J
4��x�.��`4� ��,�E��z�z�l�M�%B�B�(�;�=�BF�G��z�z�_�4�#*����
�
�h�/�05�f�
�	�*�*�-���z�z�V�+��
�
�>N�0N�'�B�I�I�$)�J�J�J�0�1�6:�;�-4�e�j�j�)����_�_�]�?�E��z�z�\�)�$����z�z�_�,�����J�

0� �*�*�Z�0��)0�*�%�5@�8��'�/5�,�+�+�,�)��1�17�� �I�I�&�)A�&��28�2��� �@�G�G� ��f��.�H�0�1�1��(�(��9�9��W%�O�#�$C�D�$�N�O��c!�,
;�*;� ��,�E��z�z�_�4�����v�-� �:�:�)9�9�$�}�}��6�(U�V[�V`�V`�Uc�&d��&/��n� 4�5�;�;�E�B�$�).��
���*�*��4�05�
�
�V�0K�*/��
��#�-2�H�M�!�$�z�z�]�:�*9��*,��"Q�C�"%�*�*����W�*�"M�C�"+�C�.�d�:��Q%�����	,
;��x�
F�
 �E�J�J�/�$A�49�M�M�V�4K�#�$J�$*�F�z�F�$:�<�AE�F�5L�%B��
F�sz�H0�H�*M.�H-�0M+�=M�M+�!A&M+�M+�,M+�M+�
M+�AM+�M'�!M+�&M'�'M+�.O�AO�Oc�$�VPW4#)z�Get a BoundArguments object, that maps the passed `args`
and `kwargs` to the function's signature.  Raises `TypeError`
if the passed arguments can not be bound.
�r�r3r�r�s"*,r{�bind�Signature.bind�s��
�z�z�$�'�'r}c�(�VPWRR7#)z�Get a BoundArguments object, that partially maps the
passed `args` and `kwargs` to the function's signature.
Raises `TypeError` if the passed arguments can not be bound.
T)r�rrs"*,r{r��Signature.bind_partial�s��
�z�z�$��z�5�5r}c�z�\V4\VPP443RVP/3#r�)rr�r�r�r�r�s&r{r��Signature.__reduce__�s=���T�
��t�'�'�.�.�0�1�3�%�t�'>�'>�?�A�	Ar}c�"�VR,VnR#)r�Nr�r�s&&r{r��Signature.__setstate__�s��"'�(<�"=��r}c�N�RPVPPV4#)z<{} {}>r�r�s&r{rq�Signature.__repr__�s�������� 7� 7��>�>r}c�"�VP4#r�)rr�s&r{r��Signature.__str__�s���{�{�}�r}�	max_widthr�c���.pRpRpVPP4F�pVPVR7pVPpV\8XdRpMV'dVPR4RpV\8XdRpM&V\8XdV'dVPR4RpVPV4K�	V'dVPR4RPRPV44p	Ve1\V	4V8�d!RPR	PV44p	VP\Jd0\VPVR7p
V	R
PV
4,
p	V	#)a�Create a string representation of the Signature object.

If *max_width* integer is passed,
signature will try to fit into the *max_width*.
If signature is longer than *max_width*,
all parameters will be on separate lines.

If *quote_annotation_strings* is False, annotations
in the signature are displayed without opening and closing quotation
marks. This is useful when the signature was created with the
STRING format or when ``from __future__ import annotations`` was used.
FTr��/rz({})r z
(
    {}
)z,
    z -> {})r�r�r�rr�r�r�r�rrBrr�r�r-)r3rr�r�render_pos_only_separator�render_kw_only_separatorr�r�r�rendered�annos&$$        r{r�Signature.format�s9����$)�!�#'� ��_�_�+�+�-�E��
�
�?W�
�X�I��:�:�D��'�'�,0�)�*��
�
�c�"�,1�)���&�,1�(���&�+C��
�
�c�"�,1�(��M�M�)�$�5.�8%�
�M�M�#���=�=����6�!2�3��� �S��]�Y�%>�%�,�,�Y�^�^�F�-C�D�H��!�!��/�#�D�$:�$:�=U�W�D������-�-�H��r})r�r�)r�r�r�)$r.r'r(r�r-r,r%r=r
rr�r�r�rrm�VALUErqr�r�r�r�r�r�r�r�r�rr
r�r�r�rqr�rr�r�r�s@r{r&r&ts�����,6�I��N�)���E�:4�V�:4�)-�:4�x�M�%)�M�37�M�@D�M�OT�M�(.���M��M�� �� ��'��'�
?�E�
?�U�
?��K�:�=�
9�L:�U�L:�\(�6�A�
>�?��:�$�:��:�:r}r�c	�4�\PWW#VVR7#)z/Get a signature object for the passed callable.)r�rYrr�rW)r&rq)r�r�rYrr�rWs&$$$$$r{rhrh�s(���"�"�3�+2�H�5F�#�H�Hr}c��]tRtRt^t^t^t^t^],t^ ],t	^@],t
^�],tR],t]],t
]t]],t]t]],],t]],t]],],t]],tRtRtRtR#)ri��ir�N)r.r'r(r��SIMPLE�WRITABLE�FORMAT�ND�STRIDES�C_CONTIGUOUS�F_CONTIGUOUS�ANY_CONTIGUOUS�INDIRECT�CONTIG�	CONTIG_RO�STRIDED�
STRIDED_RO�RECORDS�
RECORDS_RO�FULL�FULL_RO�READ�WRITEr�r�r}r{rr�s���
�F��H�
�F�	�B��R�i�G��'�>�L��'�>�L��G�^�N��w��H�
�(�]�F��I��� �G��J��� �6�)�G��6�!�J��h���'�D����G��D��Er}c�`�^RIp^RIpVPRR7pVPRRR7VPRRR	R
R7VP	4pVP
pVP
R4wrVpVP!V4;r�V'd(VP!R4pX	pVFp
\#W�4pK	X	P\P$9d2\R\PR7\P!^4VP&'Ed\RPV44\RP\)V	444\RPV	P*44XV	Jde\RP\-V	P.444\1V	R4'd%\RPV	P244M(\5V4wr�\RPV44\R4R#\\7X44R# \dcp
R
PT\T
4PT
4p\T\PR7\P!^4Rp
?
ELRp
?
ii;i \dL�i;i)z5Logic for inspecting an object given at command line NT)�colorrzzCThe object to be analysed. It supports the 'module:qualname' syntax)�helpz-dz	--details�
store_truez9Display info about the module rather than its source code)�actionr:�:zFailed to import {} ({}: {}))r~r#z#Can't get info for builtin modules.z
Target: {}z
Origin: {}z
Cached: {}z
Loader: {}r�zSubmodule search path: {}zLine: {}r:)�argparserU�ArgumentParser�add_argument�
parse_argsrz�	partition�
import_moduler�rrr.�printr�stderr�exitr)r��builtin_module_names�detailsrM�
__cached__r	rgr�r�r,rL)r>rU�parserr��target�mod_name�	has_attrs�attrsr�rPr�r��parts�part�__rjs                r{�_mainrR
s+����
�
$�
$�4�
$�
0�F�
����9��:�����k�,�
H��J�����D�
�[�[�F�!'�!1�!1�#�!6��H��� �.�.�x�8�8������C� �����D��#�$�C�����#�2�2�2�
�3�#�*�*�E�������|�|�|�
�l�!�!�&�)�*�
�l�!�!�-��"7�8�9�
�l�!�!�&�"3�"3�4�5��&�=��,�%�%�d�6�+<�+<�&=�>�?��v�z�*�*��1�8�8����I�J��
1�'��_�
���j�'�'��/�0�
�d��
�i��n���G��,�3�3�H�48��I�4F�4F�47�9��	�c��
�
�#����������8�
��
�s+�4H/�%
J�/J�:AJ�J�J-�,J-rJ)zKa-Ping Yee <ping@lfw.org>z'Yury Selivanov <yselivanov@sprymix.com>ir�)F)r<r�)r�r�)TNNF)�r-�
__author__�__all__r��
annotationlibrmrnr0rrT�collections.abcr��enum�importlib.machineryrUrrorRrrr�r�rwr�rx�keywordro�operatorrprqrr�weakrefrsr�rY�mod_dict�COMPILER_FLAG_NAMESr�r�r�r'rcrUr`rdrarYr�r_r^r[r�r]rzr�r�rgrXrRrQr\rWrSrfrZrVrTrbrerPr�rFrGrr)rJrkrOr*r5r>r*r?rIrMr1ryr|rHr�rr,r;rr	r7rNrLrlr9rr2r rArr3r-r.r8r/r.r:r8rr:rcr(r{rxr@rE�_fieldsr�rrKrDr+rirjr�rr�r�r�r�r�r��	lru_cacher�r�r6r"r#r$r!rCrBr
rrrr=r<rrrrr5r4�WrapperDescriptorTyper�rr�r�r�r�r�r�r�r
rSrVr!rgr�r�r�r��IntEnumrrDr�rEr�rGr�rHr�rJr�r%r
r&rh�IntFlagrrRr.r�r}r{�<module>rcs�
���<9�
�l��l��l��l��	l�
�l��
l��l��l��l��l��l��l��l��l��l� �!l�"�#l�$�%l�&�'l�(�)l�*�+l�,�-l�.�/l�0�1l�2�3l�4�5l�6�7l�8�9l�:�;l�<�=l�>�?l�@�Al�B�Cl�D�El�F�Gl�H�Il�J�Kl�L�Ml�N�Ol�P�Ql�R�Sl�T�Ul�V�Wl�X�Yl�Z!�[l�\�]l�^�_l�`�al�b�cl�d�el�f�gl�h�il�j�kl�l�ml�n�ol�p�ql�r�sl�t�ul�v�wl�x�yl�z
�{l�|�}l�~�l�@�Al�B�Cl�D�El�F�Gl�H�Il�J�Kl�L�Ml�N�Ol�P�Ql�R
�Sl�T�Ul�V�Wl�X�Yl�Z�[l�\�]l�^�_l�`�al�b�cl�d�el�f�gl�h�il�j
�kl�l�ml�n�ol�p�ql�r�sl�t�ul�v�wl�x�yl�z�{l�|�}l�~�l�@�Al�B�Cl�D�El�F�Gl�H�Il�J�Kl�L�Ml�N�Ol�P�Ql�R�Sl�T
�Ul�V�Wl��^�,�)�
�
������	�	�
��������/�'��9���#�#�)�)�+�D�A�q��H�U�Q�Y��
,��q�(���0�$�0�<�/�.?��5�(�)�)�>���5�(�)�)�>��2�$,�-��X��J��I�3�8�3�$3�;�3�/�$.�>9�7�H��0(�T3�
:�
�{�$E�F�	�p�h����@0�
�;�z�&�8,�8
��88��
���-�`	�)�	�90�v+%�Z"��!�4�4�l$�&0�*��+�6
�{�$:�;�	�8�6��M�O��Z<�z�Y� >�
?��9��t��$�"�"9� 8� ?�	(�.7� D�*:�x��(L�M��54�r��&S�
T�
�
-�
�
-�7�O�)A�V�
��j�9�3D�3D�&D�
E�
�
@�
�
@���C�5�'�
�H�	����y�)�1�1�� �M�M�*�5�=�=��4���������$
�'0�/�h�����
�
�
��$�&����!�����$
�����!�����$�."�7�7�!�3�3�!�;�;�!�5�5�7���RV��4X?�v*�4*�B�./+�dP8�f
<� ^9�28�,�,�^9�B+�HP�37�HP�,0�HP�&*�HP�%)�	HP�
',�HP�06�|�|�HP�V<�<�A�A��T�\�\��"*�9�9��)�?�?��)�8�8��)�6�6�
�)�5�5��a7�a7�HL�L�Dv�v�rH�T�H�4�H��H�u�H� &���H��$�,�,��,7�t�z��	�G�r}