[Zope3-checkins] CVS: Zope3/src/zope/app/contentdirective - contentdirective.py:1.12
Jim Fulton
jim@zope.com
Fri, 18 Apr 2003 18:12:58 -0400
Update of /cvs-repository/Zope3/src/zope/app/contentdirective
In directory cvs.zope.org:/tmp/cvs-serv8556/src/zope/app/contentdirective
Modified Files:
contentdirective.py
Log Message:
In prepration for the upcoming interface changes, I added some
new functions for making interface assertions on instances.
Rather than:
class C:
__class_implements__ = I1, I2
use:
class C:
classProvides(I1, I2)
rather than:
__implements__ = I1, I2
use:
moduleProvides(I1, I2)
rather than:
someinstance.__implements__ = I1, I2
use:
directlyProvides(I1, I2)
Note that interface assertions on persistent objects should be aboided
since the internal representation will change.
Continue to make assertions about the interfaces that class instances
implement the same way:
class C:
__implements__ = I1, I2
I also modified the core software to use the new spellings.
=== Zope3/src/zope/app/contentdirective/contentdirective.py 1.11 => 1.12 ===
--- Zope3/src/zope/app/contentdirective/contentdirective.py:1.11 Wed Apr 9 16:51:31 2003
+++ Zope3/src/zope/app/contentdirective/contentdirective.py Fri Apr 18 18:12:26 2003
@@ -15,6 +15,7 @@
$Id$
"""
+from zope.interface import classProvides
from types import ModuleType
from zope.interface.implements import implements
from zope.configuration.interfaces import INonEmptyDirective
@@ -49,7 +50,7 @@
class ContentDirective:
- __class_implements__ = INonEmptyDirective
+ classProvides(INonEmptyDirective)
__implements__ = ISubdirectiveHandler
def __init__(self, _context, class_):