Zope Component Architecture
.. image:: https://github.com/zopefoundation/zope.component/actions/workflows/tests.yml/badge.svg :target: https://github.com/zopefoundation/zope.component/actions/workflows/tests.yml :alt: Unit test status
.. image:: https://coveralls.io/repos/github/zopefoundation/zope.component/badge.svg?branch=master :target: https://coveralls.io/github/zopefoundation/zope.component?branch=master :alt: Coverage Status
.. image:: https://img.shields.io/pypi/v/zope.component.svg :target: https://pypi.python.org/pypi/zope.component/ :alt: Current version on PyPI
.. image:: https://img.shields.io/pypi/pyversions/zope.component :target: https://pypi.org/project/zope.component/ :alt: Supported Python versions
.. image:: https://readthedocs.org/projects/zopecomponent/badge/?version=latest :target: http://zopecomponent.readthedocs.org/en/latest/ :alt: Documentation Status
.. note::
This package is intended to be independently reusable in any Python
project. It is maintained by the
Zope Toolkit project <http://docs.zope.org/zopetoolkit/>_.
This package represents the core of the Zope Component Architecture. Together with the zope.interface_ package, it provides facilities for defining, registering and looking up components.
Please see https://zopecomponent.readthedocs.io/en/latest/ for the documentation.
.. _zope.interface: https://github.com/zopefoundation/zope.interface
Fix crash when the environment variable PYTHONOPTIMIZED is set to 2
and docstrings are set to None by the interpreter.
(#67 <https://github.com/zopefoundation/zope.component/issues/67>_)
Add support for Python 3.10 and 3.11.
TypeError. See issue 62 <https://github.com/zopefoundation/zope.component/issues/62>_.Remove backwards compatibility imports that were emitting
deprecation warnings. This affects certain imports from
zope.component.interfaces (which should be imported from
zope.interface.interfaces) as well as certain imports from
zope.component.registery (import from
zope.interface.registry), and the entire
zope.component.hookable module. See issue 59 <https://github.com/zopefoundation/zope.component/issues/59>_.
Respect permission value for utility factory registrations
(#54 <https://github.com/zopefoundation/zope.component/issues/54>_)
Add support for Python 3.9
Fix the <subscriber> ZCML directive to allow a missing
provides= attribute when a factory= is given and the Python
object has been decorated with @implementer and implements a
single interface. This has been documented, but hasn't worked
before. See issue 9 <https://github.com/zopefoundation/zope.component/issues/9>_.
Make PersistentAdapterRegistry use persistent objects
(PersistentMapping and PersistentList) for its internal data
structures instead of plain dicts and lists. This helps make it
scalable to larger registry sizes.
This requires zope.interface 5.3.0a1 or later.
New registries (and their primary users, PersistentComponents and
zope.site's LocalSiteManager) take full advantage of this
automatically. For existing persistent registries to take advantage
of this, you must call their rebuild() method and commit the
transaction.
See issue 51 <https://github.com/zopefoundation/zope.component/issues/51>_.
Fix zope.interface.interface.provideInterface and the various
search and query methods to use the current site manager instead of
always using the global site manager. (provideInterface is
called implicitly when registering components from ZCML.) The search
and query methods continue to return interfaces registered in base
site managers.
See issue 10 <https://github.com/zopefoundation/zope.component/issues/51>_.
PR 49 <https://github.com/zopefoundation/zope.component/pull/49>_.BaseGlobalComponents is
consistent. See issue 45 <https://github.com/zopefoundation/zope.component/issues/45>_.Add support for Python 3.8.
Drop support for Python 3.4.
Fix tests on Python 2 following changes in ZODB 5.5.0.
Add support for Python 3.7.
Always install zope.hookable as a dependency (the hook
extra is now empty). zope.hookable respects the PURE_PYTHON
environment variable, and has an optional C extension.
Make accessing names that have been moved to zope.interface
produce a DeprecationWarning.
searchInterface from
interfaceToName. See https://github.com/zopefoundation/zope.component/issues/32Add support for Python 3.6.
Drop support for Python 3.3.
Drop support for "setup.py test".
Code coverage reports are now produced and hosted by coveralls.io <https://coveralls.io/github/zopefoundation/zope.component>_, and
PRs must keep them at 100%.
Internal test code in zope.component.testfiles has been adjusted
and in some cases removed.
When testing PURE_PYTHON environments under tox, avoid poisoning
the user's global wheel cache.
Drop support for Python 2.6 and 3.2.
Add support for Python 3.5.
Update boostrap.py to version 2.2.
Reset the cached adapter_hooks at zope.testing.cleanup.cleanUp
time (LP1100501).
Implement ability to specify adapter and utility names in Python. Use
the @zope.component.named(name) decorator to specify the name.
Change "ZODB3" depdendency to "persistent".
tox now runs all tests for Python 3.2 and 3.3.
Enable buildout for Python 3.
Fix new failing tests.
Add PyPy and Python 3.2 support:
Security support omitted until zope.security ported.
Persistent registry support omitted until ZODB ported (or
persistent factored out).
Bring unit test coverage to 100%.
Remove the long-deprecated layer argument to the
zope.component.zcml.view and zope.component.zcml.resource
ZCML directives.
Add support for continuous integration using tox and jenkins.
Got tests to run using setup.py test.
Add Sphinx documentation.
Add setup.py docs alias (installs Sphinx and dependencies).
Add setup.py dev alias (runs setup.py develop plus installs
nose and coverage).
with site(foo) in try/finally (LP768151).with site(foo): ....Move code from zope.component.registry which implements a basic
nonperistent component registry to zope.interface.registry.  This code
was moved from zope.component into zope.interface to make porting
systems (such as Pyramid) that rely only on a basic component registry to
Python 3 possible without needing to port the entirety of the
zope.component package.  Backwards compatibility import shims have been
left behind in zope.component, so this change will not break any
existing code.
Move interfaces from zope.component.interfaces to
zope.interface.interfaces: ComponentLookupError, Invalid,
IObjectEvent, ObjectEvent, IComponentLookup, IRegistration,
IUtilityRegistration, IAdapterRegistration,
ISubscriptionAdapterRegistration, IHandlerRegistration,
IRegistrationEvent, RegistrationEvent, IRegistered,
Registered, IUnregistered, Unregistered,
IComponentRegistry, and IComponents.  Backwards compatibility shims
left in place.
Depend on zope.interface >= 3.8.0.
Remove the docs extra and the sphinxdoc recipe.
Create a security extra to move security-related dependencies out of the
test extra.
Use the new zope.testrunner package for tests.
Add a basic test for the configure.zcml file provided.
doctest to the one from zope.testing.zope.component now register the
components in the registry returned by getSiteManager instead of the
global registry. This change allows the hooking of the getSiteManager
method before the load of a ZCML file to register the components in a
custom registry.CheckerPublic to securityAdapterFactory wrongly wrapped the factory
into a LocatingUntrustedAdapterFactory.-v option.src/zope/component/testlayer.py and
src/zope/component/testlayer.txt.Remove the dependencies on zope.proxy and zope.security from the
zcml extra: zope.component no longer has a hard dependency on them;
the support for security proxied components ZCML registrations is enabled
only if zope.security and zope.proxy are available.
Move the IPossibleSite and ISite interfaces here from
zope.location as they are dealing with zope.component's concept of
a site, but not with location.
Move the zope.site.hooks functionality to zope.component.hooks as it
isn't actually dealing with zope.site's concept of a site.
Fix a problem, where queryNextUtility could fail if the context could
not be adapted to a IComponentLookup.
Fix 2 related bugs:
When a utility is registered and there was previously a utility registered for the same interface and name, then the old utility is unregistered. The 2 bugs related to this:
There was no Unregistered for the implicit unregistration. Now
there is.
The old utility was still held and returned by
getAllUtilitiesRegisteredFor.  In other words, it was still
considered registered, eeven though it wasn't.  A particularly
negative consequence of this is that the utility is held in memory
or in the database even though it isn't used.
Ensure that HookableTests are run by the testrunner.
Add zope:view and zope:resource implementations into
zope.component.zcml (dependency loaded with zope.component [zcml]).
IMPORTANT: the interfaces that were defined in the
zope.component.bbb.interfaces and deprecated for years are
now (re)moved. However, some packages, including part of zope
framework were still using those interfaces. They will be adapted
for this change. If you were using some of those interfaces, you
need to adapt your code as well:
Move IView and IDefaultViewName to zope.publisher.interfaces.
Move IResource to zope.app.publisher.interfaces.
Remove IContextDependent, IPresentation, IPresentationRequest,
IResourceFactory, and IViewFactory completely.
If you used IViewFactory in context of zope.app.form, there's now
IWidgetFactory in the zope.app.form.interfaces instead.
Move getNextUtility / queryNextUtility functions here from
zope.site (they were in zope.app.component even earlier).
Add a pure-Python hookable implementation, for use when
zope.hookable is not present.
Remove use of zope.deferredimport by breaking import cycles.
Cleanup package documentation and changelog a bit. Add sphinx-based documentation building command to the buildout.
Remove deprecated code.
Change package's mailing list address to zope-dev at zope.org, because zope3-dev at zope.org is now retired.
<utility factory="..."> no longer supported
interfaces declared in Python and always wanted an explicit
provides="..." attribute. https://bugs.launchpad.net/zope3/+bug/251865Support registration of utilities via factories through the component registry and return factory information in the registration information. Fixes https://bugs.launchpad.net/zope3/+bug/240631
Optimize un/registerUtility by storing an optimized data structure for
efficient retrieval of already registered utilities. This avoids looping over
all utilities when registering a new one.
No further changes since 3.4.0a1.
Corresponds to zope.component from Zope 3.4.0a1.
zope.component was simplified yet once
more.  See http://wiki.zope.org/zope3/LocalComponentManagementSimplification
for the proposal describing the changes.package_dir must be a relative path.setup.cfg in sdist builds.Corresponds to the verison of the zope.component package shipped as part
of the Zope 3.2.0 release.
Deprecated services and related APIs. The adapter and utility registries are now available directly via the site manager's 'adapters' and 'utilities' attributes, respectively. Services are accessible, but deprecated, and will be removed in Zope 3.3.
Deprecated all presentation-related APIs, including all view-related API functions. Use the adapter API functions instead. See http://dev.zope.org/Zope3/ImplementViewsAsAdapters`
Deprecated contextdependent package:  site managers are now looked up
via a thread global, set during URL traversal.  The context argument
is now always optional, and should no longer be passed.
Corresponds to the verison of the zope.component package shipped as part of
the Zope X3.0.0 release.