404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@18.119.158.142: ~ $
##############################################################################
#
# Copyright (c) 2003 Zope Foundation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.1 (ZPL).  A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE.
#
##############################################################################
"""Compute a resolution order for an object and its bases
"""
__docformat__ = 'restructuredtext'

def _mergeOrderings(orderings):
    """Merge multiple orderings so that within-ordering order is preserved

    Orderings are constrained in such a way that if an object appears
    in two or more orderings, then the suffix that begins with the
    object must be in both orderings.

    For example:

    >>> _mergeOrderings([
    ... ['x', 'y', 'z'],
    ... ['q', 'z'],
    ... [1, 3, 5],
    ... ['z']
    ... ])
    ['x', 'y', 'q', 1, 3, 5, 'z']

    """

    seen = {}
    result = []
    for ordering in reversed(orderings):
        for o in reversed(ordering):
            if o not in seen:
                seen[o] = 1
                result.insert(0, o)

    return result

def _flatten(ob):
    result = [ob]
    i = 0
    for ob in iter(result):
        i += 1
        # The recursive calls can be avoided by inserting the base classes
        # into the dynamically growing list directly after the currently
        # considered object;  the iterator makes sure this will keep working
        # in the future, since it cannot rely on the length of the list
        # by definition.
        result[i:i] = ob.__bases__
    return result


def ro(object):
    """Compute a "resolution order" for an object
    """
    return _mergeOrderings([_flatten(object)])

Filemanager

Name Type Size Permission Actions
__pycache__ Folder 0755
common Folder 0755
__init__.py File 3.33 KB 0644
_compat.py File 1.65 KB 0644
_flatten.py File 1.03 KB 0644
_zope_interface_coptimizations.cpython-36m-x86_64-linux-gnu.so File 32.54 KB 0755
adapter.py File 22.87 KB 0644
advice.py File 7.31 KB 0644
declarations.py File 30.85 KB 0644
document.py File 3.89 KB 0644
exceptions.py File 1.95 KB 0644
interface.py File 20.02 KB 0644
interfaces.py File 42.11 KB 0644
registry.py File 22.74 KB 0644
ro.py File 1.96 KB 0644
verify.py File 4.78 KB 0644