proof-of-concept for a simple AOP implementation
git-svn-id: svn://svn.cy55.de/Zope3/src/cybertools/trunk@1967 fd906abe-77d9-0310-91a1-e0d9ade77398
This commit is contained in:
parent
171b3c76bc
commit
a3dac1b675
2 changed files with 14 additions and 1 deletions
11
util/aop.py
11
util/aop.py
|
@ -24,8 +24,17 @@ $Id$
|
||||||
|
|
||||||
|
|
||||||
def getNotifier(method):
|
def getNotifier(method):
|
||||||
if isinstance(method, Notifier):
|
if isinstance(method, (Notifier, BoundNotifier)):
|
||||||
return method
|
return method
|
||||||
|
if method.im_self is not None:
|
||||||
|
name = method.im_func.func_name
|
||||||
|
classMethod = getattr(method.im_class, name)
|
||||||
|
if not isinstance(classMethod, Notifier):
|
||||||
|
classMethod = Notifier(classMethod)
|
||||||
|
setattr(method.im_class, name, classMethod)
|
||||||
|
notifier = BoundNotifier(classMethod, method.im_self)
|
||||||
|
setattr(method.im_self, name, notifier)
|
||||||
|
return notifier
|
||||||
return Notifier(method)
|
return Notifier(method)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -84,3 +84,7 @@ Combining class and instance level wrapping
|
||||||
logging: after foo, result=48
|
logging: after foo, result=48
|
||||||
48
|
48
|
||||||
|
|
||||||
|
TODO: check case where instance is wrapped first, then class -
|
||||||
|
that means: always wrap class when wrapping an instance, and always
|
||||||
|
wrap instance with BoundNotifier.
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue