Объекты для подсказки типов

Предусмотрены различные встроенные типы для подсказки типов. В настоящее время существует два типа - GenericAlias и Union. Только GenericAlias доступен в C.

PyObject *Py_GenericAlias(PyObject *origin, PyObject *args)
Часть Стабильный ABI с версии 3.9.

Создайте объект GenericAlias. Эквивалентно вызову класса Python types.GenericAlias. Аргументы origin и args задают GenericAliasатрибуты __origin__ и __args__ соответственно. origin должен быть PyTypeObject*, а args может быть PyTupleObject* или любым PyObject*. Если переданный args не является кортежем, автоматически строится 1-кортеж и __args__ устанавливается в (args,). Для аргументов выполняется минимальная проверка, поэтому функция будет успешной, даже если origin не является типом. Атрибут GenericAlias' __parameters__ лениво конструируется из __args__. При неудаче возникает исключение и возвращается NULL.

Вот пример того, как сделать тип расширения общим:

...
static PyMethodDef my_obj_methods[] = {
    // Other methods.
    ...
    {"__class_getitem__", Py_GenericAlias, METH_O|METH_CLASS, "See PEP 585"}
    ...
}

См.также

Метод модели данных __class_getitem__().

Added in version 3.9.

PyTypeObject Py_GenericAliasType
Часть Стабильный ABI с версии 3.9.

C-тип объекта, возвращаемого Py_GenericAlias(). Эквивалентно types.GenericAlias в Python.

Added in version 3.9.