Description
Feature or enhancement
Proposal:
The datetime module has its own C-API which is enabled with PyDateTime_IMPORT
. From the docs:
Before using any of these functions, the header file datetime.h must be included in your source
(note that this is not included by Python.h), and the macro PyDateTime_IMPORT must be invoked,
usually as part of the module initialisation function. The macro puts a pointer to a C structure into
a static variable, PyDateTimeAPI, that is used by the following macros.
My main concern is that the PyDateTimeAPI
struct is a process-global value, but it exposes object pointers (which should always be per-interpreter). We have worked around this in 3.13+, but it would be better if we could make the objects per-interpreter.
FTR, here are the objects exposed directly by PyDateTimeAPI
:
- (static type)
PyDateTime_DateType
- (static type)
PyDateTime_DateTimeType
- (static type)
PyDateTime_TimeType
- (static type)
PyDateTime_DeltaType
- (static type)
PyDateTime_TZInfoType
- (singleton)
utc_timezone
(an instance ofPyDateTime_TimeZoneType
)
exposed indirectly:
- (static type)
PyDateTime_TimeZoneType
In order to make these objects per-interpreter, it would require changes to the datetime C-API. 1 I expect we would leave PyDateTime_IMPORT
alone. Instead, we'd need to update the macros in datetime.h to get the objects from the module associated with the current interpreter. 2
Has this already been discussed elsewhere?
This is a minor feature, which does not need previous discussion elsewhere
Links to previous discussion of this feature:
No response
Footnotes
Metadata
Metadata
Assignees
Projects
Status