[Zope-Checkins] SVN: Zope/trunk/ Updated documentation to new version number.
Hanno Schlichting
hannosch at hannosch.eu
Wed May 27 08:45:05 EDT 2009
Log message for revision 100457:
Updated documentation to new version number.
Changed:
U Zope/trunk/doc/CHANGES.rst
U Zope/trunk/doc/WHATSNEW.rst
U Zope/trunk/doc/WINDOWS.rst
D Zope/trunk/doc/ZOPE3.rst
U Zope/trunk/doc/conf.py
U Zope/trunk/doc/index.rst
U Zope/trunk/inst/WinBuilders/mk/zope.mk
U Zope/trunk/inst/generate_index.py
U Zope/trunk/inst/versions.py
U Zope/trunk/setup.py
-=-
Modified: Zope/trunk/doc/CHANGES.rst
===================================================================
--- Zope/trunk/doc/CHANGES.rst 2009-05-27 12:22:59 UTC (rev 100456)
+++ Zope/trunk/doc/CHANGES.rst 2009-05-27 12:45:04 UTC (rev 100457)
@@ -2,8 +2,8 @@
=========
This file contains change information for the current Zope release.
-Change information for previous versions of Zope can be found in the
-file HISTORY.txt.
+Change information for previous versions of Zope can be found at
+http://docs.zope.org/zope2/releases/.
Trunk (unreleased)
------------------
@@ -11,460 +11,12 @@
Restructuring
+++++++++++++
-- Removed all use of ``zope.app.pagetemplate`` by cloning / simplifying
- client code.
+* Updated documentation to new version number.
-- Use ``zope.pagetemplate.engine`` instead of ``zope.app.pagetemplate.engine``.
- (update to versions 3.5.0 and 3.7.0, respectively, along with version 3.8.1
- of ``zope.app.publisher``).
-
-- Use ``IBrowserView`` interface from ``zope.browser.interfaces``, rather than
- ``zope.publisher.interfaces.browser``.
-
-- Use ``IAdding`` interface from ``zope.browser.interfaces``, rather than
- ``zope.app.container``.
-
-- No longer depend on ``zope.app.appsetup``; use the event implementations
- from ``zope.processlifetime`` instead.
-
Features Added
++++++++++++++
-- zExceptions.convertExceptionType: new API, breaking out conversion of
- exception names to exception types from 'upgradeException'.
-- Launchpad #374719: introducing new ZPublisher events:
- PubStart, PubSuccess, PubFailure, PubAfterTraversal and PubBeforeCommit.
-
-- Testing.ZopeTestCase: Include a copy of ZODB.tests.warnhook to silence
- a DeprecationWarning under Python 2.6.
-
-- Updated packages:
-
- * python-gettext 1.0
- * pytz 2009g
- * zope.app.applicationcontrol = 3.5.0
- * zope.app.appsetup 3.11
- * zope.app.component 3.8.2
- * zope.app.container 3.8.0
- * zope.app.form 3.8.0
- * zope.app.http 3.6.0
- * zope.app.interface 3.5.0
- * zope.app.pagetemplate 3.6.0
- * zope.app.publication 3.7.0
- * zope.app.publisher 3.8.0
- * zope.browser 1.2
- * zope.component 3.7.0
- * zope.componentvocabulary 1.0
- * zope.container 3.8.2
- * zope.formlib 3.6.0
- * zope.lifecycleevent 3.5.2
- * zope.location 3.5.4
- * zope.processlifetime 1.0
- * zope.publisher 3.8.0
- * zope.security 3.7.0
- * zope.testing 3.7.4
- * zope.traversing 3.7.0
-
Bugs Fixed
++++++++++
-- Launchpad #374729: Encoding cookie values to avoid issues with
- firewalls and security proxies.
-
-- Launchpad #373583: ZODBMountPoint - fixed broken mount support and
- extended the test suite.
-
-- Launchpad #373621: catching and logging exceptions that could cause
- leaking of worker threads.
-
-- Launchpad #373577: setting up standard logging earlier within the startup
- phase for improving the analysis of startup errors.
-
-- Launchpad #373601: abort transaction before connection close in order to
- prevent connection leaks in case of persistent changes after the main
- transaction is closed.
-
-- Fix BBB regression which prevented setting browser ID cookies from
- browser ID managers created before the ``HTTPOnly`` feature landed.
- https://bugs.launchpad.net/bugs/374816
-
-- RESPONSE.handle_errors was wrongly set (to debug, should have been
- ``not debug``). Also, the check for exception constructor arguments
- didn't account for exceptions that didn't override the ``__init__``
- (which are most of them). The combination of those two problems
- caused the ``standard_error_message`` not to be called. Fixes
- https://bugs.launchpad.net/zope2/+bug/372632 .
-
-- DocumentTemplate.DT_Raise: use new 'zExceptions.convertExceptionType'
- API to allow raising non-builtin exceptions.
- Fixes https://bugs.launchpad.net/zope2/+bug/372629 , which prevented
- viewing the "Try" tab of a script with no parameters.
-
-Zope 2.12.0b1 (2009/05/06)
---------------------------
-
-Restructuring
-+++++++++++++
-
-- No longer depend on ``zope.app.locales``. Zope2 uses almost none of the
- translations provided in the package and is not required for most projects.
- The decision to include locales is left to the application developer now.
-
-- Removed the dependency on ``zope.app.testing`` in favor of providing a more
- minimal placeless setup as part of ZopeTestCase for our own tests.
-
-- updated to ZODB 3.9.0b1
-
-Features Added
-++++++++++++++
-- zExceptions.convertExceptionType: new API, breaking out conversion of
- exception names to exception types from ``upgradeException``.
-
-- Extended BrowserIdManager to expose the ``HTTPOnly`` attribute for its
- cookie. Also via https://bugs.launchpad.net/zope2/+bug/367393 .
-
-- Added support for an optional ``HTTPOnly`` attribute of cookies (see
- http://www.owasp.org/index.php/HTTPOnly). Patch from Stephan Hofmockel,
- via https://bugs.launchpad.net/zope2/+bug/367393 .
-
-Bugs Fixed
-++++++++++
-
-- ZPublisher response.setBody: don't append Accept-Encoding to Vary header if
- it is already present - this can make cache configuration difficult.
-
-2.12.0a4 (2009-04-24)
----------------------
-
-Bugs Fixed
-++++++++++
-
-- fixed versions.cfg in order to support zope.z2release for
- creating a proper index structure
-
-2.12.0a3 (2009-04-19)
----------------------
-
-The generated tarball for the 2.12.0a2 source release was incomplete, due to
-a setuptools and Subversion 1.6 incompatibility.
-
-Restructuring
-+++++++++++++
-
-- Added automatic inline migration for databases created with older Zope
- versions. The ``Versions`` screen from the ``Control_Panel`` is now
- automatically removed on Zope startup.
-
-- Removed more unused code of the versions support feature including the
- Globals.VersionNameName constant.
-
-2.12.0a2 (2009-04-19)
----------------------
-
-Restructuring
-+++++++++++++
-
-- If the <permission /> ZCML directive is used to declare a permission that
- does not exist, the permission will now be created automatically, defaulting
- to being granted to the Manager role only. This means it is possible to
- create new permissions using ZCML only. The permission will Permissions that
- already exist will not be changed.
-
-- Using <require set_schema="..." /> or <require set_attributes="..." /> in
- the <class /> directive now emits a warning rather than an error. The
- concept of protecting attribute 'set' does not exist in Zope 2, but it
- should be possible to re-use packages that do declare such protection.
-
-- Updated to Acquisition 2.12.1.
-
-- Updated to DateTime 2.12.0.
-
-- Updated to ZODB 3.9.0a12.
-
-- Removed the ``getPackages`` wrapper from setup.py which would force all
- versions to an exact requirement. This made it impossible to require
- newer versions of the dependencies. This kind of KGS information needs
- to be expressed in a different way.
-
-- removed ``extras_require`` section from setup.py (this might possibly
- break legacy code).
-
-Bugs Fixed
-++++++++++
-
-- Launchpad #348223: optimize catalog query by breaking out early from loop
- over indexes if the result set is already empty.
-
-- Launchpad #344098: in ``skel/etc/zope.conf.ing``, replaced commented-out
- ``read-only-database`` option, which is deprecated, with pointers to the
- appropos sections of ZODB's ``component.xml``. Updated the description
- of the ``zserver-read-only-mode`` directive to indicate its correct
- semantics (suppressing log / pid / lock files). Added deprecation to the
- ``read-only-database`` option, which has had no effect since Zope 2.6.
-
-- "Permission tab": correct wrong form parameter for
- the user-permission report
-
-- PageTemplates: Made PreferredCharsetResolver work with new kinds of contexts
- that are not acquisition wrapped.
-
-- Object managers should evaluate to True in a boolean test.
-
-2.12.0a1 (2009-02-26)
----------------------
-
-Restructuring
-+++++++++++++
-
-- Switched Products.PageTemplates to directly use zope.i18n.translate and
- removed the GlobalTranslationService hook.
-
-- Removed bridging code from Product.Five for PlacelessTranslationService
- and Localizer. Neither of the two is actually using this anymore.
-
-- Removed the specification of ``SOFTWARE_HOME`` and ``ZOPE_HOME`` from the
- standard instance scripts.
- [hannosch]
-
-- Made the specification of ``SOFTWARE_HOME`` and ``ZOPE_HOME`` optional. In
- addition ``INSTANCE_HOME`` is no longer required to run the tests of a
- source checkout of Zope.
-
-- Removed the ``test`` command from zopectl. The test.py script it was relying
- on does no longer exist.
-
-- Updated to ZODB 3.9.0a11. ZODB-level version support has been
- removed and ZopeUndo now is part of Zope2.
-
-- The Zope2 SVN trunk is now a buildout pulling in all dependencies as
- actual released packages and not SVN externals anymore.
-
-- Make use of the new zope.container and zope.site packages.
-
-- Updated to newer versions of zope packages. Removed long deprecated
- layer and skin ZCML directives.
-
-- Disabled the XML export on the UI level - the export functionality
- however is still available on the Python level.
-
-- No longer show the Help! links in the ZMI, if there is no help
- available. The help system depends on the product registry.
-
-- Updated the quick start page and simplified the standard content.
- The default index_html is now a page template.
-
-- Removed deprecated Draft and Version support from Products.OFSP.
- Also removed version handling from the control panel. Versions are
- no longer supported on the ZODB level.
-
-- Removed left-overs of the deprecated persistent product distribution
- mechanism.
-
-- The persistent product registry is not required for starting Zope
- anymore. ``enable-product-installation`` can be set to off if you don't
- rely on the functionality provided by the registry.
-
-- ZClasses have been deprecated for two major releases. They have been
- removed in this version of Zope.
-
-- Avoid deprecation warnings for the md5 and sha modules in Python 2.6
- by adding conditional imports for the hashlib module.
-
-- Replaced imports from the 'Globals' module throughout the
- tree with imports from the actual modules; the 'Globals' module
- was always intended to be an area for shared data, rather than
- a "facade" for imports. Added zope.deferred.deprecation entries
- to 'Globals' for all symbols / modules previously imported directly.
-
-- Protect against non-existing zope.conf path and products directories.
- This makes it possible to run a Zope instance without a Products or
- lib/python directory.
-
-- Moved exception MountedStorageError from ZODB.POSExceptions
- to Products.TemporaryFolder.mount (now its only client).
-
-- Moved Zope2-specific module, ZODB/Mount.py, to
- Products/TemporaryFolder/mount.py (its only client is
- Products/TemporaryFolder/TemporaryFolder.py).
-
-- Removed spurious import-time dependencies from
- Products/ZODBMountPoint/MountedObject.py.
-
-- Removed Examples.zexp from the skeleton. The TTW shopping cart isn't
- any good example of Zope usage anymore.
-
-- Removed deprecated ZTUtil.Iterator module
-
-- Removed deprecated StructuredText module
-
-- Removed deprecated TAL module
-
-- Removed deprecated modules from Products.PageTemplates.
-
-- Removed deprecated ZCML directives from Five including the whole
- Five.site subpackage.
-
-Features added
-++++++++++++++
-
-- OFS.ObjectManager now fully implements the zope.container.IContainer
- interface. For the last Zope2 releases it already claimed to implement the
- interface, but didn't actually full-fill the interface contract. This means
- you can start using more commonly used Python idioms to access objects
- inside object managers. Complete dictionary-like access and container
- methods including iteration are now supported. For each class derived from
- ObjectManager you can use for any instance om: ``om.keys()`` instead of
- ``om.objectIds()``, ``om.values()`` instead of ``om.objectValues()``, but
- also ``om.items()``, ``ob.get('id')``, ``ob['id']``, ``'id' in om``,
- ``iter(om)``, ``len(om)``, ``om['id'] = object()`` instead of
- ``om._setObject('id', object())`` and ``del ob['id']``. Should contained
- items of the object manager have ids equal to any of the new method names,
- the objects will override the method, as expected in Acquisition enabled
- types. Adding new objects into object managers by those new names will no
- longer work, though. The added methods call the already existing methods
- internally, so if a derived type overwrote those, the new interface will
- provide the same functionality.
-
-- Acquisition has been made aware of ``__parent__`` pointers. This allows
- direct access to many Zope 3 classes without the need to mixin
- Acquisition base classes for the security to work.
-
-- MailHost: now uses zope.sendmail for delivering the mail. With this
- change MailHost integrates with the Zope transaction system (avoids
- sending dupe emails in case of conflict errors). In addition
- MailHost now provides support for asynchronous mail delivery. The
- 'Use queue' configuration option will create a mail queue on the
- filesystem (under 'Queue directory') and start a queue thread that
- checks the queue every three seconds. This decouples the sending of
- mail from its delivery. In addition MailHosts now supports
- encrypted connections through TLS/SSL.
-
-- SiteErrorLog now includes the entry id in the information copied to
- the event log. This allowes you to correlate a user error report with
- the event log after a restart, or let's you find the REQUEST
- information in the SiteErrorLog when looking at a traceback in the
- event log.
-
-Bugs Fixed
-++++++++++
-
-- Launchpad #332168: Connection.py: do not expose DB connection strings
- through exceptions
-
-- Specified height/width of icons in ZMI listings so the table doesn't
- jump around while loading.
-
-- After the proper introduction of parent-pointers, it's now
- wrong to acquisition-wrap content providers. We will now use
- the "classic" content provider expression from Zope 3.
-
-- Ported c69896 to Five. This fix makes it possible to provide a
- template using Python, and not have it being set to ``None`` by
- the viewlet manager directive.
-
-- Made Five.testbrowser compatible with mechanize 0.1.7b.
-
-- Launchpad #280334: Fixed problem with 'timeout'
- argument/attribute missing in testbrowser tests.
-
-- Launchpad #267834: proper separation of HTTP header fields
- using CRLF as requested by RFC 2616.
-
-- Launchpad #257276: fix for possible denial-of-service attack
- in PythonScript when passing an arbitrary module to the encode()
- or decode() of strings.
-
-- Launchpad #257269: 'raise SystemExit' with a PythonScript could shutdown
- a complete Zope instance
-
-- Switch to branch of 'zope.testbrowser' external which suppresses
- over-the-wire tests.
-
-- Launchpad #143902: Fixed App.ImageFile to use a stream iterator to
- output the file. Avoid loading the file content when guessing the
- mimetype and only load the first 1024 bytes of the file when it cannot
- be guessed from the filename.
-
-- Changed PageTemplateFile not to load the file contents on Zope startup
- anymore but on first access instead. This brings them inline with the
- zope.pagetemplate version and speeds up Zope startup.
-
-- Collector #2278: form ':record' objects did not implement enough
- of the mapping protocol.
-
-- "version.txt" file was being written to the wrong place by the
- Makefile, causing Zope to report "unreleased version" even for
- released versions.
-
-- Five.browser.metaconfigure.page didn't protect names from interface
- superclasses (http://www.zope.org/Collectors/Zope/2333)
-
-- DAV: litmus "notowner_modify" tests warn during a MOVE request
- because we returned "412 Precondition Failed" instead of "423
- Locked" when the resource attempting to be moved was itself
- locked. Fixed by changing Resource.Resource.MOVE to raise the
- correct error.
-
-- DAV: litmus props tests 19: propvalnspace and 20:
- propwformed were failing because Zope did not strip off the
- xmlns: attribute attached to XML property values. We now strip
- off all attributes that look like xmlns declarations.
-
-- DAV: When a client attempted to unlock a resource with a token
- that the resource hadn't been locked with, in the past we
- returned a 204 response. This was incorrect. The "correct"
- behavior is to do what mod_dav does, which is return a '400
- Bad Request' error. This was caught by litmus
- locks.notowner_lock test #10. See
- http://lists.w3.org/Archives/Public/w3c-dist-auth/2001JanMar/0099.html
- for further rationale.
-
-- When Zope properties were set via DAV in the "null" namespace
- (xmlns="") a subsequent PROPFIND for the property would cause the
- XML representation for that property to show a namespace of
- xmlns="None". Fixed within OFS.PropertySheets.dav__propstat.
-
-- integrated theuni's additional test from 2.11 (see r73132)
-
-- Relaxed requirements for context of
- Products.Five.browser.pagetemplatefile.ZopeTwoPageTemplateFile,
- to reduce barriers for testing renderability of views which
- use them.
- (http://www.zope.org/Collectors/Zope/2327)
-
-- PluginIndexes: Fixed 'parseIndexRequest' for false values.
-
-- Collector #2263: 'field2ulines' did not convert empty string
- correctly.
-
-- Collector #2198: Zope 3.3 fix breaks Five 1.5 test_getNextUtility
-
-- Prevent ZPublisher from insering incorrect <base/> tags into the
- headers of plain html files served from Zope3 resource directories.
-
-- Changed the condition checking for setting status of
- HTTPResponse from to account for new-style classes.
-
-- The Wrapper_compare function from tp_compare to tp_richcompare.
- Also another function Wrapper_richcompare is added.
-
-- The doc test has been slightly changed in ZPublisher to get
- the error message extracted correctly.
-
-- The changes made in Acquisition.c in Implicit Acquisition
- comparison made avail to Explicit Acquisition comparison also.
-
-- zopedoctest no longer breaks if the URL contains more than one
- question mark. It broke even when the second question mark was
- correctly quoted.
-
-Other Changes
-+++++++++++++
-
-- Added lib/python/webdav/litmus-results.txt explaining current
- test results from the litmus WebDAV torture test.
-
-- DocumentTemplate.DT_Var.newline_to_br(): Simpler, faster
- implementation.
-
Modified: Zope/trunk/doc/WHATSNEW.rst
===================================================================
--- Zope/trunk/doc/WHATSNEW.rst 2009-05-27 12:22:59 UTC (rev 100456)
+++ Zope/trunk/doc/WHATSNEW.rst 2009-05-27 12:45:04 UTC (rev 100457)
@@ -1,4 +1,4 @@
-What's new in Zope 2.12
+What's new in Zope 2.13
=======================
The article explains the new high-level features and changes found in this
@@ -8,333 +8,7 @@
about all minor new features and bugs being solved in this release.
-Support for newer Python versions
----------------------------------
+News!
+-----
-Zope 2 has supported and required Python 2.4 since its 2.9 release in summer
-2006. Later versions of Python have so far been unsupported by Zope 2.
-
-This version of Zope 2 adds support for both Python 2.5 and 2.6 at the same
-time. As Python 2.4 is no longer maintained itself, it is no longer officially
-supported by this Zope 2 version. There is however no code in Zope 2 yet which
-requires Python 2.5, so applications built on top of Zope 2 should still
-continue to run with Python 2.4.
-
-Python 3 is a backwards incompatible release of Python and not supported. At
-this point there is no concrete roadmap for adoption of Python 3. It is
-expected to be a question of multiple major Zope 2 releases or years, though.
-
-
-Fully eggified
---------------
-
-Zope 2 itself is now fully eggified and compatible with `setuptools
-<http://pypi.python.org/pypi/setuptools>`_. You can use popular tools like
-`easy_install <http://peak.telecommunity.com/DevCenter/EasyInstall>`_ or
-`zc.buildout <http://pypi.python.org/pypi/zc.buildout>`_ to install Zope 2.
-
-Releases of Zope 2 can be found at and will be installable from the Python
-package index at http://pypi.python.org/pypi/Zope2.
-
-The repackaging of Zope 2 into an eggified form and accompanying changes to the
-file system layout have caused a number of changes. The environment variables
-`SOFTWARE_HOME` and `ZOPE_HOME` are no longer available nor set in the control
-scripts. If you need to access data files inside the Zope 2 package, you can
-for example use `import os, OFS; os.path.dirname(OFS.__file__)` to locate the
-files inside the OFS package.
-
-In general it is discouraged to rely on the `lib/python` and `Products`
-directories to make code available to the running Zope process. While these
-mechanisms continue to work, you are encouraged to use normal distutils or
-setuptools managed packages and add these to your `sys.path` using any of the
-standard Python mechanisms. To create isolated Python environments both
-`zc.buildout <http://pypi.python.org/pypi/zc.buildout>`_ and `virtualenv
-<http://pypi.python.org/pypi/virtualenv>`_ are in wide-spread use.
-
-
-Zope Toolkit
-------------
-
-This version of Zope 2 is based on the Zope Toolkit. The Zope Toolkit is an
-extraction of the reusable and wildly used packages of the former Zope 3
-project. The Zope Toolkit is focused on supporting frameworks and applications,
-rather than trying to be one itself. Parts of the Zope Toolkit are used by
-Zope 2, Plone, Grok, Repoze.bfg, and by many other different applications and
-frameworks.
-
-A major focus of the Zope Toolkit was to refactor package dependencies to
-generate more maintainable and better structured code. Based on this effort
-the number of packages included by Zope 2 could be dramatically reduced from
-about 120 additional packages to just over 60. The total code size of Zope 2
-and its dependencies has decreased by over 200,000 lines of code as a result.
-
-You can find more information about the changes in the Zope Toolkit at
-http://docs.zope.org/zopetoolkit/. Upgrade information from Zope 3 to the Zope
-Toolkit can be found at http://docs.zope.org/zopetoolkit/migration/index.html.
-
-
-ZODB 3.9
---------
-
-This version of Zope 2 includes the latest version of the `ZODB (3.9)
-<http://pypi.python.org/pypi/ZODB3>`_. It has a multitude of new configuration
-options and bug fixes. File storages have gotten native support for blob
-storages and demo storages have been expanded extensively. There is a large
-number of options to tune ZEO servers and clients in large scale environments
-and control cache invalidation and packaging to a much wider degree.
-
-You can read more about the detailed changes in the `ZODB3 change log
-<http://pypi.python.org/pypi/ZODB3>`_ for version 3.9.
-
-
-Module cleanup
---------------
-
-As with every release of Zope 2 this version has removed various modules
-which have been deprecated in prior versions.
-
-Most notably ZClasses and supporting modules have been removed entirely from
-Zope 2. As a result the persistent product registry has been made optional, but
-is still enabled by default. If your application does not rely on the registry,
-you can now disable it by specifying::
-
- enable-product-installation off
-
-inside your `zope.conf` file. With the option turned off Zope will no longer
-write any new transactions to your database during startup in most cases.
-
-With the upgrade to ZODB 3.9 database-level version support is no longer
-available. Many of the modules in `Products.OFSP` have been removed as a
-result. The low level API to load objects from the database has lost its
-version argument as a result of this.
-
-
-Documentation updates
----------------------
-
-Zope 2 now uses `Sphinx <http://sphinx.pocoo.org/>`_ to create pleasant HTML
-representations of its documentation. An effort is underway to update the
-publicly available documentation using Sphinx at http://docs.zope.org/.
-
-So far the Zope 2 Book, the Zope Developers Guide and many smaller articles
-have been converted to reStructuredText and their content updated.
-
-
-Acquisition redux
------------------
-
-The short technical version of this change is: "Acquisition has been made aware
-of __parent__ pointers". What sounds like a small change is actually a major
-step in the integration story for Zope components based technology into Zope 2.
-
-While integrating the Zope component architecture and its many concepts into
-Zope 2 an integration layer called Five (Zope 2 + 3) has been created. One of
-the major reasons for the necessity of an integration layer has been in the way
-Zope 2 was tightly coupled to the concept of Acquisition. The entire security
-machinery, object traversal and publication has been relying on this.
-
-All classes, which wanted to interact with Zope 2 in any non-trivial way, had
-to inherit from the Acquisition base classes. As a result almost no external
-package could directly work inside Zope 2 but required an integration layer.
-
-With this version of Zope 2, objects have a new option of providing location
-awareness to Zope APIs. This new option is to provide an explicit parent
-pointer in the ``__parent__`` attribute, much like specified by the ILocation
-API from `zope.location <http://pypi.python.org/pypi/zope.location>`_. Browser
-views and other location-dependent components implement ILocation already.
-
-Classes adhering to this convention need to get `__parent__` pointers set to
-their container object, when being put into the container. Code that operates
-on such objects can then walk up the containment hierarchy by following the
-pointers. In Acquisition based classes no information would be stored on the
-objects, but Acquisition wrappers are constructed around the objects instead.
-Only those wrappers would hold the container references. The Acquisition
-wrapping relies on the objects to provide an `__of__` method as done by the
-Acquisition base classes.
-
-The most common way of getting the container of an instance is to call::
-
- from Acquisition import aq_parent
-
- container = aq_parent(instance)
-
-For instances providing the ILocation interface the common way is::
-
- container = instance.__parent__
-
-There are various `aq_*` methods available for various other tasks related to
-locating objects in the containment hierarchy. So far virtually all objects in
-Zope 2 would participate in Acquisition. As a side-effect many people relied on
-Acquisition wrappers to be found around their objects. This caused code to rely
-on accessing the `aq_*` methods as attributes of the wrapper::
-
- container = instance.aq_parent
-
-While all the existing API's still work as before, Acquisition now respects
-`__parent__` pointers to find the container for an object. It will also not
-unconditionally try to call the `__of__` method of objects anymore, but protect
-it with a proper interface check::
-
- from Acquisition.interfaces import IAcquirer
-
- if IAcquirer.providedBy(instance):
- instance = instance.__of__(container)
-
-In addition to this check you should no longer rely on the `aq_*` methods to be
-available as attributes. While all code inside Zope 2 itself still supports
-this, it does no longer rely on those but makes proper use of the functions
-provided by the Acquisition package.
-
-To understand the interaction between the new and old approach here is a
-little example::
-
- >>> class Location(object):
- ... def __init__(self, name):
- ... self.__name__ = name
- ... def __repr__(self):
- ... return self.__name__
-
- # Create an Acquisition variant of the class:
-
- >>> import Acquisition
- >>> class Implicit(Location, Acquisition.Implicit):
- ... pass
-
- # Create two implicit instances:
-
- >>> root = Implicit('root')
- >>> folder = Implicit('folder')
-
- # And two new Acquisition-free instances:
-
- >>> container = Location('container')
- >>> item = Location('item')
-
- # Provide the containment hints:
-
- >>> folder = folder.__of__(root)
- >>> container.__parent__ = folder
- >>> item.__parent__ = container
-
- # Test the containtment chain:
-
- >>> from Acquisition import aq_parent
- >>> aq_parent(container)
- folder
-
- >>> from Acquisition import aq_chain
- >>> aq_chain(item)
- [item, container, folder, root]
-
- # Explicit pointers take precedence over Acquisition wrappers:
-
- >>> item2 = Implicit('item2')
- >>> item2 = item2.__of__(folder)
- >>> item2.__parent__ = container
-
- >>> aq_chain(item2)
- [item2, container, folder, root]
-
-For a less abstract example, you so far had to do::
-
- >>> from Acquisition import aq_inner
- >>> from Acquisition import aq_parent
- >>> from Products import Five
-
- >>> class MyView(Five.browser.BrowserView):
- ...
- ... def do_something(self):
- ... container = aq_parent(aq_inner(self.context))
-
-Instead you can now do::
-
- >>> import zope.publisher.browser
-
- >>> class MyView(zope.publisher.browser.BrowserView):
- ...
- ... def do_something(self):
- ... container = aq_parent(self.context)
-
-As the zope.publisher BrowserView supports the ILocation interface, all of this
-works automatically. A view considers its context as its parent as before, but
-no longer needs Acquisition wrapping for the Acquisition machinery to
-understand this. The next time you want to use a package or make your own code
-more reusable outside of Zope 2, this should be of tremendous help.
-
-
-Object managers and IContainer
-------------------------------
-
-One of the fundamental parts of Zope 2 is the object file system as implemented
-in the `OFS` package. A central part of this package is an underlying class
-called `ObjectManager`. It is a base class of the standard `Folder` used
-for many container-ish classes inside Zope 2.
-
-The API to access objects in an object manager or to add objects to one has
-been written many years ago. Since those times Python itself has gotten
-standard ways to access objects in containers and work with them. Those Python
-API's are most familiar to most developers working with Zope. The Zope
-components libraries have formalized those API's into the general IContainer
-interface in the zope.container package. In this version of Zope 2 the standard
-OFS ObjectManager fully implements this IContainer interface in addition to its
-old API.
-
- >>> from zope.container.interfaces import IContainer
- >>> from OFS.ObjectManager import ObjectManager
- >>> IContainer.implementedBy(ObjectManager)
- True
-
-You can now write your code in a way that no longer ties it to object managers
-alone, but can support any class implementing IContainer instead. In
-conjunction with the Acquisition changes above, this will increase your chances
-of being able to reuse existing packages not specifically written for Zope 2 in
-a major way.
-
-Here's an example of how you did work with object managers before::
-
- >>> from OFS.Folder import Folder
- >>> from OFS.SimpleItem import SimpleItem
-
- >>> folder = Folder('folder')
- >>> item1 = SimpleItem('item1')
- >>> item2 = SimpleItem('item2')
-
- >>> result = folder._setObject('item1', item1)
- >>> result = folder._setObject('item2', item2)
-
- >>> folder.objectIds()
- ['item1', 'item2']
-
- >>> folder.objectValues()
- [<SimpleItem at folder/>, <SimpleItem at folder/>]
-
- >>> if folder.hasObject('item2')
- ... folder._delObject('item2')
-
-Instead of this special API, you can now use::
-
- >>> from OFS.Folder import Folder
- >>> from OFS.SimpleItem import SimpleItem
-
- >>> folder = Folder('folder')
- >>> item1 = SimpleItem('item1')
- >>> item2 = SimpleItem('item2')
-
- >>> folder['item1'] = item1
- >>> folder['item2'] = item2
-
- >>> folder.keys()
- ['item1', 'item2']
-
- >>> folder.values()
- [<SimpleItem at folder/>, <SimpleItem at folder/>]
-
- >>> folder.get('item1')
- <SimpleItem at folder/>
-
- >>> if 'item2' in folder:
- ... del folder['item2']
-
- >>> folder.items()
- [('item1', <SimpleItem at folder/>)]
-
+No major new features are available in this version yet.
Modified: Zope/trunk/doc/WINDOWS.rst
===================================================================
--- Zope/trunk/doc/WINDOWS.rst 2009-05-27 12:22:59 UTC (rev 100456)
+++ Zope/trunk/doc/WINDOWS.rst 2009-05-27 12:45:04 UTC (rev 100457)
@@ -16,7 +16,7 @@
% python.exe inst\configure.py
It should say something like:
>
- > - Zope top-level binary directory will be c:\Zope-2.12.
+ > - Zope top-level binary directory will be c:\Zope-2.13.
> - Makefile written.
>
> Next, run the Visual C++ batch file "VCVARS32.bat" and then "nmake".
Deleted: Zope/trunk/doc/ZOPE3.rst
===================================================================
--- Zope/trunk/doc/ZOPE3.rst 2009-05-27 12:22:59 UTC (rev 100456)
+++ Zope/trunk/doc/ZOPE3.rst 2009-05-27 12:45:04 UTC (rev 100457)
@@ -1,30 +0,0 @@
-Using Zope Components in Zope 2 Applications
-============================================
-
-Background
-----------
-
-Zope 3 is a separate project from the Zope community aimed at web
-development. It is designed to be more 'programmer-centric' and easier
-to learn, use and extend for programmers. Zope 3 introduces an
-interface-centric component architecture that makes it easier to develop
-and deploy components without requiring developers to learn and
-understand the entire Zope framework.
-
-As of Zope 2.8, the "Five" project has been integrated into the
-Zope 2 core. The "Five" project implements a compatibility layer
-that allows many Zope 3 components and patterns to be used in
-new and existing Zope 2 applications.
-
-Features
---------
-
-The Five integration layer provides support for Zope 3 interfaces,
-Zope Configuration Markup Language (ZCML), adapters, views,
-utilities and schema-driven content.
-
-Note that the Five layer does *not* attempt to provide a ZMI user
-interface for Zope 3 components.
-
-Zope 2 includes the essential Zope 3 packages, so it is not
-necessary to install Zope 3.
Modified: Zope/trunk/doc/conf.py
===================================================================
--- Zope/trunk/doc/conf.py 2009-05-27 12:22:59 UTC (rev 100456)
+++ Zope/trunk/doc/conf.py 2009-05-27 12:45:04 UTC (rev 100457)
@@ -49,9 +49,9 @@
# built documents.
#
# The short X.Y version.
-version = '2.12.0'
+version = '2.13'
# The full version, including alpha/beta/rc tags.
-release = '2.12.0a4'
+release = '2.13.0dev'
# The language for content autogenerated by Sphinx. Refer to documentation
# for a list of supported languages.
Modified: Zope/trunk/doc/index.rst
===================================================================
--- Zope/trunk/doc/index.rst 2009-05-27 12:22:59 UTC (rev 100456)
+++ Zope/trunk/doc/index.rst 2009-05-27 12:45:04 UTC (rev 100457)
@@ -1,5 +1,5 @@
-Zope 2.12 specific documentation
+Zope 2.13 specific documentation
================================
Contents:
Modified: Zope/trunk/inst/WinBuilders/mk/zope.mk
===================================================================
--- Zope/trunk/inst/WinBuilders/mk/zope.mk 2009-05-27 12:22:59 UTC (rev 100456)
+++ Zope/trunk/inst/WinBuilders/mk/zope.mk 2009-05-27 12:45:04 UTC (rev 100457)
@@ -1,4 +1,4 @@
-ZOPEVERSION = 2.12.0b1
+ZOPEVERSION = 2.13.0dev
ZOPEDIRNAME := Zope-$(ZOPEVERSION)
ZOPE_REQUIRED_FILES=tmp/$(ZOPEDIRNAME).tgz
Modified: Zope/trunk/inst/generate_index.py
===================================================================
--- Zope/trunk/inst/generate_index.py 2009-05-27 12:22:59 UTC (rev 100456)
+++ Zope/trunk/inst/generate_index.py 2009-05-27 12:45:04 UTC (rev 100457)
@@ -49,7 +49,7 @@
links = list()
dirname = sys.argv[1]
-write_index('Zope2', '2.12.0a3')
+write_index('Zope2', '2.13.0dev')
for package in CP.options('versions'):
Modified: Zope/trunk/inst/versions.py
===================================================================
--- Zope/trunk/inst/versions.py 2009-05-27 12:22:59 UTC (rev 100456)
+++ Zope/trunk/inst/versions.py 2009-05-27 12:45:04 UTC (rev 100457)
@@ -1,7 +1,7 @@
-ZOPE_MAJOR_VERSION = '2.12'
+ZOPE_MAJOR_VERSION = '2.13'
ZOPE_MINOR_VERSION = '0'
ZOPE_BRANCH_NAME = '$Name$'[6:] or 'no-branch'
# always start prerelease branches with '0' to avoid upgrade
# issues in RPMs
-VERSION_RELEASE_TAG = 'b1'
+VERSION_RELEASE_TAG = '0.dev'
Modified: Zope/trunk/setup.py
===================================================================
--- Zope/trunk/setup.py 2009-05-27 12:22:59 UTC (rev 100456)
+++ Zope/trunk/setup.py 2009-05-27 12:45:04 UTC (rev 100457)
@@ -19,7 +19,7 @@
EXTENSIONCLASS_INCLUDEDIRS = ['include', 'src']
params = dict(name='Zope2',
- version='2.13dev',
+ version='2.13.0dev',
url='http://www.zope.org',
license='ZPL 2.1',
description='Zope2 application server / web framework',
More information about the Zope-Checkins
mailing list