2008-01-20 09:30:57 +00:00
|
|
|
.. highlightlang:: c
|
|
|
|
|
|
|
|
.. _setobjects:
|
|
|
|
|
|
|
|
Set Objects
|
|
|
|
-----------
|
|
|
|
|
|
|
|
.. sectionauthor:: Raymond D. Hettinger <python@rcn.com>
|
|
|
|
|
|
|
|
|
|
|
|
.. index::
|
|
|
|
object: set
|
|
|
|
object: frozenset
|
|
|
|
|
|
|
|
This section details the public API for :class:`set` and :class:`frozenset`
|
|
|
|
objects. Any functionality not listed below is best accessed using the either
|
|
|
|
the abstract object protocol (including :cfunc:`PyObject_CallMethod`,
|
|
|
|
:cfunc:`PyObject_RichCompareBool`, :cfunc:`PyObject_Hash`,
|
|
|
|
:cfunc:`PyObject_Repr`, :cfunc:`PyObject_IsTrue`, :cfunc:`PyObject_Print`, and
|
|
|
|
:cfunc:`PyObject_GetIter`) or the abstract number protocol (including
|
|
|
|
:cfunc:`PyNumber_And`, :cfunc:`PyNumber_Subtract`, :cfunc:`PyNumber_Or`,
|
|
|
|
:cfunc:`PyNumber_Xor`, :cfunc:`PyNumber_InPlaceAnd`,
|
|
|
|
:cfunc:`PyNumber_InPlaceSubtract`, :cfunc:`PyNumber_InPlaceOr`, and
|
|
|
|
:cfunc:`PyNumber_InPlaceXor`).
|
|
|
|
|
|
|
|
|
|
|
|
.. ctype:: PySetObject
|
|
|
|
|
|
|
|
This subtype of :ctype:`PyObject` is used to hold the internal data for both
|
|
|
|
:class:`set` and :class:`frozenset` objects. It is like a :ctype:`PyDictObject`
|
|
|
|
in that it is a fixed size for small sets (much like tuple storage) and will
|
|
|
|
point to a separate, variable sized block of memory for medium and large sized
|
|
|
|
sets (much like list storage). None of the fields of this structure should be
|
|
|
|
considered public and are subject to change. All access should be done through
|
|
|
|
the documented API rather than by manipulating the values in the structure.
|
|
|
|
|
|
|
|
|
|
|
|
.. cvar:: PyTypeObject PySet_Type
|
|
|
|
|
|
|
|
This is an instance of :ctype:`PyTypeObject` representing the Python
|
|
|
|
:class:`set` type.
|
|
|
|
|
|
|
|
|
|
|
|
.. cvar:: PyTypeObject PyFrozenSet_Type
|
|
|
|
|
|
|
|
This is an instance of :ctype:`PyTypeObject` representing the Python
|
|
|
|
:class:`frozenset` type.
|
|
|
|
|
|
|
|
The following type check macros work on pointers to any Python object. Likewise,
|
|
|
|
the constructor functions work with any iterable Python object.
|
|
|
|
|
|
|
|
|
Merged revisions 60383-60407 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r60388 | thomas.heller | 2008-01-28 09:44:13 +0100 (Mon, 28 Jan 2008) | 1 line
Revert rev. 59925, it breaks comtypes (I need to further examine this).
........
r60397 | raymond.hettinger | 2008-01-28 21:34:33 +0100 (Mon, 28 Jan 2008) | 5 lines
Make PySet_Add() work with frozensets.
Works like PyTuple_SetItem() to build-up values in a brand new frozenset.
Also, PyFrozenSet_New() is now guaranteed to produce a distinct new frozenset.
........
r60398 | raymond.hettinger | 2008-01-28 22:34:30 +0100 (Mon, 28 Jan 2008) | 1 line
Let marshal built-up sets and frozensets one element at a time (without creating an intermediate tuple).
........
r60399 | raymond.hettinger | 2008-01-28 22:47:42 +0100 (Mon, 28 Jan 2008) | 1 line
Factor-out common code with a new macro
........
r60400 | raymond.hettinger | 2008-01-28 22:48:07 +0100 (Mon, 28 Jan 2008) | 1 line
Factor-out common code with a new macro
........
r60401 | raymond.hettinger | 2008-01-28 22:51:25 +0100 (Mon, 28 Jan 2008) | 1 line
Removed unnecessary conditional (spotted by Neal Norwitz).
........
r60403 | gregory.p.smith | 2008-01-29 00:21:00 +0100 (Tue, 29 Jan 2008) | 4 lines
Disable use of BerkeleyDB 4.6.x to see what the odd platform buildbots
think. In particular, neal norwitz has traced an Ubuntu sparc64 crash
to the Lib/test/bsddb/test_basics.py test when opening a db with DB_THREAD.
........
r60405 | brett.cannon | 2008-01-29 05:13:07 +0100 (Tue, 29 Jan 2008) | 2 lines
Fix the reindent rule to use $(BUILDPYTHON).
........
r60406 | brett.cannon | 2008-01-29 05:18:04 +0100 (Tue, 29 Jan 2008) | 3 lines
Update Vim syntax highlighting to specify what revision was used to generate
the file.
........
r60407 | brett.cannon | 2008-01-29 05:20:56 +0100 (Tue, 29 Jan 2008) | 2 lines
Ignore .pyc and .pyo files.
........
2008-01-29 12:18:50 +00:00
|
|
|
.. cfunction:: int PySet_Check(PyObject *p)
|
|
|
|
|
|
|
|
Return true if *p* is a :class:`set` object or an instance of a subtype.
|
|
|
|
|
|
|
|
.. versionadded:: 2.6
|
|
|
|
|
2008-01-20 09:30:57 +00:00
|
|
|
.. cfunction:: int PyAnySet_Check(PyObject *p)
|
|
|
|
|
|
|
|
Return true if *p* is a :class:`set` object, a :class:`frozenset` object, or an
|
|
|
|
instance of a subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: int PyAnySet_CheckExact(PyObject *p)
|
|
|
|
|
|
|
|
Return true if *p* is a :class:`set` object or a :class:`frozenset` object but
|
|
|
|
not an instance of a subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: int PyFrozenSet_CheckExact(PyObject *p)
|
|
|
|
|
|
|
|
Return true if *p* is a :class:`frozenset` object but not an instance of a
|
|
|
|
subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: PyObject* PySet_New(PyObject *iterable)
|
|
|
|
|
|
|
|
Return a new :class:`set` containing objects returned by the *iterable*. The
|
|
|
|
*iterable* may be *NULL* to create a new empty set. Return the new set on
|
|
|
|
success or *NULL* on failure. Raise :exc:`TypeError` if *iterable* is not
|
|
|
|
actually iterable. The constructor is also useful for copying a set
|
|
|
|
(``c=set(s)``).
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: PyObject* PyFrozenSet_New(PyObject *iterable)
|
|
|
|
|
|
|
|
Return a new :class:`frozenset` containing objects returned by the *iterable*.
|
|
|
|
The *iterable* may be *NULL* to create a new empty frozenset. Return the new
|
|
|
|
set on success or *NULL* on failure. Raise :exc:`TypeError` if *iterable* is
|
|
|
|
not actually iterable.
|
|
|
|
|
Merged revisions 60383-60407 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r60388 | thomas.heller | 2008-01-28 09:44:13 +0100 (Mon, 28 Jan 2008) | 1 line
Revert rev. 59925, it breaks comtypes (I need to further examine this).
........
r60397 | raymond.hettinger | 2008-01-28 21:34:33 +0100 (Mon, 28 Jan 2008) | 5 lines
Make PySet_Add() work with frozensets.
Works like PyTuple_SetItem() to build-up values in a brand new frozenset.
Also, PyFrozenSet_New() is now guaranteed to produce a distinct new frozenset.
........
r60398 | raymond.hettinger | 2008-01-28 22:34:30 +0100 (Mon, 28 Jan 2008) | 1 line
Let marshal built-up sets and frozensets one element at a time (without creating an intermediate tuple).
........
r60399 | raymond.hettinger | 2008-01-28 22:47:42 +0100 (Mon, 28 Jan 2008) | 1 line
Factor-out common code with a new macro
........
r60400 | raymond.hettinger | 2008-01-28 22:48:07 +0100 (Mon, 28 Jan 2008) | 1 line
Factor-out common code with a new macro
........
r60401 | raymond.hettinger | 2008-01-28 22:51:25 +0100 (Mon, 28 Jan 2008) | 1 line
Removed unnecessary conditional (spotted by Neal Norwitz).
........
r60403 | gregory.p.smith | 2008-01-29 00:21:00 +0100 (Tue, 29 Jan 2008) | 4 lines
Disable use of BerkeleyDB 4.6.x to see what the odd platform buildbots
think. In particular, neal norwitz has traced an Ubuntu sparc64 crash
to the Lib/test/bsddb/test_basics.py test when opening a db with DB_THREAD.
........
r60405 | brett.cannon | 2008-01-29 05:13:07 +0100 (Tue, 29 Jan 2008) | 2 lines
Fix the reindent rule to use $(BUILDPYTHON).
........
r60406 | brett.cannon | 2008-01-29 05:18:04 +0100 (Tue, 29 Jan 2008) | 3 lines
Update Vim syntax highlighting to specify what revision was used to generate
the file.
........
r60407 | brett.cannon | 2008-01-29 05:20:56 +0100 (Tue, 29 Jan 2008) | 2 lines
Ignore .pyc and .pyo files.
........
2008-01-29 12:18:50 +00:00
|
|
|
.. versionchanged:: 2.6
|
|
|
|
Now guaranteed to return a brand-new :class:`frozenset`. Formerly,
|
|
|
|
frozensets of zero-length were a singleton. This got in the way of
|
|
|
|
building-up new frozensets with :meth:`PySet_Add`.
|
|
|
|
|
2008-01-20 09:30:57 +00:00
|
|
|
The following functions and macros are available for instances of :class:`set`
|
|
|
|
or :class:`frozenset` or instances of their subtypes.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: Py_ssize_t PySet_Size(PyObject *anyset)
|
|
|
|
|
|
|
|
.. index:: builtin: len
|
|
|
|
|
|
|
|
Return the length of a :class:`set` or :class:`frozenset` object. Equivalent to
|
|
|
|
``len(anyset)``. Raises a :exc:`PyExc_SystemError` if *anyset* is not a
|
|
|
|
:class:`set`, :class:`frozenset`, or an instance of a subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: Py_ssize_t PySet_GET_SIZE(PyObject *anyset)
|
|
|
|
|
|
|
|
Macro form of :cfunc:`PySet_Size` without error checking.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: int PySet_Contains(PyObject *anyset, PyObject *key)
|
|
|
|
|
|
|
|
Return 1 if found, 0 if not found, and -1 if an error is encountered. Unlike
|
|
|
|
the Python :meth:`__contains__` method, this function does not automatically
|
|
|
|
convert unhashable sets into temporary frozensets. Raise a :exc:`TypeError` if
|
|
|
|
the *key* is unhashable. Raise :exc:`PyExc_SystemError` if *anyset* is not a
|
|
|
|
:class:`set`, :class:`frozenset`, or an instance of a subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: int PySet_Add(PyObject *set, PyObject *key)
|
|
|
|
|
|
|
|
Add *key* to a :class:`set` instance. Does not apply to :class:`frozenset`
|
|
|
|
instances. Return 0 on success or -1 on failure. Raise a :exc:`TypeError` if
|
|
|
|
the *key* is unhashable. Raise a :exc:`MemoryError` if there is no room to grow.
|
|
|
|
Raise a :exc:`SystemError` if *set* is an not an instance of :class:`set` or its
|
|
|
|
subtype.
|
|
|
|
|
Merged revisions 60383-60407 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r60388 | thomas.heller | 2008-01-28 09:44:13 +0100 (Mon, 28 Jan 2008) | 1 line
Revert rev. 59925, it breaks comtypes (I need to further examine this).
........
r60397 | raymond.hettinger | 2008-01-28 21:34:33 +0100 (Mon, 28 Jan 2008) | 5 lines
Make PySet_Add() work with frozensets.
Works like PyTuple_SetItem() to build-up values in a brand new frozenset.
Also, PyFrozenSet_New() is now guaranteed to produce a distinct new frozenset.
........
r60398 | raymond.hettinger | 2008-01-28 22:34:30 +0100 (Mon, 28 Jan 2008) | 1 line
Let marshal built-up sets and frozensets one element at a time (without creating an intermediate tuple).
........
r60399 | raymond.hettinger | 2008-01-28 22:47:42 +0100 (Mon, 28 Jan 2008) | 1 line
Factor-out common code with a new macro
........
r60400 | raymond.hettinger | 2008-01-28 22:48:07 +0100 (Mon, 28 Jan 2008) | 1 line
Factor-out common code with a new macro
........
r60401 | raymond.hettinger | 2008-01-28 22:51:25 +0100 (Mon, 28 Jan 2008) | 1 line
Removed unnecessary conditional (spotted by Neal Norwitz).
........
r60403 | gregory.p.smith | 2008-01-29 00:21:00 +0100 (Tue, 29 Jan 2008) | 4 lines
Disable use of BerkeleyDB 4.6.x to see what the odd platform buildbots
think. In particular, neal norwitz has traced an Ubuntu sparc64 crash
to the Lib/test/bsddb/test_basics.py test when opening a db with DB_THREAD.
........
r60405 | brett.cannon | 2008-01-29 05:13:07 +0100 (Tue, 29 Jan 2008) | 2 lines
Fix the reindent rule to use $(BUILDPYTHON).
........
r60406 | brett.cannon | 2008-01-29 05:18:04 +0100 (Tue, 29 Jan 2008) | 3 lines
Update Vim syntax highlighting to specify what revision was used to generate
the file.
........
r60407 | brett.cannon | 2008-01-29 05:20:56 +0100 (Tue, 29 Jan 2008) | 2 lines
Ignore .pyc and .pyo files.
........
2008-01-29 12:18:50 +00:00
|
|
|
.. versionchanged:: 2.6
|
|
|
|
Now works with instances of :class:`frozenset` or its subtypes.
|
|
|
|
Like :cfunc:`PyTuple_SetItem` in that it can be used to fill-in the
|
|
|
|
values of brand new frozensets before they are exposed to other code.
|
|
|
|
|
|
|
|
The following functions are available for instances of :class:`set` or its
|
|
|
|
subtypes but not for instances of :class:`frozenset` or its subtypes.
|
|
|
|
|
2008-01-20 09:30:57 +00:00
|
|
|
|
|
|
|
.. cfunction:: int PySet_Discard(PyObject *set, PyObject *key)
|
|
|
|
|
|
|
|
Return 1 if found and removed, 0 if not found (no action taken), and -1 if an
|
|
|
|
error is encountered. Does not raise :exc:`KeyError` for missing keys. Raise a
|
|
|
|
:exc:`TypeError` if the *key* is unhashable. Unlike the Python :meth:`discard`
|
|
|
|
method, this function does not automatically convert unhashable sets into
|
|
|
|
temporary frozensets. Raise :exc:`PyExc_SystemError` if *set* is an not an
|
|
|
|
instance of :class:`set` or its subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: PyObject* PySet_Pop(PyObject *set)
|
|
|
|
|
|
|
|
Return a new reference to an arbitrary object in the *set*, and removes the
|
|
|
|
object from the *set*. Return *NULL* on failure. Raise :exc:`KeyError` if the
|
|
|
|
set is empty. Raise a :exc:`SystemError` if *set* is an not an instance of
|
|
|
|
:class:`set` or its subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: int PySet_Clear(PyObject *set)
|
|
|
|
|
|
|
|
Empty an existing set of all elements.
|