This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

classification
Title: Allow extensions to set a callback to be invoked when a type is modified
Type: enhancement Stage:
Components: C API, Interpreter Core Versions: Python 3.11
process
Status: open Resolution:
Dependencies: Superseder:
Assigned To: Nosy List: carljm, dino.viehland, itamaro, mpage
Priority: normal Keywords:

Created on 2022-03-01 22:16 by mpage, last changed 2022-04-11 14:59 by admin.

Messages (1)
msg414305 - (view) Author: Matt Page (mpage) * Date: 2022-03-01 22:16
CPython extensions providing optimized execution of Python bytecode (e.g. the Cinder JIT), or even CPython itself (e.g. the faster-cpython project) may wish to cache access to lookups in the class hierarchy (e.g. when resolving the target of a method call). Extensions that perform these optimizations need to know when to invalidate the cached values. CPython already has a mechanism to invalidate its internal state (e.g. the global method cache) when a type is modified: _PyType_Modified. We propose adding an API to allow extensions to set a callback that will be invoked by _PyType_Modified whenever a type, or any ancestor of the type in the class hierarchy, changes.

Proposed API:

```
// A callback to be invoked with the modified type and optionally the name of
// the attribute that was modified.
typedef void(*PyType_ModifiedCallback)(PyTypeObject* type, PyObject* attr);

// Set or get the callback. The callback may be cleared by supplying a NULL callback.
void PyType_SetModifiedCallback(PyType_ModifiedCallback callback);
PyType_ModifiedCallback PyType_GetModifiedCallback();
```
History
Date User Action Args
2022-04-11 14:59:56adminsetgithub: 91051
2022-03-01 22:21:58mpagesetversions: + Python 3.11
2022-03-01 22:17:56mpagesettitle: Type-Modified Callbacks -> Allow extensions to set a callback to be invoked when a type is modified
2022-03-01 22:16:51mpagecreate