[Zodb-checkins] CVS: Zope3/src/zope/interface - declarations.py:1.17.10.3 interface.py:1.13.4.4 surrogate.py:1.1.2.3

Jim Fulton jim at zope.com
Sun Oct 12 16:40:43 EDT 2003


Update of /cvs-repository/Zope3/src/zope/interface
In directory cvs.zope.org:/tmp/cvs-serv8539/src/zope/interface

Modified Files:
      Tag: adaptergeddon-branch
	declarations.py interface.py surrogate.py 
Log Message:
Got tests to pass on branch.


=== Zope3/src/zope/interface/declarations.py 1.17.10.2 => 1.17.10.3 ===
--- Zope3/src/zope/interface/declarations.py:1.17.10.2	Sat Oct 11 10:19:03 2003
+++ Zope3/src/zope/interface/declarations.py	Sun Oct 12 16:40:12 2003
@@ -284,7 +284,30 @@
 
     # This also manages storage of implementation specifications
 
-    spec = cls.__dict__.get('__implements__')
+    try:
+        spec = cls.__dict__.get('__implements__')
+    except AttributeError:
+        
+        # we can't get the class dict. This is probably due to a
+        # security proxy.  If this is the case, then probably no
+        # descriptor was installed for the class.
+
+        # We don't want to depend directly on zope.secury in
+        # zope.interface, but we'll try to make reasonable
+        # accomidations in an indirect way.
+
+        # We'll check to see if there's an implements:
+
+        spec = getattr(cls, '__implements__', _empty)
+        if isinstance(spec, Implements):
+            # we defaulted to _empty or there was a spec. Good enough.
+            # Return it.
+            return spec
+
+        # Hm, there's an __implements__, but it's not a spec. Must be
+        # an old-style declaration. Just compute a spec for it
+        return Declaration(*_normalizeargs((spec, )))
+        
     if isinstance(spec, Implements):
         return spec
 
@@ -306,7 +329,8 @@
 
     try:
         cls.__implements__ = spec
-        cls.__providedBy__ = objectSpecificationDescriptor
+        if not hasattr(cls, '__providedBy__'):
+            cls.__providedBy__ = objectSpecificationDescriptor
     except TypeError:
         if not isinstance(cls, type):
             raise TypeError("ImplementedBy called for non-type", cls)


=== Zope3/src/zope/interface/interface.py 1.13.4.3 => 1.13.4.4 ===
--- Zope3/src/zope/interface/interface.py:1.13.4.3	Sat Oct 11 10:51:19 2003
+++ Zope3/src/zope/interface/interface.py	Sun Oct 12 16:40:12 2003
@@ -116,9 +116,6 @@
         self.dependents = weakref.WeakKeyDictionary()
         self.__bases__ = tuple(bases)
 
-    def addDependent(self, ob):
-        self.dependents[ob] = 1
-
     def __setBases(self, bases):
         # Register ourselves as a dependent of our old bases
         for b in self.__bases__:
@@ -141,8 +138,7 @@
         """We, or something we depend on, have changed
         """
         
-        implied = self._implied
-        implied.clear()
+        implied = self._implied = {}
 
         ancestors = ro(self)
         self.__iro__ = tuple([ancestor for ancestor in ancestors
@@ -193,9 +189,12 @@
           >>> list(i)
           []
         """
+        seen = {}
         for base in self.__bases__:
             for interface in base.interfaces():
-                yield interface
+                if interface not in seen:
+                    seen[interface] = 1
+                    yield interface
         
 
     def extends(self, interface, strict=True):
@@ -267,12 +266,6 @@
 
         self.__module__ = __module__
 
-        for b in bases:
-            if not isinstance(b, InterfaceClass):
-                raise TypeError, 'Expected base interfaces'
-
-        Specification.__init__(self, bases)
-
         if attrs is None:
             attrs = {}
 
@@ -287,6 +280,12 @@
             __doc__ = ''
 
         Element.__init__(self, name, __doc__)
+
+        for b in bases:
+            if not isinstance(b, InterfaceClass):
+                raise TypeError, 'Expected base interfaces'
+
+        Specification.__init__(self, bases)
 
         for k, v in attrs.items():
             if isinstance(v, Attribute):


=== Zope3/src/zope/interface/surrogate.py 1.1.2.2 => 1.1.2.3 ===
--- Zope3/src/zope/interface/surrogate.py:1.1.2.2	Sat Oct 11 10:51:19 2003
+++ Zope3/src/zope/interface/surrogate.py	Sun Oct 12 16:40:12 2003
@@ -64,8 +64,8 @@
     def __init__(self, interface, registry):
         self._adapters = {}
         self._implied = {}
-        self._interface = interface
-        interface.addDependent(self)
+        self._interface = weakref.ref(interface)
+        interface.dependents[self] = 1
 
         self._registry = registry
         self.dependents = weakref.WeakKeyDictionary()
@@ -84,7 +84,7 @@
         return False
 
     def isImplementedBy(self, ob):
-        return self._interface.isImplementedBy(ob)
+        return self._interface().isImplementedBy(ob)
 
     def _adaptTo(self, specification, factory, name=None, with=()):
         self._adapters[with, name, specification] = factory




More information about the Zodb-checkins mailing list