What is zope.intid?¶
This package provides an API to create integer ids for any object. Later objects can be looked up by their id as well. This functionality is commonly used in situations where dealing with objects is undesirably, such as in search indices or any code that needs an easy hash of an object.
Reference¶
Interfaces¶
Interfaces for the unique id utility.
-
interface
zope.intid.interfaces.
IIntIdsManage
[source]¶ Some methods used by the view.
-
__len__
()¶ Return the number of objects indexed.
-
items
()¶ Return a list of (id, object) pairs.
-
-
interface
zope.intid.interfaces.
IIntIds
[source]¶ Extends:
zope.intid.interfaces.IIntIdsSet
,zope.intid.interfaces.IIntIdsQuery
,zope.intid.interfaces.IIntIdsManage
A utility that assigns unique ids to objects.
Allows to query object by id and id by object.
-
interface
zope.intid.interfaces.
IIntIdEvent
[source]¶ Generic base interface for IntId-related events
-
object
¶ The object related to this event
-
original_event
¶ The ObjectEvent related to this event
-
-
interface
zope.intid.interfaces.
IIntIdRemovedEvent
[source]¶ Extends:
zope.intid.interfaces.IIntIdEvent
A unique id will be removed
The event is published before the unique id is removed from the utility so that the indexing objects can unindex the object.
-
class
zope.intid.interfaces.
IntIdRemovedEvent
(object, event)[source]¶ Bases:
object
The event which is published before the unique id is removed from the utility so that the catalogs can unindex the object.
-
interface
zope.intid.interfaces.
IIntIdAddedEvent
[source]¶ Extends:
zope.intid.interfaces.IIntIdEvent
A unique id has been added
The event gets sent when an object is registered in a unique id utility.
-
idmap
¶ The dictionary that holds an (utility -> id) mapping of created ids
-
Implementation¶
Unique id utility.
This utility assigns unique integer ids to objects and allows lookups by object and by id.
This functionality can be used in cataloging.
-
class
zope.intid.
IntIds
(family=None)[source]¶ Bases:
persistent.Persistent
This utility provides a two way mapping between objects and integer ids.
IKeyReferences to objects are stored in the indexes.
-
zope.intid.
removeIntIdSubscriber
(ob, event)[source]¶ A subscriber to ObjectRemovedEvent
Removes the unique ids registered for the object in all the unique id utilities.
Changes¶
4.2.0 (unreleased)¶
- Add support for Python 3.5.
- Drop support for Python 2.6.
4.1.0 (2014-12-27)¶
- Add support for PyPy (PyPy3 blocked on PyPy3-compatible
zodbpickle
). - Add support for Python 3.4.
4.0.0 (2014-12-20)¶
- Add support for testing on Travis.
4.0.0a1 (2013-02-22)¶
- Add support for Python 3.3.
- Replace deprecated
zope.interface.implements
usage with equivalentzope.interface.implementer
decorator. - Drop support for Python 2.4 and 2.5.
- Bug fix: ensure that the IntId utility never generates ids greater than the maxint of the BTree family being used.
3.7.2 (2009-12-27)¶
- Use the zope.component API in favor of ztapi.
- Remove
zope.app.testing
dependency.
3.7.1 (2009-05-18)¶
- Remove dependencies on
zope.container
. Instead importObject*Event
classes fromzope.lifecycleevent
and importIContained
fromzope.location
. In order to be able to do this, depend onzope.lifecycleevent
>=3.5.2 andzope.location
>=3.5.4. - Remove a dependency on
zope.container.contained.Contained
(this is a dumb base class that defines __parent__ and __name__ as None and declares that the class implements IContained).
3.7.0 (2009-02-01)¶
- Split out this package from
zope.app.intid
. The latter one now only contains browser views and compatibility imports while whole IntId functionality is moved here.
Project URLs¶
- http://pypi.python.org/pypi/zope.intid (PyPI entry and downloads)