mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 15:58:57 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			144 lines
		
	
	
	
		
			4.3 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			144 lines
		
	
	
	
		
			4.3 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. highlightlang:: c
 | |
| 
 | |
| .. _contextvarsobjects:
 | |
| 
 | |
| Context Variables Objects
 | |
| -------------------------
 | |
| 
 | |
| .. _contextvarsobjects_pointertype_change:
 | |
| .. 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.
 | |
| 
 | |
| 
 | |
| .. versionadded:: 3.7
 | |
| 
 | |
| 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
 | |
|    *NULL*.  This function always succeeds.
 | |
| 
 | |
| .. c:function:: int PyContextVar_CheckExact(PyObject *o)
 | |
| 
 | |
|    Return true if *o* is of type :c:data:`PyContextVar_Type`. *o* must not be
 | |
|    *NULL*.  This function always succeeds.
 | |
| 
 | |
| .. c:function:: int PyContextToken_CheckExact(PyObject *o)
 | |
| 
 | |
|    Return true if *o* is of type :c:data:`PyContextToken_Type`.
 | |
|    *o* must not be *NULL*.  This function always succeeds.
 | |
| 
 | |
| 
 | |
| Context object management functions:
 | |
| 
 | |
| .. c:function:: PyObject *PyContext_New(void)
 | |
| 
 | |
|    Create a new empty context object.  Returns ``NULL`` if an error
 | |
|    has occurred.
 | |
| 
 | |
| .. c:function:: PyObject *PyContext_Copy(PyObject *ctx)
 | |
| 
 | |
|    Create a shallow copy of the passed *ctx* context object.
 | |
|    Returns ``NULL`` if an error has occurred.
 | |
| 
 | |
| .. c:function:: PyObject *PyContext_CopyCurrent(void)
 | |
| 
 | |
|    Create a shallow copy of the current thread context.
 | |
|    Returns ``NULL`` if an error has occurred.
 | |
| 
 | |
| .. c:function:: int PyContext_Enter(PyObject *ctx)
 | |
| 
 | |
|    Set *ctx* as the current context for the current thread.
 | |
|    Returns ``0`` on success, and ``-1`` on error.
 | |
| 
 | |
| .. c:function:: int PyContext_Exit(PyObject *ctx)
 | |
| 
 | |
|    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.
 | |
| 
 | |
| .. c:function:: int PyContext_ClearFreeList()
 | |
| 
 | |
|    Clear the context variable free list. Return the total number of
 | |
|    freed items.  This function always succeeds.
 | |
| 
 | |
| 
 | |
| Context variable functions:
 | |
| 
 | |
| .. c:function:: PyObject *PyContextVar_New(const char *name, PyObject *def)
 | |
| 
 | |
|    Create a new ``ContextVar`` object.  The *name* parameter is used
 | |
|    for introspection and debug purposes.  The *def* parameter may optionally
 | |
|    specify the default value for the context variable.  If an error has
 | |
|    occurred, this function returns ``NULL``.
 | |
| 
 | |
| .. c:function:: int PyContextVar_Get(PyObject *var, PyObject *default_value, PyObject **value)
 | |
| 
 | |
|    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``
 | |
| 
 | |
|    If the value was found, the function will create a new reference to it.
 | |
| 
 | |
| .. c:function:: PyObject *PyContextVar_Set(PyObject *var, PyObject *value)
 | |
| 
 | |
|    Set the value of *var* to *value* in the current context.  Returns a
 | |
|    pointer to a :c:type:`PyObject` object, or ``NULL`` if an error
 | |
|    has occurred.
 | |
| 
 | |
| .. c:function:: int PyContextVar_Reset(PyObject *var, PyObject *token)
 | |
| 
 | |
|    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.
 | 
