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/mercurial/thirdparty/zope/interface/__pycache__/advice.cpython-310.pyc
o

�]Lbf�@s�dZddlmZddlmZzddlmZWney!dZYnwdZddlZdd	�Z	ddd�Z
d
d�Zddd�Zdd�Z
dS)ajClass advice.

This module was adapted from 'protocols.advice', part of the Python
Enterprise Application Kit (PEAK).  Please notify the PEAK authors
(pje@telecommunity.com and tsarna@sarna.org) if bugs are found or
Zope-specific changes are required, so that the PEAK version of this module
can be kept in sync.

PEAK is a Python application framework that interoperates with (but does
not require) Zope 3 and Twisted.  It provides tools for manipulating UML
models, object-relational persistence, aspect-oriented programming, and more.
Visit the PEAK home page at http://peak.telecommunity.com for more information.
�)�absolute_import)�FunctionType��	ClassTypeTFNc
Cs�|j}|j}||u}d|v}d|v}|o|}|o|d|dk}|r*tj�|d�p+d}|o2|j|u}|s8d}	n|r?|s?d}	n|rF|sFd}	n|sKd}	nd}	|	|||fS)	z�Return (kind,module,locals,globals) for a frame

    'kind' is one of "exec", "module", "class", "function call", or "unknown".
    �
__module__�__name__N�exec�module�classz
function call�unknown)�f_locals�	f_globals�sys�modules�get�__dict__)
�framerr
�
sameNamespace�	hasModule�hasName�sameNamer	�namespaceIsModule�kind�r�L/usr/lib/python3/dist-packages/mercurial/thirdparty/zope/interface/advice.py�getFrameInfo(s&r�csvtrtd��t�|�}t|�\}}}}|�d��tr!|�dt��n|�dt�����fdd�}�|_�|_	||d<dS)a2Set up 'callback' to be passed the containing class upon creation

    This function is designed to be called by an "advising" function executed
    in a class suite.  The "advising" function supplies a callback that it
    wishes to have executed when the containing class is created.  The
    callback will be given one argument: the newly created containing class.
    The return value of the callback will be used in place of the class, so
    the callback should return the input if it does not wish to replace the
    class.

    The optional 'depth' argument to this function determines the number of
    frames between this function and the targeted class suite.  'depth'
    defaults to 2, since this skips this function's frame and one calling
    function frame.  If you use this function from a function called directly
    in the class suite, the default will be correct, otherwise you will need
    to determine the correct depth yourself.

    This function works by installing a special class factory function in
    place of the '__metaclass__' of the containing class.  Therefore, only
    callbacks *after* the last '__metaclass__' assignment in the containing
    class will be executed.  Be sure that classes using "advising" functions
    declare any '__metaclass__' *first*, to ensure all callbacks are run.z"Class advice impossible in Python3�
__metaclass__csVd|vr|d=�dur|rt|�}n�}nt��r�}nt|��}||||�}�|�S)Nr)�determineMetaclass�isClassAdvisor)�name�bases�cdict�meta�newClass��callback�defaultMetaclass�previousMetaclassrr�advisezs

zaddClassAdvisor.<locals>.adviseN)
�	__python3�	TypeErrorr�	_getframerr�typerr(r&)r&�depthrrr	�
caller_locals�caller_globalsr)rr%r�addClassAdvisorLs


r1cCst|t�o	t|d�S)z(True if 'ob' is a class advisor functionr()�
isinstancer�hasattr)�obrrrr�srcCsjdd�|D�}|dur|�|�t|�dkr|dSt|�}|s&tr$J�tSt|�dkr1td|��|dS)zEDetermine metaclass from 1+ bases and optional explicit __metaclass__cSsg|]
}t|dt|���qS)�	__class__)�getattrr-)�.0�brrr�
<listcomp>�sz&determineMetaclass.<locals>.<listcomp>N�rzIncompatible metatypes)�append�len�minimalBasesr*rr+)r!�explicit_mcr#�
candidatesrrrr�s

rcCs`ts	dd�|D�}g}|D] }|D]
}t||�r||urnq||vr(|�|�|�|�q
|S)z?Reduce a list of base classes to its ordered minimum equivalentcSsg|]}|tur|�qSrr)r7�crrrr9�sz minimalBases.<locals>.<listcomp>)r*�
issubclass�remover;)�classesr?�m�nrrrr=�s�

�r=)r)N)�__doc__�
__future__r�typesrr�ImportErrorr*rrr1rrr=rrrr�<module>s
�
$P