SILENT KILLERPanel

Current Path: > > usr > lib64 > python2.7 > > Demo > > > metaclasses


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //usr/lib64/python2.7//Demo///metaclasses

NameTypeSizeLast ModifiedActions
Eiffel.py File 3468 bytes April 19 2020 21:13:39.
Eiffel.pyc File 4632 bytes April 10 2024 04:58:46.
Eiffel.pyo File 4530 bytes April 10 2024 04:58:44.
Enum.py File 4419 bytes April 19 2020 21:13:39.
Enum.pyc File 6179 bytes April 10 2024 04:58:46.
Enum.pyo File 6179 bytes April 10 2024 04:58:46.
Meta.py File 2933 bytes April 19 2020 21:13:39.
Meta.pyc File 4579 bytes April 10 2024 04:58:46.
Meta.pyo File 4579 bytes April 10 2024 04:58:46.
Simple.py File 1192 bytes April 19 2020 21:13:39.
Simple.pyc File 2746 bytes April 10 2024 04:58:46.
Simple.pyo File 2746 bytes April 10 2024 04:58:46.
Synch.py File 7938 bytes April 19 2020 21:13:39.
Synch.pyc File 8462 bytes April 10 2024 04:58:46.
Synch.pyo File 8314 bytes April 10 2024 04:58:44.
Trace.py File 4133 bytes April 19 2020 21:13:39.
Trace.pyc File 6173 bytes April 10 2024 04:58:46.
Trace.pyo File 6173 bytes April 10 2024 04:58:46.
index.html File 20573 bytes April 19 2020 21:13:39.
meta-vladimir.txt File 11527 bytes April 19 2020 21:13:39.

Reading File: //usr/lib64/python2.7//Demo///metaclasses/Meta.py

"""Generic metaclass.

XXX This is very much a work in progress.

"""

import types

class MetaMethodWrapper:

    def __init__(self, func, inst):
        self.func = func
        self.inst = inst
        self.__name__ = self.func.__name__

    def __call__(self, *args, **kw):
        return apply(self.func, (self.inst,) + args, kw)

class MetaHelper:

    __methodwrapper__ = MetaMethodWrapper # For derived helpers to override

    def __helperinit__(self, formalclass):
        self.__formalclass__ = formalclass

    def __getattr__(self, name):
        # Invoked for any attr not in the instance's __dict__
        try:
            raw = self.__formalclass__.__getattr__(name)
        except AttributeError:
            try:
                ga = self.__formalclass__.__getattr__('__usergetattr__')
            except (KeyError, AttributeError):
                raise AttributeError, name
            return ga(self, name)
        if type(raw) != types.FunctionType:
            return raw
        return self.__methodwrapper__(raw, self)

class MetaClass:

    """A generic metaclass.

    This can be subclassed to implement various kinds of meta-behavior.

    """

    __helper__ = MetaHelper             # For derived metaclasses to override

    __inited = 0

    def __init__(self, name, bases, dict):
        try:
            ga = dict['__getattr__']
        except KeyError:
            pass
        else:
            dict['__usergetattr__'] = ga
            del dict['__getattr__']
        self.__name__ = name
        self.__bases__ = bases
        self.__realdict__ = dict
        self.__inited = 1

    def __getattr__(self, name):
        try:
            return self.__realdict__[name]
        except KeyError:
            for base in self.__bases__:
                try:
                    return base.__getattr__(name)
                except AttributeError:
                    pass
            raise AttributeError, name

    def __setattr__(self, name, value):
        if not self.__inited:
            self.__dict__[name] = value
        else:
            self.__realdict__[name] = value

    def __call__(self, *args, **kw):
        inst = self.__helper__()
        inst.__helperinit__(self)
        try:
            init = inst.__getattr__('__init__')
        except AttributeError:
            init = lambda: None
        apply(init, args, kw)
        return inst


Meta = MetaClass('Meta', (), {})


def _test():
    class C(Meta):
        def __init__(self, *args):
            print "__init__, args =", args
        def m1(self, x):
            print "m1(x=%r)" % (x,)
    print C
    x = C()
    print x
    x.m1(12)
    class D(C):
        def __getattr__(self, name):
            if name[:2] == '__': raise AttributeError, name
            return "getattr:%s" % name
    x = D()
    print x.foo
    print x._foo
##     print x.__foo
##     print x.__foo__


if __name__ == '__main__':
    _test()

SILENT KILLER Tool