| 
									
										
										
										
											2019-05-17 11:55:34 +02:00
										 |  |  | .. highlight:: c
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. _contextvarsobjects:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Context Variables Objects
 | 
					
						
							|  |  |  | -------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 15:33:56 -04:00
										 |  |  | .. _contextvarsobjects_pointertype_change:
 | 
					
						
							| 
									
										
										
										
											2024-03-07 10:05:03 +02:00
										 |  |  | .. versionadded:: 3.7
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 15:33:56 -04:00
										 |  |  | .. versionchanged:: 3.7.1
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. note::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       In Python 3.7.1 the signatures of all context variables
 | 
					
						
							|  |  |  |       C APIs were **changed** to use :c:type:`PyObject` pointers instead
 | 
					
						
							|  |  |  |       of :c:type:`PyContext`, :c:type:`PyContextVar`, and
 | 
					
						
							|  |  |  |       :c:type:`PyContextToken`, e.g.::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          // in 3.7.0:
 | 
					
						
							|  |  |  |          PyContext *PyContext_New(void);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |          // in 3.7.1+:
 | 
					
						
							|  |  |  |          PyObject *PyContext_New(void);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       See :issue:`34762` for more details.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | This section details the public C API for the :mod:`contextvars` module.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. c:type:: PyContext
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The C structure used to represent a :class:`contextvars.Context`
 | 
					
						
							|  |  |  |    object.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. c:type:: PyContextVar
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The C structure used to represent a :class:`contextvars.ContextVar`
 | 
					
						
							|  |  |  |    object.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. c:type:: PyContextToken
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The C structure used to represent a :class:`contextvars.Token` object.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. c:var:: PyTypeObject PyContext_Type
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The type object representing the *context* type.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. c:var:: PyTypeObject PyContextVar_Type
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The type object representing the *context variable* type.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. c:var:: PyTypeObject PyContextToken_Type
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The type object representing the *context variable token* type.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Type-check macros:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. c:function:: int PyContext_CheckExact(PyObject *o)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return true if *o* is of type :c:data:`PyContext_Type`. *o* must not be
 | 
					
						
							| 
									
										
										
										
											2019-10-30 12:03:20 +02:00
										 |  |  |    ``NULL``.  This function always succeeds.
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. c:function:: int PyContextVar_CheckExact(PyObject *o)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return true if *o* is of type :c:data:`PyContextVar_Type`. *o* must not be
 | 
					
						
							| 
									
										
										
										
											2019-10-30 12:03:20 +02:00
										 |  |  |    ``NULL``.  This function always succeeds.
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. c:function:: int PyContextToken_CheckExact(PyObject *o)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return true if *o* is of type :c:data:`PyContextToken_Type`.
 | 
					
						
							| 
									
										
										
										
											2019-10-30 12:03:20 +02:00
										 |  |  |    *o* must not be ``NULL``.  This function always succeeds.
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Context object management functions:
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 15:33:56 -04:00
										 |  |  | .. c:function:: PyObject *PyContext_New(void)
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Create a new empty context object.  Returns ``NULL`` if an error
 | 
					
						
							|  |  |  |    has occurred.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 15:33:56 -04:00
										 |  |  | .. c:function:: PyObject *PyContext_Copy(PyObject *ctx)
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Create a shallow copy of the passed *ctx* context object.
 | 
					
						
							|  |  |  |    Returns ``NULL`` if an error has occurred.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 15:33:56 -04:00
										 |  |  | .. c:function:: PyObject *PyContext_CopyCurrent(void)
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Create a shallow copy of the current thread context.
 | 
					
						
							|  |  |  |    Returns ``NULL`` if an error has occurred.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 15:33:56 -04:00
										 |  |  | .. c:function:: int PyContext_Enter(PyObject *ctx)
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Set *ctx* as the current context for the current thread.
 | 
					
						
							|  |  |  |    Returns ``0`` on success, and ``-1`` on error.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 15:33:56 -04:00
										 |  |  | .. c:function:: int PyContext_Exit(PyObject *ctx)
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Deactivate the *ctx* context and restore the previous context as the
 | 
					
						
							|  |  |  |    current context for the current thread.  Returns ``0`` on success,
 | 
					
						
							|  |  |  |    and ``-1`` on error.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-23 20:40:17 -07:00
										 |  |  | .. c:function:: int PyContext_AddWatcher(PyContext_WatchCallback callback)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Register *callback* as a context object watcher for the current interpreter.
 | 
					
						
							|  |  |  |    Return an ID which may be passed to :c:func:`PyContext_ClearWatcher`.
 | 
					
						
							|  |  |  |    In case of error (e.g. no more watcher IDs available),
 | 
					
						
							|  |  |  |    return ``-1`` and set an exception.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.14
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. c:function:: int PyContext_ClearWatcher(int watcher_id)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Clear watcher identified by *watcher_id* previously returned from
 | 
					
						
							|  |  |  |    :c:func:`PyContext_AddWatcher` for the current interpreter.
 | 
					
						
							|  |  |  |    Return ``0`` on success, or ``-1`` and set an exception on error
 | 
					
						
							|  |  |  |    (e.g. if the given *watcher_id* was never registered.)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.14
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. c:type:: PyContextEvent
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Enumeration of possible context object watcher events:
 | 
					
						
							| 
									
										
										
										
											2024-10-09 19:44:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-16 14:53:21 +03:00
										 |  |  |    - ``Py_CONTEXT_SWITCHED``: The :term:`current context` has switched to a
 | 
					
						
							|  |  |  |      different context.  The object passed to the watch callback is the
 | 
					
						
							|  |  |  |      now-current :class:`contextvars.Context` object, or None if no context is
 | 
					
						
							|  |  |  |      current.
 | 
					
						
							| 
									
										
										
										
											2024-09-23 20:40:17 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.14
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-12 16:57:27 -04:00
										 |  |  | .. c:type:: int (*PyContext_WatchCallback)(PyContextEvent event, PyObject *obj)
 | 
					
						
							| 
									
										
										
										
											2024-09-23 20:40:17 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-09 19:44:03 -04:00
										 |  |  |    Context object watcher callback function.  The object passed to the callback
 | 
					
						
							|  |  |  |    is event-specific; see :c:type:`PyContextEvent` for details.
 | 
					
						
							| 
									
										
										
										
											2024-09-23 20:40:17 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |    If the callback returns with an exception set, it must return ``-1``; this
 | 
					
						
							|  |  |  |    exception will be printed as an unraisable exception using
 | 
					
						
							|  |  |  |    :c:func:`PyErr_FormatUnraisable`. Otherwise it should return ``0``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    There may already be a pending exception set on entry to the callback. In
 | 
					
						
							|  |  |  |    this case, the callback should return ``0`` with the same exception still
 | 
					
						
							|  |  |  |    set. This means the callback may not call any other API that can set an
 | 
					
						
							|  |  |  |    exception unless it saves and clears the exception state first, and restores
 | 
					
						
							|  |  |  |    it before returning.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.14
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | Context variable functions:
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 15:33:56 -04:00
										 |  |  | .. c:function:: PyObject *PyContextVar_New(const char *name, PyObject *def)
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Create a new ``ContextVar`` object.  The *name* parameter is used
 | 
					
						
							| 
									
										
										
										
											2021-04-28 16:03:19 +02:00
										 |  |  |    for introspection and debug purposes.  The *def* parameter specifies
 | 
					
						
							|  |  |  |    a default value for the context variable, or ``NULL`` for no default.
 | 
					
						
							|  |  |  |    If an error has occurred, this function returns ``NULL``.
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 15:33:56 -04:00
										 |  |  | .. c:function:: int PyContextVar_Get(PyObject *var, PyObject *default_value, PyObject **value)
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Get the value of a context variable.  Returns ``-1`` if an error has
 | 
					
						
							|  |  |  |    occurred during lookup, and ``0`` if no error occurred, whether or not
 | 
					
						
							|  |  |  |    a value was found.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    If the context variable was found, *value* will be a pointer to it.
 | 
					
						
							|  |  |  |    If the context variable was *not* found, *value* will point to:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    - *default_value*, if not ``NULL``;
 | 
					
						
							|  |  |  |    - the default value of *var*, if not ``NULL``;
 | 
					
						
							|  |  |  |    - ``NULL``
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-28 16:03:19 +02:00
										 |  |  |    Except for ``NULL``, the function returns a new reference.
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 15:33:56 -04:00
										 |  |  | .. c:function:: PyObject *PyContextVar_Set(PyObject *var, PyObject *value)
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-28 16:03:19 +02:00
										 |  |  |    Set the value of *var* to *value* in the current context.  Returns
 | 
					
						
							|  |  |  |    a new token object for this change, or ``NULL`` if an error has occurred.
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-21 15:33:56 -04:00
										 |  |  | .. c:function:: int PyContextVar_Reset(PyObject *var, PyObject *token)
 | 
					
						
							| 
									
										
										
										
											2018-05-22 13:31:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Reset the state of the *var* context variable to that it was in before
 | 
					
						
							|  |  |  |    :c:func:`PyContextVar_Set` that returned the *token* was called.
 | 
					
						
							|  |  |  |    This function returns ``0`` on success and ``-1`` on error.
 |