Hooks, aspect-oriented programming, and design by contract
aleax at aleax.it
Tue Jan 22 16:59:12 CET 2002
"Pedro Rodriguez" <pedro_rodriguez at club-internet.fr> wrote in message
news:pan.2002.01.22.16.08.43.505728.1637 at club-internet.fr...
> As Alex pointed, 'metaclasses' are maybe the next step. BTW, there are the
> examples in Demo/metaclasses that may help, you'll even find an Eiffel
> class implementation for pre/post conditions.
I also point out that I don't know how to switch metaclasses dynamically,
temporarily and "retroactively" (i.e. so that already-existing instances
are also affected), as requested by the original poster. I don't even
know if such a metaclass-switch scheme is possible at all.
Note also that the sources in 2.2's Demo\metaclasses are pretty old; I
think that 2.2's innovations make things quite a bit better now (although
the old stuff should keep working).
Still, metaclasses (particularly in 2.2) are no doubt the way to go,
when it's not dynamic/temporary/noninvasive behavior that you are
after, but, rather, some kind of permanent behavior modification.
More information about the Python-list