[Zope-Checkins] SVN: Products.Five/trunk/ Merge zope33-port branch

Philipp von Weitershausen philikon at philikon.de
Tue May 2 05:21:50 EDT 2006


Log message for revision 67820:
  Merge zope33-port branch
  

Changed:
  U   Products.Five/trunk/__init__.py
  U   Products.Five/trunk/browser/TrustedExpression.py
  U   Products.Five/trunk/browser/__init__.py
  U   Products.Five/trunk/browser/absoluteurl.py
  U   Products.Five/trunk/browser/adding.py
  U   Products.Five/trunk/browser/configure.zcml
  U   Products.Five/trunk/browser/metaconfigure.py
  U   Products.Five/trunk/browser/pagetemplatefile.py
  U   Products.Five/trunk/browser/resource.py
  U   Products.Five/trunk/browser/tests/pages.txt
  U   Products.Five/trunk/browser/tests/provider.txt
  A   Products.Five/trunk/browser/tests/skin.py
  U   Products.Five/trunk/browser/tests/skin.zcml
  U   Products.Five/trunk/browser/tests/test_absoluteurl.py
  U   Products.Five/trunk/browser/tests/test_menu.py
  A   Products.Five/trunk/component/
  U   Products.Five/trunk/configure.zcml
  U   Products.Five/trunk/event.zcml
  U   Products.Five/trunk/fiveconfigure.py
  U   Products.Five/trunk/fivedirectives.py
  U   Products.Five/trunk/form/__init__.py
  U   Products.Five/trunk/form/metaconfigure.py
  U   Products.Five/trunk/form/tests/test_forms.py
  U   Products.Five/trunk/formlib/formbase.py
  U   Products.Five/trunk/formlib/tests/formlib.txt
  U   Products.Five/trunk/i18n.py
  U   Products.Five/trunk/meta.zcml
  U   Products.Five/trunk/metaconfigure.py
  U   Products.Five/trunk/security.py
  U   Products.Five/trunk/site/browser.py
  U   Products.Five/trunk/site/configure.zcml
  U   Products.Five/trunk/site/interfaces.py
  U   Products.Five/trunk/site/localsite.py
  U   Products.Five/trunk/site/metaconfigure.py
  U   Products.Five/trunk/site/tests/dummy.py
  U   Products.Five/trunk/site/tests/sitemanager.txt
  U   Products.Five/trunk/site/tests/test_localsite.py
  U   Products.Five/trunk/site/tests/test_utility.py
  U   Products.Five/trunk/site/utility.py
  U   Products.Five/trunk/sizeconfigure.py
  U   Products.Five/trunk/skin/standardmacros.py
  U   Products.Five/trunk/tests/directives.zcml
  U   Products.Five/trunk/tests/event.txt
  U   Products.Five/trunk/tests/test_event.py
  U   Products.Five/trunk/tests/test_i18n.py
  U   Products.Five/trunk/tests/test_security.py
  U   Products.Five/trunk/tests/test_size.py
  U   Products.Five/trunk/traversable.py
  A   Products.Five/trunk/traversing.zcml
  U   Products.Five/trunk/utilities/browser/tests/test_marker.py
  U   Products.Five/trunk/utilities/marker.py
  U   Products.Five/trunk/viewable.py
  U   Products.Five/trunk/viewlet/README.txt
  U   Products.Five/trunk/viewlet/tests.py

-=-
Modified: Products.Five/trunk/__init__.py
===================================================================
--- Products.Five/trunk/__init__.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/__init__.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -18,12 +18,23 @@
 import Acquisition
 from Globals import INSTANCE_HOME
 
-import zcml
+from Products.Five import zcml
 
 # public API provided by Five
 # usage: from Products.Five import <something>
-from browser import BrowserView
-from skin.standardmacros import StandardMacros
+from Products.Five.browser import BrowserView
+from Products.Five.skin.standardmacros import StandardMacros
 
+# load the site's ZCML tree (usually site.zcml) upon product
+# initialization
 def initialize(context):
     zcml.load_site()
+
+# some convenience methods/decorators
+
+def fivemethod(func):
+    func.__five_method__ = True
+    return func
+
+def isFiveMethod(m):
+    return hasattr(m, '__five_method__')

Modified: Products.Five/trunk/browser/TrustedExpression.py
===================================================================
--- Products.Five/trunk/browser/TrustedExpression.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/TrustedExpression.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -15,10 +15,7 @@
 
 $Id$
 """
-from sys import modules
-
 from Products.PageTemplates.PythonExpr import PythonExpr
-
 from Products.PageTemplates.Expressions import \
      SubPathExpr, PathExpr, \
      StringExpr, \

Modified: Products.Five/trunk/browser/__init__.py
===================================================================
--- Products.Five/trunk/browser/__init__.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/__init__.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -16,9 +16,9 @@
 $Id$
 """
 import Acquisition
-import zope.app.publisher.browser
+import zope.publisher.browser
 
-class BrowserView(Acquisition.Explicit, zope.app.publisher.browser.BrowserView):
+class BrowserView(Acquisition.Explicit, zope.publisher.browser.BrowserView):
     """Five browser view
 
     Mixes in explicit acquisition so that security can be acquired for

Modified: Products.Five/trunk/browser/absoluteurl.py
===================================================================
--- Products.Five/trunk/browser/absoluteurl.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/absoluteurl.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -19,15 +19,15 @@
 from OFS.interfaces import ITraversable
 
 from zope.interface import implements
-from zope.app import zapi
-from zope.app.traversing.browser.interfaces import IAbsoluteURL
+from zope.component import getMultiAdapter
+from zope.traversing.browser.interfaces import IAbsoluteURL
 
 from Products.Five.browser import BrowserView
 
 class AbsoluteURL(BrowserView):
     """An adapter for Zope3-style absolute_url using Zope2 methods
 
-    (original: zope.app.traversing.browser.absoluteurl)
+    (original: zope.traversing.browser.absoluteurl)
     """
     implements(IAbsoluteURL)
 
@@ -52,7 +52,7 @@
             return (
                 {'name': name, 'url': context.absolute_url()},)
 
-        view = zapi.getMultiAdapter((container, request), IAbsoluteURL)
+        view = getMultiAdapter((container, request), IAbsoluteURL)
         base = tuple(view.breadcrumbs())
         base += (
             {'name': name, 'url': ("%s/%s" % (base[-1]['url'], name))},)
@@ -72,7 +72,7 @@
     This one is just used to stop breadcrumbs from crumbing up
     to the Zope root.
 
-    (original: zope.app.traversing.browser.absoluteurl)
+    (original: zope.traversing.browser.absoluteurl)
     """
 
     def breadcrumbs(self):

Modified: Products.Five/trunk/browser/adding.py
===================================================================
--- Products.Five/trunk/browser/adding.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/adding.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -19,30 +19,28 @@
 __docformat__ = 'restructuredtext'
 
 from warnings import warn
+
+import zope.component
 from zope.interface import implements
 from zope.publisher.interfaces import IPublishTraverse
 from zope.component.interfaces import IFactory
+from zope.event import notify
+from zope.exceptions import UserError
+from zope.lifecycleevent import ObjectCreatedEvent
 
-from zope.app.exception.interfaces import UserError
 from zope.app.container.interfaces import IAdding, INameChooser
 from zope.app.container.interfaces import IContainerNamesContainer
 from zope.app.container.constraints import checkFactory, checkObject
-
 from zope.app.publisher.browser.menu import getMenu
 
-from zope.app import zapi
-from zope.app.event.objectevent import ObjectCreatedEvent
-from zope.event import notify
-
+from Acquisition import Implicit
 from zExceptions import BadRequest
+from OFS.SimpleItem import SimpleItem
 
 from Products.Five import BrowserView
 
 from Products.Five.browser.pagetemplatefile import ZopeTwoPageTemplateFile
 
-from Acquisition import Implicit
-from OFS.SimpleItem import SimpleItem
-
 class BasicAdding(Implicit, BrowserView):
     implements(IAdding, IPublishTraverse)
 
@@ -86,8 +84,8 @@
         # XXX this is definitely not right for all or even most uses
         # of Five, but can be overridden by an AddView subclass, using
         # the class attribute of a zcml:addform directive
-        return str(zapi.getMultiAdapter((self.context, self.request),
-                                        name=u"absolute_url")) + '/manage_main'
+        return str(zope.component.getMultiAdapter(
+            (self.context, self.request), name=u"absolute_url")) + '/manage_main'
 
     # set in BrowserView.__init__
     request = None 
@@ -106,18 +104,18 @@
 
             if view_name.startswith('@@'):
                 view_name = view_name[2:]
-            return zapi.getMultiAdapter((self, request), name=view_name)
+            return zope.component.getMultiAdapter((self, request), name=view_name)
 
         if name.startswith('@@'):
             view_name = name[2:]
         else:
             view_name = name
 
-        view = zapi.queryView(self, view_name, request)
+        view = zope.component.queryMultiAdapter((self, request), name=view_name)
         if view is not None:
             return view
 
-        factory = zapi.queryUtility(IFactory, name)
+        factory = zope.component.queryUtility(IFactory, name)
         if factory is None:
             return super(BasicAdding, self).publishTraverse(request, name)
 
@@ -135,9 +133,10 @@
         else:
             view_name = type_name
 
-        if zapi.queryView(self, view_name, self.request) is not None:
+        if (zope.component.queryMultiAdapter((self, self.request), name=view_name)
+            is not None):
             url = "%s/%s=%s" % (
-                zapi.getMultiAdapter((self, self.request), name=u"absolute_url"),
+                zope.component.getMultiAdapter((self, self.request), name=u"absolute_url"),
                 type_name, id)
             self.request.response.redirect(url)
             return
@@ -145,7 +144,7 @@
         if not self.contentName:
             self.contentName = id
 
-        factory = zapi.getUtility(IFactory, type_name)
+        factory = zope.component.getUtility(IFactory, type_name)
         content = factory()
 
         notify(ObjectCreatedEvent(content))
@@ -180,7 +179,7 @@
                 if extra:
                     factory = extra.get('factory')
                     if factory:
-                        factory = zapi.getUtility(IFactory, factory)
+                        factory = zope.component.getUtility(IFactory, factory)
                         if not checkFactory(container, None, factory):
                             continue
                         elif item['extra']['factory'] != item['action']:

Modified: Products.Five/trunk/browser/configure.zcml
===================================================================
--- Products.Five/trunk/browser/configure.zcml	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/configure.zcml	2006-05-02 09:21:45 UTC (rev 67820)
@@ -5,28 +5,19 @@
                        name="index.html" />
 
   <interface
-      interface="zope.publisher.interfaces.browser.ILayer"
+      interface="zope.publisher.interfaces.browser.IBrowserSkinType"
       />
 
   <interface
-      interface="zope.publisher.interfaces.browser.ISkin"
-      />
-
-  <interface
       interface="zope.app.publisher.interfaces.browser.IMenuItemType"
       />
 
-  <browser:layer
-      name="default"
-      interface="zope.publisher.interfaces.browser.IDefaultBrowserLayer"
-      />
-
   <browser:page
       for="*"
       name="absolute_url"
       class=".absoluteurl.AbsoluteURL"
       permission="zope.Public"
-      allowed_interface="zope.app.traversing.browser.interfaces.IAbsoluteURL"
+      allowed_interface="zope.traversing.browser.interfaces.IAbsoluteURL"
       />
 
   <view
@@ -34,23 +25,23 @@
       factory=".absoluteurl.AbsoluteURL"
       type="zope.publisher.interfaces.http.IHTTPRequest"
       permission="zope.Public"
-      provides="zope.app.traversing.browser.interfaces.IAbsoluteURL"
+      provides="zope.traversing.browser.interfaces.IAbsoluteURL"
       />
 
   <browser:page
-      for="zope.app.traversing.interfaces.IContainmentRoot"
+      for="zope.traversing.interfaces.IContainmentRoot"
       name="absolute_url"
       class=".absoluteurl.SiteAbsoluteURL"
       permission="zope.Public"
-      allowed_interface="zope.app.traversing.browser.interfaces.IAbsoluteURL"
+      allowed_interface="zope.traversing.browser.interfaces.IAbsoluteURL"
       />
 
   <view
-      for="zope.app.traversing.interfaces.IContainmentRoot"
+      for="zope.traversing.interfaces.IContainmentRoot"
       factory=".absoluteurl.SiteAbsoluteURL"
       type="zope.publisher.interfaces.http.IHTTPRequest"
       permission="zope.Public"
-      provides="zope.app.traversing.browser.interfaces.IAbsoluteURL"
+      provides="zope.traversing.browser.interfaces.IAbsoluteURL"
       />
 
   <browser:view

Modified: Products.Five/trunk/browser/metaconfigure.py
===================================================================
--- Products.Five/trunk/browser/metaconfigure.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/metaconfigure.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -22,6 +22,8 @@
 
 from zope import component
 from zope.interface import Interface
+from zope.component.zcml import handler
+from zope.component.interface import provideInterface
 from zope.configuration.exceptions import ConfigurationError
 from zope.publisher.interfaces.browser import IBrowserRequest, \
      IDefaultBrowserLayer
@@ -30,11 +32,10 @@
 from zope.app.publisher.browser.viewmeta import view as zope_app_view
 from zope.app.publisher.browser.viewmeta import providesCallable, \
      _handle_menu, _handle_for
-from zope.app.component.metaconfigure import handler
-from zope.app.component.interface import provideInterface
 
 from Products.Five.browser import BrowserView
-from Products.Five.browser.resource import FileResourceFactory, ImageResourceFactory
+from Products.Five.browser.resource import FileResourceFactory
+from Products.Five.browser.resource import ImageResourceFactory
 from Products.Five.browser.resource import PageTemplateResourceFactory
 from Products.Five.browser.resource import DirectoryResourceFactory
 from Products.Five.browser.pagetemplatefile import ZopeTwoPageTemplateFile
@@ -125,8 +126,8 @@
     _context.action(
         discriminator = ('view', for_, name, IBrowserRequest, layer),
         callable = handler,
-        args = ('provideAdapter',
-                (for_, layer), Interface, name, new_class, _context.info),
+        args = ('registerAdapter',
+                new_class, (for_, layer), Interface, name, _context.info),
         )
     _context.action(
         discriminator = ('five:protectClass', new_class),
@@ -193,8 +194,8 @@
 
                 if name in pages:
                     return getattr(self, pages[name])
-                view = component.queryMultiAdapter((self, request), name = name,
-                                                   default = None)
+                view = component.queryMultiAdapter((self, request), name=name,
+                                                   default=None)
                 if view is not None:
                     return view.__of__(self)
 
@@ -207,8 +208,8 @@
 
                 if name in pages:
                     return getattr(self, pages[name])
-                view = component.queryMultiAdapter((self, request), name = name,
-                                                   default = None)
+                view = component.queryMultiAdapter((self, request), name=name,
+                                                   default=None)
                 if view is not None:
                     return view.__of__(self)
 
@@ -253,8 +254,8 @@
             discriminator = ('view', for_, name, IBrowserRequest, layer,
                              self.provides),
             callable = handler,
-            args = ('provideAdapter',
-                    (for_, layer), self.provides, name, newclass,
+            args = ('registerAdapter',
+                    newclass, (for_, layer), self.provides, name,
                     _context.info),
             )
 
@@ -293,8 +294,8 @@
     _context.action(
         discriminator = ('resource', name, IBrowserRequest, layer),
         callable = handler,
-        args = ('provideAdapter',
-                (layer,), Interface, name, factory, _context.info),
+        args = ('registerAdapter',
+                factory, (layer,), Interface, name, _context.info),
         )
     _context.action(
         discriminator = ('five:protectClass', new_class),
@@ -360,8 +361,8 @@
     _context.action(
         discriminator = ('resource', name, IBrowserRequest, layer),
         callable = handler,
-        args = ('provideAdapter',
-                (layer,), Interface, name, factory, _context.info),
+        args = ('registerAdapter',
+                factory, (layer,), Interface, name, _context.info),
         )
     for new_class in new_classes:
         _context.action(

Modified: Products.Five/trunk/browser/pagetemplatefile.py
===================================================================
--- Products.Five/trunk/browser/pagetemplatefile.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/pagetemplatefile.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -70,7 +70,7 @@
     pt_render = rebindFunction(PageTemplateFile.pt_render,
                                getEngine=getEngine)
 
-    def _pt_getContext(self):
+    def pt_getContext(self):
         try:
             root = self.getPhysicalRoot()
         except AttributeError:
@@ -99,6 +99,3 @@
             c['views'] = ViewMapper(here, request)
 
         return c
-
-    pt_getContext = rebindFunction(_pt_getContext,
-                                   SecureModuleImporter=ModuleImporter)

Modified: Products.Five/trunk/browser/resource.py
===================================================================
--- Products.Five/trunk/browser/resource.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/resource.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -23,12 +23,12 @@
 from OFS.Traversable import Traversable as OFSTraversable
 
 from zope.interface import implements
+from zope.component import getMultiAdapter
 from zope.component.interfaces import IResource
 from zope.publisher.interfaces.browser import IBrowserPublisher
+from zope.traversing.browser.interfaces import IAbsoluteURL
+from zope.datetime import time as timeFromDateTimeString
 
-from zope.app import zapi
-from zope.app.traversing.browser.interfaces import IAbsoluteURL
-from zope.app.datetimeutils import time as timeFromDateTimeString
 from zope.app.publisher.fileresource import File, Image
 from zope.app.publisher.pagetemplateresource import PageTemplate
 from zope.app.publisher.browser.resources import empty
@@ -51,7 +51,7 @@
 
         # TODO Zope 3 uses site = getSite() instead of container here
         # and the @@ resource access view
-        url = str(zapi.getMultiAdapter((container, self.request), IAbsoluteURL))
+        url = str(getMultiAdapter((container, self.request), IAbsoluteURL))
         url = urllib.unquote(url)
         if not isinstance(container, DirectoryResource):
             name = '++resource++%s' % name

Modified: Products.Five/trunk/browser/tests/pages.txt
===================================================================
--- Products.Five/trunk/browser/tests/pages.txt	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/tests/pages.txt	2006-05-02 09:21:45 UTC (rev 67820)
@@ -194,12 +194,12 @@
 This tests security on a low level (functional pages test has
 high-level security tests).  Let's manually look up a protected view:
 
+  >>> from zope.component import getMultiAdapter
+  >>> from zope.publisher.browser import setDefaultSkin
   >>> from Products.Five.traversable import FakeRequest
-  >>> from zope.app import zapi
-  >>> from zope.app.publication.browser import setDefaultSkin
   >>> request = FakeRequest()
   >>> setDefaultSkin(request)
-  >>> view = zapi.getMultiAdapter((self.folder.testoid, request), name=u'eagle.txt')
+  >>> view = getMultiAdapter((self.folder.testoid, request), name=u'eagle.txt')
 
 It's protecting the object with the permission, and not the attribute,
 so we get ('',) instead of ('eagle',):

Modified: Products.Five/trunk/browser/tests/provider.txt
===================================================================
--- Products.Five/trunk/browser/tests/provider.txt	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/tests/provider.txt	2006-05-02 09:21:45 UTC (rev 67820)
@@ -103,7 +103,7 @@
   ... ''')
   HTTP/1.1 500 Internal Server Error
   ...
-  ...ContentProviderLookupError: 'mypage.UnknownName'
+  ...ContentProviderLookupError: mypage.UnknownName
   ...
 
 Additional Data from TAL

Copied: Products.Five/trunk/browser/tests/skin.py (from rev 67817, Products.Five/branches/zope33-port/browser/tests/skin.py)

Modified: Products.Five/trunk/browser/tests/skin.zcml
===================================================================
--- Products.Five/trunk/browser/tests/skin.zcml	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/tests/skin.zcml	2006-05-02 09:21:45 UTC (rev 67820)
@@ -5,11 +5,10 @@
   <!-- make the zope2.Public permission work -->
   <meta:redefinePermission from="zope2.Public" to="zope.Public" />
 
-  <browser:layer name="test" />
-
-  <browser:skin
+  <interface
+      interface=".skin.ITestSkin"
+      type="zope.publisher.interfaces.browser.IBrowserSkinType"
       name="TestSkin"
-      layers="test default"
       />
 
   <browser:page
@@ -18,7 +17,7 @@
       attribute="eagle"
       name="eagle.html"
       permission="zope2.Public"
-      layer="test"
+      layer=".skin.ITestSkin"
       />
 
 </configure>

Modified: Products.Five/trunk/browser/tests/test_absoluteurl.py
===================================================================
--- Products.Five/trunk/browser/tests/test_absoluteurl.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/tests/test_absoluteurl.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -55,7 +55,7 @@
     interface:
 
       >>> from zope.interface import directlyProvides, providedBy
-      >>> from zope.app.traversing.interfaces import IContainmentRoot
+      >>> from zope.traversing.interfaces import IContainmentRoot
       >>> directlyProvides(self.folder, IContainmentRoot)
 
       >>> for crumb in view.breadcrumbs():

Modified: Products.Five/trunk/browser/tests/test_menu.py
===================================================================
--- Products.Five/trunk/browser/tests/test_menu.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/browser/tests/test_menu.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -38,7 +38,7 @@
     Now for some actual testing... Let's look up the menu we registered:
 
       >>> from Products.Five.traversable import FakeRequest
-      >>> from zope.app.publication.browser import setDefaultSkin
+      >>> from zope.publisher.browser import setDefaultSkin
       >>> from zope.app.publisher.browser.menu import getMenu
 
       >>> request = FakeRequest()

Copied: Products.Five/trunk/component (from rev 67817, Products.Five/branches/zope33-port/component)

Modified: Products.Five/trunk/configure.zcml
===================================================================
--- Products.Five/trunk/configure.zcml	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/configure.zcml	2006-05-02 09:21:45 UTC (rev 67820)
@@ -6,6 +6,8 @@
   <include file="i18n.zcml" />
   <include file="event.zcml"/>
   <include file="deprecated.zcml"/>
+  <include file="traversing.zcml"/>
+  <include package=".component" />
   <include package=".site" />
   <include package=".browser" />
   <include package=".form" />
@@ -13,22 +15,6 @@
   <include package=".skin" />
   <include package=".utilities" />
 
-  <include package="zope.app.event" />
-  <include package="zope.app.traversing" />
-
-  <!-- do 'traditional' traversing by default; needed by ZPT -->
-  <adapter
-      for="*"
-      factory=".traversable.FiveTraversable"
-      provides="zope.app.traversing.interfaces.ITraversable"
-      />
-
-  <adapter
-      for="*"
-      factory="zope.app.traversing.adapters.Traverser"
-      provides="zope.app.traversing.interfaces.ITraverser"
-      />
-
   <!-- this is really lying, but it's to please checkContainer -->
   <five:implements class="OFS.ObjectManager.ObjectManager"
                    interface="zope.app.container.interfaces.IContainer" />

Modified: Products.Five/trunk/event.zcml
===================================================================
--- Products.Five/trunk/event.zcml	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/event.zcml	2006-05-02 09:21:45 UTC (rev 67820)
@@ -1,36 +1,19 @@
 <configure xmlns="http://namespaces.zope.org/zope">
 
+  <!-- Enable object event dispatcher -->
+  <include package="zope.app.event" />
+
   <!-- Adapter giving sublocations for ObjectManagers, used
        by dispatchToSublocations -->
+  <adapter factory="OFS.subscribers.ObjectManagerSublocations" />
 
-  <adapter
-      for="OFS.interfaces.IObjectManager"
-      provides="zope.app.location.interfaces.ISublocations"
-      factory="OFS.subscribers.ObjectManagerSublocations"
-      />
-
   <!-- dispatch IObjectWillBeMovedEvent with "bottom-up" semantics -->
+  <subscriber handler="OFS.subscribers.dispatchObjectWillBeMovedEvent" />
 
-  <subscriber
-      for="OFS.interfaces.IItem
-           OFS.interfaces.IObjectWillBeMovedEvent"
-      handler="OFS.subscribers.dispatchObjectWillBeMovedEvent"
-      />
-
   <!-- dispatch IObjectMovedEvent with "top-down" semantics -->
+  <subscriber handler="OFS.subscribers.dispatchObjectMovedEvent" />
 
-  <subscriber
-      for="OFS.interfaces.IItem
-           zope.app.container.interfaces.IObjectMovedEvent"
-      handler="OFS.subscribers.dispatchObjectMovedEvent"
-      />
-
   <!-- dispatch IObjectClonedEvent with "top-down" semantics -->
+  <subscriber handler="OFS.subscribers.dispatchObjectClonedEvent" />
 
-  <subscriber
-      for="OFS.interfaces.IItem
-           OFS.interfaces.IObjectClonedEvent"
-      handler="OFS.subscribers.dispatchObjectClonedEvent"
-      />
-
 </configure>

Modified: Products.Five/trunk/fiveconfigure.py
===================================================================
--- Products.Five/trunk/fiveconfigure.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/fiveconfigure.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -28,15 +28,15 @@
 
 from zope.interface import classImplements, classImplementsOnly, implementedBy
 from zope.interface.interface import InterfaceClass
+from zope.component import getUtility
+from zope.component.interface import provideInterface
+from zope.component.zcml import adapter
 from zope.configuration import xmlconfig
 from zope.configuration.exceptions import ConfigurationError
 from zope.publisher.interfaces.browser import IDefaultBrowserLayer
+from zope.security.interfaces import IPermission
 
-from zope.app import zapi
-from zope.app.component.interface import provideInterface
-from zope.app.component.metaconfigure import adapter
-from zope.app.security.interfaces import IPermission
-
+from Products.Five import isFiveMethod
 from Products.Five.bridge import fromZ2Interface
 from Products.Five.browser.metaconfigure import page
 from Products.Five.interfaces import IBrowserDefault
@@ -107,9 +107,6 @@
                     interface)
             )
 
-def isFiveMethod(m):
-    return hasattr(m, '__five_method__')
-
 # BBB 2006/05/01 -- to be removed after 12 months
 def traversable(_context, class_):
     warnings.warn("The five:traversable statement is no longer needed "
@@ -173,7 +170,7 @@
 def _registerClass(class_, meta_type, permission, addview, icon, global_):
     setattr(class_, 'meta_type', meta_type)
 
-    permission_obj = zapi.getUtility(IPermission, permission)
+    permission_obj = getUtility(IPermission, permission)
 
     if icon:
         setattr(class_, 'icon', '++resource++%s' % icon)

Modified: Products.Five/trunk/fivedirectives.py
===================================================================
--- Products.Five/trunk/fivedirectives.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/fivedirectives.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -17,12 +17,10 @@
 """
 from zope.interface import Interface
 from zope.app.publisher.browser.metadirectives import IBasicResourceInformation
-from zope.app.security.fields import Permission
+from zope.security.zcml import Permission
 from zope.configuration.fields import GlobalObject, Tokens, PythonIdentifier
 from zope.configuration.fields import Bool
-from zope.schema import ASCII
-from zope.schema import TextLine
-from zope.schema import BytesLine
+from zope.schema import ASCII, TextLine, BytesLine
 
 class IImplementsDirective(Interface):
     """State that a class implements something.

Modified: Products.Five/trunk/form/__init__.py
===================================================================
--- Products.Five/trunk/form/__init__.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/form/__init__.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -21,17 +21,18 @@
 import Acquisition
 import transaction
 from zope.event import notify
+from zope.lifecycleevent import ObjectCreatedEvent, ObjectModifiedEvent
+from zope.location.interfaces import ILocation
+from zope.location import LocationProxy
 from zope.schema.interfaces import ValidationError
+from zope.i18nmessageid import MessageFactory
+_ = MessageFactory('zope')
 
-from zope.app.location.interfaces import ILocation
-from zope.app.location import LocationProxy
 from zope.app.form.utility import setUpEditWidgets, applyWidgetsChanges
 from zope.app.form.browser.submit import Update
 from zope.app.form.interfaces import WidgetsError, MissingInputError
 from zope.app.form.utility import setUpWidgets, getWidgetsData
 from zope.app.form.interfaces import IInputWidget, WidgetsError
-from zope.app.event.objectevent import ObjectCreatedEvent, ObjectModifiedEvent
-from zope.app.i18n import ZopeMessageFactory as _
 
 from Products.Five.browser import BrowserView
 from Products.Five.browser.decode import processInputs, setPageEncoding

Modified: Products.Five/trunk/form/metaconfigure.py
===================================================================
--- Products.Five/trunk/form/metaconfigure.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/form/metaconfigure.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -18,14 +18,15 @@
 import ExtensionClass
 from Globals import InitializeClass as initializeClass
 
+import zope.component
 from zope.interface import Interface
 from zope.publisher.interfaces.browser import IBrowserRequest
+from zope.i18nmessageid import MessageFactory
+_ = MessageFactory('zope')
 
-from zope.app import zapi
 from zope.app.publisher.browser.menumeta import menuItemDirective
 from zope.app.form.browser.metaconfigure import BaseFormDirective
 from zope.app.container.interfaces import IAdding
-from zope.app.i18n import ZopeMessageFactory as _
 
 from Products.Five.form import EditView, AddView
 from Products.Five.metaclass import makeClass
@@ -53,8 +54,8 @@
     if layer is None:
         layer = IDefaultBrowserLayer
 
-    s = zapi.getGlobalSiteManager()
-    s.provideAdapter((for_, layer), Interface, name, class_)
+    s = zope.component.getGlobalSiteManager()
+    s.registerAdapter(class_, (for_, layer), Interface, name)
 
     # Reminder: the permission we got has already been processed by
     # BaseFormDirective, that means that zope.Public has been
@@ -116,8 +117,8 @@
     if layer is None:
         layer = IDefaultBrowserLayer
 
-    s = zapi.getGlobalSiteManager()
-    s.provideAdapter((for_, layer), Interface, name, class_)
+    s = zope.component.getGlobalSiteManager()
+    s.registerAdapter(class_, (for_, layer), Interface, name)
 
     # Reminder: the permission we got has already been processed by
     # BaseFormDirective, that means that zope.Public has been

Modified: Products.Five/trunk/form/tests/test_forms.py
===================================================================
--- Products.Five/trunk/form/tests/test_forms.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/form/tests/test_forms.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -41,16 +41,16 @@
       >>> salutation = salutation.bind(request)
       >>> contactname = contactname.bind(request)
 
-      >>> from zope.app import zapi
+      >>> from zope.component import getMultiAdapter
       >>> from zope.app.form.interfaces import IInputWidget
       >>> from zope.app.form.browser.textwidgets import TextWidget
       >>> from zope.app.form.browser.itemswidgets import DropdownWidget
 
-      >>> view1 = zapi.getMultiAdapter((contactname, request), IInputWidget)
+      >>> view1 = getMultiAdapter((contactname, request), IInputWidget)
       >>> view1.__class__ == TextWidget
       True
 
-      >>> view2 = zapi.getMultiAdapter((salutation, request), IInputWidget)
+      >>> view2 = getMultiAdapter((salutation, request), IInputWidget)
       >>> view2.__class__ == DropdownWidget
       True
 

Modified: Products.Five/trunk/formlib/formbase.py
===================================================================
--- Products.Five/trunk/formlib/formbase.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/formlib/formbase.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -19,10 +19,10 @@
 import Acquisition
 
 import zope.event
-import zope.app.event.objectevent
+import zope.lifecycleevent
 from zope import interface
 from zope.formlib import interfaces, form, namedtemplate
-from zope.app.i18n import ZopeMessageFactory as _
+from zope.formlib.i18n import _
 
 from Products.Five.browser.pagetemplatefile import ZopeTwoPageTemplateFile
 from Products.Five.browser.decode import processInputs, setPageEncoding
@@ -59,7 +59,7 @@
             self.context, self.form_fields, data, self.adapters):
             
             zope.event.notify(
-                zope.app.event.objectevent.ObjectModifiedEvent(self.context)
+                zope.lifecycleevent.ObjectModifiedEvent(self.context)
                 )
             # TODO: Needs locale support. See also Five.form.EditView.
             self.status = _(

Modified: Products.Five/trunk/formlib/tests/formlib.txt
===================================================================
--- Products.Five/trunk/formlib/tests/formlib.txt	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/formlib/tests/formlib.txt	2006-05-02 09:21:45 UTC (rev 67820)
@@ -21,7 +21,6 @@
   >>> zcml.load_config('meta.zcml', Products.Five)
   >>> import Products.Five.form.tests
   >>> zcml.load_config('configure.zcml', package=Products.Five)
-  >>> zcml.load_config('configure.zcml', package=Products.Five.formlib)
   >>> zcml.load_config('configure.zcml', package=Products.Five.formlib.tests)
 
 Finally, we need to setup a traversable folder. Otherwise, Five won't get

Modified: Products.Five/trunk/i18n.py
===================================================================
--- Products.Five/trunk/i18n.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/i18n.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -20,15 +20,10 @@
 from zope.i18n import interpolate
 from zope.i18n.interfaces import ITranslationDomain, IUserPreferredLanguages
 from zope.i18n.negotiator import normalize_lang
-from zope.app import zapi
+from zope.component import queryUtility
 from zope.publisher.browser import BrowserLanguages
+from zope.i18nmessageid import Message
 
-# BBB 2005/10/10 -- MessageIDs are to be removed for Zope 3.3
-import zope.deprecation
-zope.deprecation.__show__.off()
-from zope.i18nmessageid import MessageID, Message
-zope.deprecation.__show__.on()
-
 class FiveTranslationService:
     """Translation service that delegates to ``zope.i18n`` machinery.
     """
@@ -36,12 +31,12 @@
     # regarding fallback and Zope 2 compatability
     def translate(self, domain, msgid, mapping=None,
                   context=None, target_language=None, default=None):
-        if isinstance(msgid, (Message, MessageID)):
+        if isinstance(msgid, Message):
             domain = msgid.domain
             default = msgid.default
             mapping = msgid.mapping
 
-        util = zapi.queryUtility(ITranslationDomain, domain)
+        util = queryUtility(ITranslationDomain, domain)
 
         if util is None:
             # fallback to translation service that was registered,

Modified: Products.Five/trunk/meta.zcml
===================================================================
--- Products.Five/trunk/meta.zcml	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/meta.zcml	2006-05-02 09:21:45 UTC (rev 67820)
@@ -2,6 +2,13 @@
     xmlns="http://namespaces.zope.org/zope"
     xmlns:meta="http://namespaces.zope.org/meta">
 
+  <include package="zope.component" file="meta.zcml" />
+  <include package="zope.security" file="meta.zcml" />
+  <include package="zope.i18n" file="meta.zcml" />
+
+  <!-- BBB 2006/02/24, to be removed after 12 months -->
+  <include package="zope.modulealias" file="meta.zcml" />
+
   <include package=".site" file="meta.zcml" />
   <include package=".browser" file="meta.zcml" />
   <include package=".form" file="meta.zcml" />
@@ -9,42 +16,13 @@
   <meta:directives namespace="http://namespaces.zope.org/zope">
 
     <meta:directive
-        name="permission"
-        schema="zope.app.security.metadirectives.IDefinePermissionDirective"
-        handler="zope.app.security.metaconfigure.definePermission"
-        />
-
-    <meta:directive
-        name="interface"
-        schema="zope.app.component.metadirectives.IInterfaceDirective"
-        handler="zope.app.component.metaconfigure.interface"
-        />
-
-    <meta:directive
         name="view"
         schema="zope.app.component.metadirectives.IViewDirective"
         handler="zope.app.component.metaconfigure.view"
         />
 
+    <!-- BBB 2006/02/24, to be removed after 12 months -->
     <meta:directive
-        name="adapter"
-        schema="zope.app.component.metadirectives.IAdapterDirective"
-        handler="zope.app.component.metaconfigure.adapter"
-        />
-
-    <meta:directive
-        name="subscriber"
-        schema="zope.app.component.metadirectives.ISubscriberDirective"
-        handler="zope.app.component.metaconfigure.subscriber"
-        />
-
-    <meta:directive
-        name="utility"
-        schema="zope.app.component.metadirectives.IUtilityDirective"
-        handler="zope.app.component.metaconfigure.utility"
-        />
-
-    <meta:directive
         name="factory"
         schema="zope.app.component.metadirectives.IFactoryDirective"
         handler="zope.app.component.metaconfigure.factory"
@@ -53,7 +31,7 @@
     <meta:complexDirective
         name="class"
         schema="zope.app.component.metadirectives.IClassDirective"
-        handler=".metaconfigure.ContentDirective"
+        handler=".metaconfigure.ClassDirective"
         >
 
       <meta:subdirective
@@ -73,6 +51,7 @@
 
     </meta:complexDirective>
 
+    <!-- BBB 2006/02/24, to be removed after 12 months -->
     <meta:complexDirective
         name="content"
         schema="zope.app.component.metadirectives.IClassDirective"
@@ -96,6 +75,7 @@
 
     </meta:complexDirective>
 
+    <!-- BBB 2006/02/24, to be removed after 12 months -->
     <meta:directive
         name="vocabulary"
         schema="zope.app.schema.metadirectives.IVocabularyDirective"
@@ -182,17 +162,4 @@
 
   </meta:directives>
 
-  <meta:directive
-      name="redefinePermission"
-      namespace="http://namespaces.zope.org/meta"
-      schema="zope.app.security.metadirectives.IRedefinePermission"
-      handler="zope.app.security.metaconfigure.redefinePermission"
-      />
-
-  <!-- load the zope:modulealias directive -->
-  <include package="zope.modulealias" file="meta.zcml" />
-
-  <!-- load the i18n:registerTranslations directive -->
-  <include package="zope.app.i18n" file="meta.zcml" />
-
 </configure>

Modified: Products.Five/trunk/metaconfigure.py
===================================================================
--- Products.Five/trunk/metaconfigure.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/metaconfigure.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -15,13 +15,12 @@
 
 $Id$
 """
+import warnings
 from Products.Five.security import CheckerPublic, protectName
 from Globals import InitializeClass as initializeClass
+import zope.app.component.contentdirective
 
-from zope.app.component.contentdirective import ContentDirective as \
-     zope_app_ContentDirective
-
-class ContentDirective(zope_app_ContentDirective):
+class ClassDirective(zope.app.component.contentdirective.ClassDirective):
         
     def __protectName(self, name, permission_id):
         self.__context.action(
@@ -37,3 +36,13 @@
             callable = initializeClass,
             args = (self.__class,)
             )
+
+# BBB 2006/02/24, to be removed after 12 months
+class ContentDirective(ClassDirective):
+
+    def __init__(self, _context, class_):
+        warnings.warn_explicit(
+            "The 'content' alias for the 'class' directive has been "
+            "deprecated and will be removed in Zope 2.12.\n",
+            DeprecationWarning, _context.info.file, _context.info.line)        
+        super(ContentDirective, self).__init__(_context, class_)

Modified: Products.Five/trunk/security.py
===================================================================
--- Products.Five/trunk/security.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/security.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -19,9 +19,8 @@
 from zope.component import queryUtility, getUtility
 from zope.security.management import thread_local
 from zope.security.interfaces import IInteraction, ISecurityPolicy
+from zope.security.interfaces import IPermission
 from zope.security.simplepolicies import ParanoidSecurityPolicy
-from zope.app.security.interfaces import IPermission
-from zope.app import zapi
 
 from AccessControl import ClassSecurityInfo, getSecurityManager
 from Globals import InitializeClass as initializeClass
@@ -67,7 +66,7 @@
         return True
 
     if isinstance(permission, StringTypes):
-        permission = zapi.queryUtility(IPermission, unicode(permission))
+        permission = queryUtility(IPermission, unicode(permission))
         if permission is None:
             return False
 

Modified: Products.Five/trunk/site/browser.py
===================================================================
--- Products.Five/trunk/site/browser.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/site/browser.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -19,8 +19,7 @@
 from zope.app.component.hooks import clearSite
 
 from Products.Five.browser import BrowserView
-from Products.Five.site.localsite import enableLocalSiteHook, \
-     disableLocalSiteHook
+from Products.Five.component import enableSite, disableSite
 
 class LocalSiteView(BrowserView):
     """View for convering a possible site to a site
@@ -41,7 +40,7 @@
         if self.isSite():
             raise ValueError('This is already a site')
 
-        enableLocalSiteHook(self.context)
+        enableSite(self.context)
         return "This object is now a site"
 
     def unmakeSite(self):
@@ -49,7 +48,7 @@
         if not self.isSite():
             raise ValueError('This is not a site')
 
-        disableLocalSiteHook(self.context)
+        disableSite(self.context)
 
         # disableLocalSiteHook circumcised our context so that it's
         # not an ISite anymore.  That can mean that certain things for

Modified: Products.Five/trunk/site/configure.zcml
===================================================================
--- Products.Five/trunk/site/configure.zcml	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/site/configure.zcml	2006-05-02 09:21:45 UTC (rev 67820)
@@ -2,28 +2,11 @@
            xmlns:browser="http://namespaces.zope.org/browser">
 
   <adapter
-      for="*"
-      provides="zope.component.interfaces.ISiteManager"
-      factory=".localsite.siteManagerAdapter"
-      />
-
-  <adapter
-      for="zope.app.site.interfaces.ISite"
+      for="zope.app.component.interfaces.ISite"
       provides=".interfaces.IFiveUtilityRegistry"
       factory=".utility.SimpleLocalUtilityRegistry"
       />
 
-  <subscriber
-      for="zope.app.component.interfaces.ISite
-           zope.app.publication.interfaces.IBeforeTraverseEvent"
-      handler="zope.app.component.site.threadSiteSubscriber"
-      />
-
-  <subscriber
-      for="zope.app.publication.interfaces.IEndRequestEvent"
-      handler="zope.app.component.site.clearThreadSiteSubscriber"
-      />
-
   <browser:page
       for="zope.app.component.interfaces.IPossibleSite"
       name="manage_site.html"

Modified: Products.Five/trunk/site/interfaces.py
===================================================================
--- Products.Five/trunk/site/interfaces.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/site/interfaces.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -16,7 +16,7 @@
 $Id: interfaces.py 18584 2005-10-14 17:13:27Z regebro $
 """
 from zope.interface import Interface, Attribute
-from zope.component.interfaces import ISiteManager
+from zope.component.interfaces import IComponentLookup
 
 class IRegisterUtilitySimply(Interface):
     """Register utilities simply
@@ -76,7 +76,7 @@
         returned.
         """
 
-class IFiveSiteManager(ISiteManager, IRegisterUtilitySimply):
+class IFiveSiteManager(IComponentLookup, IRegisterUtilitySimply):
     """Five site manager
 
     For the sake of forward-portability, registering utilities can be
@@ -84,12 +84,3 @@
     utility service (this corresponds to Zope 3.1's understanding of
     site managers).  An implementation of this interface will probably
     delegate the work to an IFiveUtilityService component, though."""
-
-
-# BBB 2005/11/01 -- gone in Five 1.5.
-IFiveUtilityService = IFiveUtilityRegistry
-import zope.deprecation
-zope.deprecation.deprecated(
-    'IFiveUtilityService', "'IFiveUtilityService' has been renamed to "
-    "'IFiveUtilityRegistry' and will disappear in Five 1.5."
-    )

Modified: Products.Five/trunk/site/localsite.py
===================================================================
--- Products.Five/trunk/site/localsite.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/site/localsite.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -15,78 +15,13 @@
 
 $Id$
 """
-from zope.event import notify
-from zope.interface import directlyProvides, directlyProvidedBy
 from zope.interface import implements
 from zope.component import getGlobalSiteManager
-from zope.component.exceptions import ComponentLookupError
-
+from zope.component.interfaces import ComponentLookupError
 from zope.app.component.interfaces import ISite, IPossibleSite
-from zope.app.publication.zopepublication import BeforeTraverseEvent
-
-from ExtensionClass import Base
-from Acquisition import aq_base, aq_inner, aq_parent
-from Products.SiteAccess.AccessRule import AccessRule
-from ZPublisher.BeforeTraverse import registerBeforeTraverse
-from ZPublisher.BeforeTraverse import unregisterBeforeTraverse
-
+from Acquisition import aq_parent, aq_inner
 from Products.Five.site.interfaces import IFiveSiteManager, IFiveUtilityRegistry
 
-# Hook up custom component architecture calls
-import zope.app.component.hooks
-zope.app.component.hooks.setHooks()
-
-def siteManagerAdapter(ob):
-    """An adapter * -> ISiteManager.
-
-    This is registered in place of the one in Zope 3 so that we lookup
-    using acquisition instead of ILocation.
-    """
-    current = ob
-    while True:
-        if ISite.providedBy(current):
-            return current.getSiteManager()
-        current = getattr(current, '__parent__', aq_parent(aq_inner(current)))
-        if current is None:
-            # It does not support acquisition or has no parent, so we
-            # return the global site
-            return getGlobalSiteManager()
-
-HOOK_NAME = '__local_site_hook__'
-
-class LocalSiteHook(Base):
-    def __call__(self, container, request):
-        notify(BeforeTraverseEvent(container, request))
-
-
-def enableLocalSiteHook(obj):
-    """Install __before_traverse__ hook for Local Site
-    """
-    # We want the original object, not stuff in between, and no acquisition
-    obj = aq_base(obj)
-    if not IPossibleSite.providedBy(obj):
-        raise TypeError, 'Must provide IPossibleSite'
-    hook = AccessRule(HOOK_NAME)
-    registerBeforeTraverse(obj, hook, HOOK_NAME, 1)
-
-    if not hasattr(obj, HOOK_NAME):
-        setattr(obj, HOOK_NAME, LocalSiteHook())
-
-    directlyProvides(obj, ISite, directlyProvidedBy(obj))
-
-def disableLocalSiteHook(obj):
-    """Remove __before_traverse__ hook for Local Site
-    """
-    # We want the original object, not stuff in between, and no acquisition
-    obj = aq_base(obj)
-    if not ISite.providedBy(obj):
-        raise TypeError, 'Must provide ISite'
-    unregisterBeforeTraverse(obj, HOOK_NAME)
-    if hasattr(obj, HOOK_NAME):
-        delattr(obj, HOOK_NAME)
-
-    directlyProvides(obj, directlyProvidedBy(obj) - ISite)
-
 class FiveSiteManager(object):
     implements(IFiveSiteManager)
 
@@ -96,6 +31,13 @@
         self.context = self.__parent__ = context
 
     @property
+    def __bases__(self):
+        next = self.next
+        if next is None:
+            return ()
+        return (next,)
+
+    @property
     def next(self):
         obj = self.context
         while obj is not None:

Modified: Products.Five/trunk/site/metaconfigure.py
===================================================================
--- Products.Five/trunk/site/metaconfigure.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/site/metaconfigure.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -20,7 +20,7 @@
 from zope.interface import classImplements, classImplementsOnly, implementedBy
 from zope.interface.interface import InterfaceClass
 from zope.configuration.exceptions import ConfigurationError
-from zope.app.component.metaconfigure import adapter
+from zope.component.zcml import adapter
 from zope.app.component.interfaces import IPossibleSite
 
 from Products.Five.site.localsite import FiveSite

Modified: Products.Five/trunk/site/tests/dummy.py
===================================================================
--- Products.Five/trunk/site/tests/dummy.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/site/tests/dummy.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -15,7 +15,7 @@
 
 $Id$
 """
-from zope.interface import implements, Interface
+from zope.interface import implements, implementsOnly, Interface
 from OFS.SimpleItem import SimpleItem
 from Products.Five.tests.testing import FiveTraversableFolder
 
@@ -25,7 +25,10 @@
 class DummySite(FiveTraversableFolder):
     """A very dummy Site
     """
-    implements(IDummySite)
+    # we specifically do not let this site inherit any interfaces from
+    # the superclasses so that this class does not implement
+    # IPossibleSite under any circumstances
+    implementsOnly(IDummySite)
 
 def manage_addDummySite(self, id, REQUEST=None):
     """Add the dummy site."""

Modified: Products.Five/trunk/site/tests/sitemanager.txt
===================================================================
--- Products.Five/trunk/site/tests/sitemanager.txt	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/site/tests/sitemanager.txt	2006-05-02 09:21:45 UTC (rev 67820)
@@ -30,8 +30,8 @@
 
 Let's make the possible site a real site:
 
-  >>> from Products.Five.site.localsite import enableLocalSiteHook
-  >>> enableLocalSiteHook(dummysite)
+  >>> from Products.Five.component import enableSite
+  >>> enableSite(dummysite)
 
 and tell Zope 3 about it:
 
@@ -104,7 +104,7 @@
 
 Let's get all the adapters for ``adaptable``:
 
-  >>> zapi.getAdapters((adaptable,), IAdapted) #doctest: +ELLIPSIS
+  >>> list(zapi.getAdapters((adaptable,), IAdapted)) #doctest: +ELLIPSIS
   [(u'', <Products.Five.tests.adapters.Adapter instance at ...>)]
 
 
@@ -118,7 +118,7 @@
 
 Now we set the current site to the ``subsite``:
 
-  >>> enableLocalSiteHook(subsite)
+  >>> enableSite(subsite)
   >>> setSite(subsite)
 
 When we call getServices() now, we get the correct site manager:

Modified: Products.Five/trunk/site/tests/test_localsite.py
===================================================================
--- Products.Five/trunk/site/tests/test_localsite.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/site/tests/test_localsite.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -23,14 +23,13 @@
 import unittest
 from Testing import ZopeTestCase
 
-from zope.interface import implements
-from zope.interface import directlyProvides, directlyProvidedBy
+import zope.interface
 from zope.component import getGlobalSiteManager, getSiteManager
-from zope.component.exceptions import ComponentLookupError
-from zope.component.interfaces import ISiteManager
+from zope.component.interfaces import ComponentLookupError
+from zope.component.interfaces import IComponentLookup
+from zope.traversing.interfaces import IContainmentRoot
 from zope.app.component.hooks import setSite, getSite, setHooks
 from zope.app.component.interfaces import IPossibleSite, ISite
-from zope.app.traversing.interfaces import IContainmentRoot
 from zope.app.testing.placelesssetup import PlacelessSetup
 
 from Acquisition import Implicit
@@ -40,33 +39,32 @@
 from Products.Five import zcml
 
 class SiteManager(Implicit):
-    implements(ISiteManager)
+    zope.interface.implements(IComponentLookup)
 
+    @property
+    def __bases__(self):
+        next = getattr(self, 'next', None)
+        if next is None:
+            return ()
+        return (next,)
+
 class Folder(ObjectManager):
-    implements(IPossibleSite)
 
-    sm = None
-
-    def getId(self):
-        return self.id
-
-    def getSiteManager(self, default=None):
-        return self.sm
-
     def setSiteManager(self, sm):
-        self.sm = sm
-        directlyProvides(self, ISite, directlyProvidedBy(self))
+        super(Folder, self).setSiteManager(sm)
+        zope.interface.alsoProvides(self, ISite)
 
 class Package(Implicit):
     pass
 
 class Root(Folder):
-    implements(IContainmentRoot, ISite)
+    zope.interface.implements(IContainmentRoot, ISite)
+
     def getSiteManager(self):
         return getGlobalSiteManager()
 
 class SiteManagerStub(object):
-    implements(ISiteManager)
+    zope.interface.implements(IComponentLookup)
 
 class SiteManagerTest(PlacelessSetup, unittest.TestCase):
 
@@ -91,6 +89,7 @@
         self.unrooted_subfolder = Folder().__of__(self.unparented_folder)
         zcml.load_config("meta.zcml", Products.Five)
         zcml.load_config("permissions.zcml", Products.Five)
+        zcml.load_config("configure.zcml", Products.Five.component)
         zcml.load_config("configure.zcml", Products.Five.site)
         zcml_text = """\
         <five:localsite
@@ -165,29 +164,6 @@
 #         # Check that getGlobalSiteManager() is not proxied
 #         self.assert_(getNextSiteManager(sm) is getGlobalSiteManager())
 
-    def test_siteManagerAdapter(self):
-        from Products.Five.site.localsite import siteManagerAdapter
-
-        # If it is a site, return the service service.
-        sm = SiteManagerStub()
-        site = Folder()
-        site.setSiteManager(sm)
-        self.assertEqual(siteManagerAdapter(site), sm)
-
-        # If it has an acquisition context, "acquire" the site
-        # and return the service service
-        ob = Folder()
-        ob = ob.__of__(site)
-        self.assertEqual(siteManagerAdapter(ob), sm)
-        ob2 = Folder()
-        ob2 = ob2.__of__(ob)
-        self.assertEqual(siteManagerAdapter(ob2), sm)
-
-        # If it does we are unable to find a service service, raise
-        # ComponentLookupError
-        orphan = Folder()
-        self.failUnless(siteManagerAdapter(orphan) is getGlobalSiteManager())
-
     def test_setThreadSite_clearThreadSite(self):
         from zope.app.component.site import threadSiteSubscriber, clearSite
         from zope.app.publication.zopepublication import BeforeTraverseEvent

Modified: Products.Five/trunk/site/tests/test_utility.py
===================================================================
--- Products.Five/trunk/site/tests/test_utility.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/site/tests/test_utility.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -26,7 +26,7 @@
 
 from zope.interface import directlyProvides
 from zope.component import provideUtility
-from zope.component.exceptions import ComponentLookupError
+from zope.component.interfaces import ComponentLookupError
 from zope.app import zapi
 from zope.app.testing.placelesssetup import setUp, tearDown
 from zope.app.component import getNextUtility
@@ -34,8 +34,8 @@
 
 import Products.Five
 from Products.Five import zcml
+from Products.Five.component import enableSite
 from Products.Five.site.interfaces import IRegisterUtilitySimply
-from Products.Five.site.localsite import enableLocalSiteHook
 from Products.Five.site.tests.dummy import manage_addDummySite, \
      IDummyUtility, ISuperDummyUtility, DummyUtility
 
@@ -45,6 +45,7 @@
         setUp()
         zcml.load_config("meta.zcml", Products.Five)
         zcml.load_config("permissions.zcml", Products.Five)
+        zcml.load_config("configure.zcml", Products.Five.component)
         zcml.load_config("configure.zcml", Products.Five.site)
         zcml_text = """\
         <five:localsite
@@ -52,7 +53,7 @@
             class="Products.Five.site.tests.dummy.DummySite" />"""
         zcml.load_string(zcml_text)
         manage_addDummySite(self.folder, 'site')
-        enableLocalSiteHook(self.folder.site)
+        enableSite(self.folder.site)
         setSite(self.folder.site)
 
         # Hook up custom component architecture calls; we need to do
@@ -173,7 +174,7 @@
 
         # let's also create a subsite and make that our site
         manage_addDummySite(self.folder.site, 'subsite')
-        enableLocalSiteHook(self.folder.site.subsite)
+        enableSite(self.folder.site.subsite)
         setSite(self.folder.site.subsite)
 
         # we should still be able to lookup the original utility from
@@ -249,7 +250,7 @@
 
         # test local site vs. nested local site
         manage_addDummySite(self.folder.site, 'subsite')
-        enableLocalSiteHook(self.folder.site.subsite)
+        enableSite(self.folder.site.subsite)
         setSite(self.folder.site.subsite)
 
         sublocal_dummy = DummyUtility()

Modified: Products.Five/trunk/site/utility.py
===================================================================
--- Products.Five/trunk/site/utility.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/site/utility.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -17,7 +17,7 @@
 """
 from zope.interface import implements
 from zope.component import getGlobalSiteManager
-from zope.component.exceptions import ComponentLookupError
+from zope.component.interfaces import ComponentLookupError
 from zope.app.component import getNextSiteManager
 
 from Acquisition import aq_base
@@ -116,11 +116,3 @@
                              "%s with the name '%s'" % (interface.getName(),
                                                         name))
         utilities._setObject(id, utility)
-
-# BBB 2005/11/01 -- gone in Five 1.5.
-SimpleLocalUtilityService = SimpleLocalUtilityRegistry
-import zope.deprecation
-zope.deprecation.deprecated(
-    'SimpleLocalUtilityService', "'SimpleLocalUtilityService' has been renamed to "
-    "'SimpleLocalUtilityRegistry' and will disappear in Five 1.5."
-    )

Modified: Products.Five/trunk/sizeconfigure.py
===================================================================
--- Products.Five/trunk/sizeconfigure.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/sizeconfigure.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -16,12 +16,13 @@
 
 $Id$
 """
-from zope.app.size.interfaces import ISized
-from Products.Five.fiveconfigure import isFiveMethod
+from zope.size.interfaces import ISized
+from Products.Five import fivemethod, isFiveMethod
 
 # holds classes that were monkeyed with; for clean up
 _monkied = []
 
+ at fivemethod
 def get_size(self):
     size = ISized(self, None)
     if size is not None:
@@ -32,8 +33,6 @@
     if method is not None:
         return self.__five_original_get_size()
 
-get_size.__five_method__ = True
-
 def classSizable(class_):
     """Monkey the class to be sizable through Five"""
     # tuck away the original method if necessary

Modified: Products.Five/trunk/skin/standardmacros.py
===================================================================
--- Products.Five/trunk/skin/standardmacros.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/skin/standardmacros.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -16,8 +16,7 @@
 $Id$
 """
 import zope.interface
-
-from zope.app import zapi
+import zope.component
 from Products.Five.browser import BrowserView
 
 # this is a verbatim copy of zope.app.basicskin except that it doesn't
@@ -37,7 +36,7 @@
         context = self.context
         request = self.request
         for name in self.macro_pages:
-            page = zapi.getMultiAdapter((context, request), name=name)
+            page = zope.component.getMultiAdapter((context, request), name=name)
             try:
                 v = page[key]
             except KeyError:

Modified: Products.Five/trunk/tests/directives.zcml
===================================================================
--- Products.Five/trunk/tests/directives.zcml	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/tests/directives.zcml	2006-05-02 09:21:45 UTC (rev 67820)
@@ -7,13 +7,6 @@
       factory=".adapters.Adapter"
       />
 
-  <!-- Testing the vocabulary directive -->
-
-  <vocabulary
-     name="aVocabulary"
-     factory="zope.schema.tests.test_vocabulary.SampleVocabulary"
-     />
-
   <!-- testing that products meta.zcml statements are picked up. -->
 
   <include file="meta.zcml" />

Modified: Products.Five/trunk/tests/event.txt
===================================================================
--- Products.Five/trunk/tests/event.txt	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/tests/event.txt	2006-05-02 09:21:45 UTC (rev 67820)
@@ -25,9 +25,6 @@
 A bit of setup for the tests. Because we'll test copy/paste, we need to
 work inside a database::
 
-  >>> from zope.app.testing.placelesssetup import setUp, tearDown
-  >>> setUp()
-
   >>> import ZODB.tests.util
   >>> db = ZODB.tests.util.DB()
   >>> connection = db.open()
@@ -58,7 +55,7 @@
 framework's ones, so ours will be called first. This has the effect that
 printed events will be in their "natural" order::
 
-  >>> from zope.app.event.interfaces import IObjectEvent
+  >>> from zope.component.interfaces import IObjectEvent, IRegistrationEvent
   >>> from zope.app.container.interfaces import IObjectMovedEvent
   >>> from OFS.interfaces import IObjectWillBeMovedEvent
   >>> from OFS.interfaces import IObjectClonedEvent
@@ -68,7 +65,8 @@
   >>> def printObjectEventExceptSome(object, event):
   ...     if (IObjectMovedEvent.providedBy(event) or
   ...         IObjectWillBeMovedEvent.providedBy(event) or
-  ...         IObjectClonedEvent.providedBy(event)):
+  ...         IObjectClonedEvent.providedBy(event) or
+  ...         IRegistrationEvent.providedBy(event)):
   ...         return
   ...     print event.__class__.__name__, object.getId()
 
@@ -80,11 +78,12 @@
 
 Finally we need to load the subscribers configuration::
 
-  >>> from Products.Five import zcml
-  >>> import Products.Five
-  >>> import zope.app.component
-  >>> zcml.load_config('meta.zcml', zope.app.component)
-  >>> zcml.load_config('event.zcml', Products.Five)
+  >>> import zope.component
+  >>> import OFS.subscribers
+  >>> zope.component.provideAdapter(OFS.subscribers.ObjectManagerSublocations)
+  >>> zope.component.provideHandler(OFS.subscribers.dispatchObjectWillBeMovedEvent)
+  >>> zope.component.provideHandler(OFS.subscribers.dispatchObjectMovedEvent)
+  >>> zope.component.provideHandler(OFS.subscribers.dispatchObjectClonedEvent)
 
 We need at least one fake deprecated method to tell the compatibility
 framework that component architecture is initialized::
@@ -465,4 +464,3 @@
 
   >>> import transaction
   >>> transaction.abort()
-  >>> tearDown()

Modified: Products.Five/trunk/tests/test_event.py
===================================================================
--- Products.Five/trunk/tests/test_event.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/tests/test_event.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -28,6 +28,12 @@
 from OFS.OrderedFolder import OrderedFolder
 from Products.BTreeFolder2.BTreeFolder2 import BTreeFolder2
 
+from zope.component import testing, eventtesting
+
+def setUp(test):
+    testing.setUp(test)
+    eventtesting.setUp(test)
+
 class DontComplain(object):
     def _verifyObjectPaste(self, object, validate_src=1):
         pass
@@ -82,7 +88,8 @@
 
 def test_suite():
     from zope.testing.doctest import DocFileSuite
-    return DocFileSuite('event.txt', package="Products.Five.tests")
+    return DocFileSuite('event.txt', package="Products.Five.tests",
+                        setUp=setUp, tearDown=testing.tearDown)
 
 if __name__ == '__main__':
     framework()

Modified: Products.Five/trunk/tests/test_i18n.py
===================================================================
--- Products.Five/trunk/tests/test_i18n.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/tests/test_i18n.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -19,18 +19,16 @@
 if __name__ == '__main__':
     execfile(os.path.join(sys.path[0], 'framework.py'))
 
+from zope.component.testing import setUp, tearDown
+
 def test_directive():
     """
-    Test the i18n directive
+    Test the i18n directive.  First, we need to register the ZCML
+    directive:
 
-      >>> from zope.app.testing.placelesssetup import setUp, tearDown
-      >>> setUp()
-
-    First, we need to register the ZCML directive:
-
-      >>> import zope.app.i18n
+      >>> import zope.i18n
       >>> from Products.Five import zcml
-      >>> zcml.load_config('meta.zcml', zope.app.i18n)
+      >>> zcml.load_config('meta.zcml', zope.i18n)
 
     Let's register the gettext locales using the ZCML directive:
 
@@ -56,16 +54,11 @@
       u'This is an explicit message'
       >>> translate(msg, target_language='de')
       u'Dies ist eine explizite Nachricht'
-
-
-    Clean up:
-
-      >>> tearDown()
     """
 
 def test_suite():
-    from Testing.ZopeTestCase import ZopeDocTestSuite
-    return ZopeDocTestSuite()
+    from zope.testing.doctest import DocTestSuite
+    return DocTestSuite(setUp=setUp, tearDown=tearDown)
 
 if __name__ == '__main__':
     framework()

Modified: Products.Five/trunk/tests/test_security.py
===================================================================
--- Products.Five/trunk/tests/test_security.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/tests/test_security.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -72,13 +72,13 @@
 
       >>> configure_zcml = '''
       ... <configure xmlns="http://namespaces.zope.org/zope">
-      ...   <content class="Products.Five.tests.test_security.Dummy1">
+      ...   <class class="Products.Five.tests.test_security.Dummy1">
       ...     <allow attributes="foo" />
       ...     <!--deny attributes="baz" /--> <!-- XXX not yet supported -->
       ...     <require attributes="bar keg"
       ...              permission="zope2.ViewManagementScreens"
       ...              />
-      ...   </content>
+      ...   </class>
       ... </configure>
       ... '''
       >>> zcml.load_string(configure_zcml)

Modified: Products.Five/trunk/tests/test_size.py
===================================================================
--- Products.Five/trunk/tests/test_size.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/tests/test_size.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -20,7 +20,7 @@
     execfile(os.path.join(sys.path[0], 'framework.py'))
 
 from zope.interface import implements
-from zope.app.size.interfaces import ISized
+from zope.size.interfaces import ISized
 
 class SimpleContentSize(object):
     """Size for ``SimpleContent`` objects."""
@@ -64,12 +64,12 @@
       ...   <five:sizable class="Products.Five.tests.testing.fancycontent.FancyContent" />
       ...   <adapter
       ...       for="Products.Five.tests.testing.simplecontent.ISimpleContent"
-      ...       provides="zope.app.size.interfaces.ISized"
+      ...       provides="zope.size.interfaces.ISized"
       ...       factory="Products.Five.tests.test_size.SimpleContentSize"
       ...       />
       ...   <adapter
       ...       for="Products.Five.tests.testing.fancycontent.IFancyContent"
-      ...       provides="zope.app.size.interfaces.ISized"
+      ...       provides="zope.size.interfaces.ISized"
       ...       factory="Products.Five.tests.test_size.FancyContentSize"
       ...       />
       ... </configure>'''

Modified: Products.Five/trunk/traversable.py
===================================================================
--- Products.Five/trunk/traversable.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/traversable.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -15,24 +15,20 @@
 
 $Id$
 """
-
 import warnings
 import zope.deprecation
 
-from zope.component import getMultiAdapter, ComponentLookupError
+import zope.publisher.interfaces
 from zope.interface import implements, Interface
-from zope.publisher.interfaces import ILayer
+from zope.security.proxy import removeSecurityProxy
 from zope.publisher.interfaces.browser import IBrowserRequest
-
-from zope.app.traversing.interfaces import ITraverser, ITraversable
-from zope.app.traversing.adapters import DefaultTraversable
-from zope.app.traversing.adapters import traversePathElement
-from zope.app.publication.browser import setDefaultSkin
+from zope.publisher.browser import setDefaultSkin
 from zope.app.interface import queryType
+from zope.app.publication.publicationtraverse import PublicationTraverse
 
+import zExceptions
 import Products.Five.security
-from zExceptions import NotFound
-from ZPublisher import xmlrpc
+from Products.Five import fivemethod
 
 class FakeRequest(dict):
     implements(IBrowserRequest)
@@ -48,6 +44,7 @@
     """
     __five_traversable__ = True
 
+    @fivemethod
     def __bobo_traverse__(self, REQUEST, name):
         """Hook for Zope 2 traversal
 
@@ -74,7 +71,7 @@
                 return self.__fallback_traverse__(REQUEST, name)
             except (AttributeError, KeyError):
                 pass
-            except NotFound:
+            except zExceptions.NotFound:
                 # OFS.Application.__bobo_traverse__ calls
                 # REQUEST.RESPONSE.notFoundError which sets the HTTP
                 # status code to 404
@@ -109,25 +106,14 @@
         # Con Zope 3 into using Zope 2's checkPermission
         Products.Five.security.newInteraction()
 
-        # Use the ITraverser adapter (which in turn uses ITraversable
-        # adapters) to traverse to a view.  Note that we're mixing
-        # object-graph and object-publishing traversal here, but Zope
-        # 2 has no way to tell us when to use which...
-        # TODO Perhaps we can decide on object-graph vs.
-        # object-publishing traversal depending on whether REQUEST is
-        # a stub or not?
         try:
-            return ITraverser(self).traverse(
-                path=[name], request=REQUEST).__of__(self)
-        except (ComponentLookupError, LookupError,
-                AttributeError, KeyError, NotFound):
+            ob = PublicationTraverse().traverseName(REQUEST, self, name)
+            return removeSecurityProxy(ob).__of__(self)
+        except zope.publisher.interfaces.NotFound:
             pass
 
         raise AttributeError(name)
 
-    __bobo_traverse__.__five_method__ = True
-
-
 class FiveTraversable(DefaultTraversable):
 
     def __init__(self, subject):

Copied: Products.Five/trunk/traversing.zcml (from rev 67817, Products.Five/branches/zope33-port/traversing.zcml)
===================================================================
--- Products.Five/branches/zope33-port/traversing.zcml	2006-05-02 08:43:49 UTC (rev 67817)
+++ Products.Five/trunk/traversing.zcml	2006-05-02 09:21:45 UTC (rev 67820)
@@ -0,0 +1,13 @@
+<configure xmlns="http://namespaces.zope.org/zope"
+           xmlns:five="http://namespaces.zope.org/five">
+
+  <!-- define default namespace adapters, etc. -->
+  <include package="zope.traversing" />
+
+  <adapter
+      for="*"
+      factory=".viewable.BrowserDefault"
+      provides=".interfaces.IBrowserDefault"
+      />
+
+</configure>

Modified: Products.Five/trunk/utilities/browser/tests/test_marker.py
===================================================================
--- Products.Five/trunk/utilities/browser/tests/test_marker.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/utilities/browser/tests/test_marker.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -60,7 +60,7 @@
 
       >>> from Products.Five.tests.testing.simplecontent import ISimpleContent
       >>> class IFooMarker(ISimpleContent): pass
-      >>> from zope.app.component.interface import provideInterface
+      >>> from zope.component.interface import provideInterface
       >>> provideInterface('', IFooMarker)
       >>> view.getAvailableInterfaceNames()
       [...IFooMarker...]

Modified: Products.Five/trunk/utilities/marker.py
===================================================================
--- Products.Five/trunk/utilities/marker.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/utilities/marker.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -19,14 +19,11 @@
 """
 from sets import Set
 
-from zope.interface import implements
-from zope.interface import implementedBy
-from zope.interface import directlyProvidedBy
-from zope.interface import directlyProvides
-from zope.interface import providedBy
+from zope.interface import implements, implementedBy, providedBy
+from zope.interface import directlyProvides, directlyProvidedBy
 from zope.interface.interfaces import IInterface
-from zope.app.component.interface import getInterface, interfaceToName
-from zope.app.component.interface import searchInterface
+from zope.component.interface import getInterface, interfaceToName
+from zope.component.interface import searchInterface
 
 from interfaces import IMarkerInterfaces
 

Modified: Products.Five/trunk/viewable.py
===================================================================
--- Products.Five/trunk/viewable.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/viewable.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -15,21 +15,13 @@
 
 $Id$
 """
-import inspect
-from zExceptions import NotFound
-from zope.component import ComponentLookupError
+import warnings
+import zope.deprecation
 from zope.interface import implements
-from zope.publisher.interfaces.browser import IBrowserRequest
-from zope.app.zapi import getDefaultViewName
-
-from Products.Five.traversable import FakeRequest
+from zope.component.interfaces import ComponentLookupError
+from zope.app.publisher.browser import getDefaultViewName
 from Products.Five.interfaces import IBrowserDefault
 
-_marker = object
-
-import warnings
-import zope.deprecation
-
 class BrowserDefault(object):
     implements(IBrowserDefault)
 

Modified: Products.Five/trunk/viewlet/README.txt
===================================================================
--- Products.Five/trunk/viewlet/README.txt	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/viewlet/README.txt	2006-05-02 09:21:45 UTC (rev 67820)
@@ -181,7 +181,7 @@
   >>> leftColumn['stock']
   Traceback (most recent call last):
   ...
-  ComponentLookupError: 'No provider with name `stock` found.'
+  ComponentLookupError: No provider with name `stock` found.
 
   >>> leftColumn.get('stock') is None
   True

Modified: Products.Five/trunk/viewlet/tests.py
===================================================================
--- Products.Five/trunk/viewlet/tests.py	2006-05-02 09:01:18 UTC (rev 67819)
+++ Products.Five/trunk/viewlet/tests.py	2006-05-02 09:21:45 UTC (rev 67820)
@@ -23,7 +23,6 @@
 from zope.component import provideAdapter
 from zope.interface import Interface
 from zope.interface import implements
-from Products.Five.traversable import FiveTraversable
 from zope.app.traversing.adapters import Traverser
 from zope.app.traversing.interfaces import ITraversable
 from zope.app.traversing.interfaces import ITraverser



More information about the Zope-Checkins mailing list