python3-sys 0.7.1

FFI Declarations for Python 3
Documentation
use core::ptr;
use libc::{c_char, c_int, c_uint, c_ulong, c_void};

use crate::pyport::{Py_hash_t, Py_ssize_t};

#[repr(C)]
#[derive(Copy, Clone)]
pub struct PyObject {
    #[cfg(py_sys_config = "Py_TRACE_REFS")]
    _ob_next: *mut PyObject,
    #[cfg(py_sys_config = "Py_TRACE_REFS")]
    _ob_prev: *mut PyObject,
    pub ob_refcnt: Py_ssize_t,
    pub ob_type: *mut PyTypeObject,
}

#[cfg(py_sys_config = "Py_TRACE_REFS")]
pub const PyObject_HEAD_INIT: PyObject = PyObject {
    _ob_next: 0 as *mut PyObject,
    _ob_prev: 0 as *mut PyObject,
    ob_refcnt: 1,
    ob_type: 0 as *mut PyTypeObject,
};

#[cfg(not(py_sys_config = "Py_TRACE_REFS"))]
pub const PyObject_HEAD_INIT: PyObject = PyObject {
    ob_refcnt: 1,
    ob_type: 0 as *mut PyTypeObject,
};

#[repr(C)]
#[derive(Copy, Clone)]
pub struct PyVarObject {
    pub ob_base: PyObject,
    pub ob_size: Py_ssize_t,
}

#[inline(always)]
pub unsafe fn Py_REFCNT(ob: *mut PyObject) -> Py_ssize_t {
    (*ob).ob_refcnt
}

#[inline(always)]
pub unsafe fn Py_TYPE(ob: *mut PyObject) -> *mut PyTypeObject {
    (*ob).ob_type
}

#[inline(always)]
pub unsafe fn Py_SIZE(ob: *mut PyObject) -> Py_ssize_t {
    (*(ob as *mut PyVarObject)).ob_size
}

pub type unaryfunc = unsafe extern "C" fn(arg1: *mut PyObject) -> *mut PyObject;
pub type binaryfunc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: *mut PyObject) -> *mut PyObject;
pub type ternaryfunc = unsafe extern "C" fn(
    arg1: *mut PyObject,
    arg2: *mut PyObject,
    arg3: *mut PyObject,
) -> *mut PyObject;
pub type inquiry = unsafe extern "C" fn(arg1: *mut PyObject) -> c_int;
pub type lenfunc = unsafe extern "C" fn(arg1: *mut PyObject) -> Py_ssize_t;
pub type ssizeargfunc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: Py_ssize_t) -> *mut PyObject;
pub type ssizessizeargfunc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: Py_ssize_t, arg3: Py_ssize_t) -> *mut PyObject;
pub type ssizeobjargproc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: Py_ssize_t, arg3: *mut PyObject) -> c_int;
pub type ssizessizeobjargproc = unsafe extern "C" fn(
    arg1: *mut PyObject,
    arg2: Py_ssize_t,
    arg3: Py_ssize_t,
    arg4: *mut PyObject,
) -> c_int;
pub type objobjargproc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: *mut PyObject, arg3: *mut PyObject) -> c_int;

#[cfg(not(Py_LIMITED_API))]
pub type getbufferproc = extern "C" fn(
        arg1: *mut crate::object::PyObject,
        arg2: *mut crate::pybuffer::Py_buffer,
        arg3: c_int,
    ) -> c_int;
#[cfg(not(Py_LIMITED_API))]
pub type releasebufferproc =
    extern "C" fn(arg1: *mut crate::object::PyObject, arg2: *mut crate::pybuffer::Py_buffer) -> ();

pub type objobjproc = unsafe extern "C" fn(arg1: *mut PyObject, arg2: *mut PyObject) -> c_int;
pub type visitproc = unsafe extern "C" fn(object: *mut PyObject, arg: *mut c_void) -> c_int;
pub type traverseproc =
    unsafe extern "C" fn(slf: *mut PyObject, visit: visitproc, arg: *mut c_void) -> c_int;

pub type freefunc = unsafe extern "C" fn(arg1: *mut c_void);
pub type destructor = unsafe extern "C" fn(arg1: *mut PyObject);
#[cfg(not(Py_LIMITED_API))]
pub type printfunc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: *mut libc::FILE, arg3: c_int) -> c_int;
pub type getattrfunc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: *mut c_char) -> *mut PyObject;
pub type getattrofunc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: *mut PyObject) -> *mut PyObject;
pub type setattrfunc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: *mut c_char, arg3: *mut PyObject) -> c_int;
pub type setattrofunc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: *mut PyObject, arg3: *mut PyObject) -> c_int;
pub type reprfunc = unsafe extern "C" fn(arg1: *mut PyObject) -> *mut PyObject;
pub type hashfunc = unsafe extern "C" fn(arg1: *mut PyObject) -> Py_hash_t;
pub type richcmpfunc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: *mut PyObject, arg3: c_int) -> *mut PyObject;
pub type getiterfunc = unsafe extern "C" fn(arg1: *mut PyObject) -> *mut PyObject;
pub type iternextfunc = unsafe extern "C" fn(arg1: *mut PyObject) -> *mut PyObject;
pub type descrgetfunc = unsafe extern "C" fn(
    arg1: *mut PyObject,
    arg2: *mut PyObject,
    arg3: *mut PyObject,
) -> *mut PyObject;
pub type descrsetfunc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: *mut PyObject, arg3: *mut PyObject) -> c_int;
pub type initproc =
    unsafe extern "C" fn(arg1: *mut PyObject, arg2: *mut PyObject, arg3: *mut PyObject) -> c_int;
pub type newfunc = unsafe extern "C" fn(
    arg1: *mut PyTypeObject,
    arg2: *mut PyObject,
    arg3: *mut PyObject,
) -> *mut PyObject;
pub type allocfunc =
    unsafe extern "C" fn(arg1: *mut PyTypeObject, arg2: Py_ssize_t) -> *mut PyObject;

#[cfg(Py_3_8)]
pub type vectorcallfunc = unsafe extern "C" fn(
    callable: *mut crate::object::PyObject,
    args: *const *mut crate::object::PyObject,
    nargsf: libc::size_t,
    kwnames: *mut crate::object::PyObject,
) -> *mut crate::object::PyObject;

#[cfg(Py_LIMITED_API)]
#[repr(C)]
pub struct PyTypeObject {
    _private: [u8; 0],
}

#[cfg(not(Py_LIMITED_API))]
mod typeobject {
    use libc::{c_char, c_uint, c_ulong, c_void};

    use crate::pyport::Py_ssize_t;
    #[cfg(Py_3_10)]
    use super::PyObject;

    #[repr(C)]
    #[derive(Copy)]
    pub struct PyNumberMethods {
        pub nb_add: Option<crate::object::binaryfunc>,
        pub nb_subtract: Option<crate::object::binaryfunc>,
        pub nb_multiply: Option<crate::object::binaryfunc>,
        pub nb_remainder: Option<crate::object::binaryfunc>,
        pub nb_divmod: Option<crate::object::binaryfunc>,
        pub nb_power: Option<crate::object::ternaryfunc>,
        pub nb_negative: Option<crate::object::unaryfunc>,
        pub nb_positive: Option<crate::object::unaryfunc>,
        pub nb_absolute: Option<crate::object::unaryfunc>,
        pub nb_bool: Option<crate::object::inquiry>,
        pub nb_invert: Option<crate::object::unaryfunc>,
        pub nb_lshift: Option<crate::object::binaryfunc>,
        pub nb_rshift: Option<crate::object::binaryfunc>,
        pub nb_and: Option<crate::object::binaryfunc>,
        pub nb_xor: Option<crate::object::binaryfunc>,
        pub nb_or: Option<crate::object::binaryfunc>,
        pub nb_int: Option<crate::object::unaryfunc>,
        pub nb_reserved: *mut c_void,
        pub nb_float: Option<crate::object::unaryfunc>,
        pub nb_inplace_add: Option<crate::object::binaryfunc>,
        pub nb_inplace_subtract: Option<crate::object::binaryfunc>,
        pub nb_inplace_multiply: Option<crate::object::binaryfunc>,
        pub nb_inplace_remainder: Option<crate::object::binaryfunc>,
        pub nb_inplace_power: Option<crate::object::ternaryfunc>,
        pub nb_inplace_lshift: Option<crate::object::binaryfunc>,
        pub nb_inplace_rshift: Option<crate::object::binaryfunc>,
        pub nb_inplace_and: Option<crate::object::binaryfunc>,
        pub nb_inplace_xor: Option<crate::object::binaryfunc>,
        pub nb_inplace_or: Option<crate::object::binaryfunc>,
        pub nb_floor_divide: Option<crate::object::binaryfunc>,
        pub nb_true_divide: Option<crate::object::binaryfunc>,
        pub nb_inplace_floor_divide: Option<crate::object::binaryfunc>,
        pub nb_inplace_true_divide: Option<crate::object::binaryfunc>,
        pub nb_index: Option<crate::object::unaryfunc>,
        #[cfg(Py_3_5)]
        pub nb_matrix_multiply: Option<crate::object::binaryfunc>,
        #[cfg(Py_3_5)]
        pub nb_inplace_matrix_multiply: Option<crate::object::binaryfunc>,
    }
    impl Clone for PyNumberMethods {
        #[inline]
        fn clone(&self) -> Self {
            *self
        }
    }
    impl Default for PyNumberMethods {
        #[inline]
        fn default() -> Self {
            unsafe { core::mem::zeroed() }
        }
    }
    macro_rules! as_expr {
        ($e:expr) => {
            $e
        };
    }

    macro_rules! py_number_methods_init {
        ($($tail:tt)*) => {
            as_expr! {
                PyNumberMethods {
                    nb_add: None,
                    nb_subtract: None,
                    nb_multiply: None,
                    nb_remainder: None,
                    nb_divmod: None,
                    nb_power: None,
                    nb_negative: None,
                    nb_positive: None,
                    nb_absolute: None,
                    nb_bool: None,
                    nb_invert: None,
                    nb_lshift: None,
                    nb_rshift: None,
                    nb_and: None,
                    nb_xor: None,
                    nb_or: None,
                    nb_int: None,
                    nb_reserved: 0 as *mut c_void,
                    nb_float: None,
                    nb_inplace_add: None,
                    nb_inplace_subtract: None,
                    nb_inplace_multiply: None,
                    nb_inplace_remainder: None,
                    nb_inplace_power: None,
                    nb_inplace_lshift: None,
                    nb_inplace_rshift: None,
                    nb_inplace_and: None,
                    nb_inplace_xor: None,
                    nb_inplace_or: None,
                    nb_floor_divide: None,
                    nb_true_divide: None,
                    nb_inplace_floor_divide: None,
                    nb_inplace_true_divide: None,
                    nb_index: None,
                    $($tail)*
                }
            }
        }
    }

    #[cfg(not(Py_3_5))]
    pub const PyNumberMethods_INIT: PyNumberMethods = py_number_methods_init!();

    #[cfg(Py_3_5)]
    pub const PyNumberMethods_INIT: PyNumberMethods = py_number_methods_init! {
        nb_matrix_multiply: None,
        nb_inplace_matrix_multiply: None,
    };

    #[repr(C)]
    #[derive(Copy)]
    pub struct PySequenceMethods {
        pub sq_length: Option<crate::object::lenfunc>,
        pub sq_concat: Option<crate::object::binaryfunc>,
        pub sq_repeat: Option<crate::object::ssizeargfunc>,
        pub sq_item: Option<crate::object::ssizeargfunc>,
        pub was_sq_slice: *mut c_void,
        pub sq_ass_item: Option<crate::object::ssizeobjargproc>,
        pub was_sq_ass_slice: *mut c_void,
        pub sq_contains: Option<crate::object::objobjproc>,
        pub sq_inplace_concat: Option<crate::object::binaryfunc>,
        pub sq_inplace_repeat: Option<crate::object::ssizeargfunc>,
    }
    impl Clone for PySequenceMethods {
        #[inline]
        fn clone(&self) -> Self {
            *self
        }
    }
    impl Default for PySequenceMethods {
        #[inline]
        fn default() -> Self {
            unsafe { core::mem::zeroed() }
        }
    }
    pub const PySequenceMethods_INIT: PySequenceMethods = PySequenceMethods {
        sq_length: None,
        sq_concat: None,
        sq_repeat: None,
        sq_item: None,
        was_sq_slice: 0 as *mut _,
        sq_ass_item: None,
        was_sq_ass_slice: 0 as *mut _,
        sq_contains: None,
        sq_inplace_concat: None,
        sq_inplace_repeat: None,
    };
    #[repr(C)]
    #[derive(Copy)]
    pub struct PyMappingMethods {
        pub mp_length: Option<crate::object::lenfunc>,
        pub mp_subscript: Option<crate::object::binaryfunc>,
        pub mp_ass_subscript: Option<crate::object::objobjargproc>,
    }
    impl Clone for PyMappingMethods {
        #[inline]
        fn clone(&self) -> Self {
            *self
        }
    }
    impl Default for PyMappingMethods {
        #[inline]
        fn default() -> Self {
            unsafe { core::mem::zeroed() }
        }
    }
    pub const PyMappingMethods_INIT: PyMappingMethods = PyMappingMethods {
        mp_length: None,
        mp_subscript: None,
        mp_ass_subscript: None,
    };
    #[cfg(Py_3_10)]
    pub type sendfunc = unsafe extern "C" fn(iter: *mut PyObject, value: *mut PyObject, result: *mut *mut PyObject) -> super::PySendResult;
    #[repr(C)]
    #[derive(Copy)]
    #[cfg(Py_3_5)]
    pub struct PyAsyncMethods {
        pub am_await: Option<crate::object::unaryfunc>,
        pub am_aiter: Option<crate::object::unaryfunc>,
        pub am_anext: Option<crate::object::unaryfunc>,
        #[cfg(Py_3_10)]
        pub am_send: Option<sendfunc>,
    }
    #[cfg(Py_3_5)]
    impl Clone for PyAsyncMethods {
        #[inline]
        fn clone(&self) -> Self {
            *self
        }
    }
    #[cfg(Py_3_5)]
    impl Default for PyAsyncMethods {
        #[inline]
        fn default() -> Self {
            unsafe { core::mem::zeroed() }
        }
    }
    #[cfg(Py_3_5)]
    pub const PyAsyncMethods_INIT: PyAsyncMethods = PyAsyncMethods {
        am_await: None,
        am_aiter: None,
        am_anext: None,
        #[cfg(Py_3_10)]
        am_send: None
    };
    #[repr(C)]
    #[derive(Copy)]
    pub struct PyBufferProcs {
        pub bf_getbuffer: Option<crate::object::getbufferproc>,
        pub bf_releasebuffer: Option<crate::object::releasebufferproc>,
    }
    impl Clone for PyBufferProcs {
        #[inline]
        fn clone(&self) -> Self {
            *self
        }
    }
    impl Default for PyBufferProcs {
        #[inline]
        fn default() -> Self {
            unsafe { core::mem::zeroed() }
        }
    }

    #[repr(C)]
    #[derive(Copy)]
    pub struct PyTypeObject {
        pub ob_base: crate::object::PyVarObject,
        pub tp_name: *const c_char,
        pub tp_basicsize: Py_ssize_t,
        pub tp_itemsize: Py_ssize_t,
        pub tp_dealloc: Option<crate::object::destructor>,
        #[cfg(not(Py_3_8))]
        pub tp_print: Option<crate::object::printfunc>,
        #[cfg(Py_3_8)]
        pub tp_vectorcall_offset: Py_ssize_t,
        pub tp_getattr: Option<crate::object::getattrfunc>,
        pub tp_setattr: Option<crate::object::setattrfunc>,
        #[cfg(Py_3_5)]
        pub tp_as_async: *mut PyAsyncMethods,
        #[cfg(not(Py_3_5))]
        pub tp_reserved: *mut c_void,
        pub tp_repr: Option<crate::object::reprfunc>,
        pub tp_as_number: *mut PyNumberMethods,
        pub tp_as_sequence: *mut PySequenceMethods,
        pub tp_as_mapping: *mut PyMappingMethods,
        pub tp_hash: Option<crate::object::hashfunc>,
        pub tp_call: Option<crate::object::ternaryfunc>,
        pub tp_str: Option<crate::object::reprfunc>,
        pub tp_getattro: Option<crate::object::getattrofunc>,
        pub tp_setattro: Option<crate::object::setattrofunc>,
        pub tp_as_buffer: *mut PyBufferProcs,
        pub tp_flags: c_ulong,
        pub tp_doc: *const c_char,
        pub tp_traverse: Option<crate::object::traverseproc>,
        pub tp_clear: Option<crate::object::inquiry>,
        pub tp_richcompare: Option<crate::object::richcmpfunc>,
        pub tp_weaklistoffset: Py_ssize_t,
        pub tp_iter: Option<crate::object::getiterfunc>,
        pub tp_iternext: Option<crate::object::iternextfunc>,
        pub tp_methods: *mut crate::methodobject::PyMethodDef,
        pub tp_members: *mut crate::structmember::PyMemberDef,
        pub tp_getset: *mut crate::descrobject::PyGetSetDef,
        pub tp_base: *mut PyTypeObject,
        pub tp_dict: *mut crate::object::PyObject,
        pub tp_descr_get: Option<crate::object::descrgetfunc>,
        pub tp_descr_set: Option<crate::object::descrsetfunc>,
        pub tp_dictoffset: Py_ssize_t,
        pub tp_init: Option<crate::object::initproc>,
        pub tp_alloc: Option<crate::object::allocfunc>,
        pub tp_new: Option<crate::object::newfunc>,
        pub tp_free: Option<crate::object::freefunc>,
        pub tp_is_gc: Option<crate::object::inquiry>,
        pub tp_bases: *mut crate::object::PyObject,
        pub tp_mro: *mut crate::object::PyObject,
        pub tp_cache: *mut crate::object::PyObject,
        pub tp_subclasses: *mut crate::object::PyObject,
        pub tp_weaklist: *mut crate::object::PyObject,
        pub tp_del: Option<crate::object::destructor>,
        pub tp_version_tag: c_uint,
        #[cfg(Py_3_4)]
        pub tp_finalize: Option<crate::object::destructor>,
        #[cfg(Py_3_8)]
        pub tp_vectorcall: Option<crate::object::vectorcallfunc>,
        #[cfg(all(Py_3_8, not(Py_3_9)))]
        pub tp_print: Option<crate::object::printfunc>,
        #[cfg(all(py_sys_config = "COUNT_ALLOCS", not(Py_3_9)))]
        pub tp_allocs: Py_ssize_t,
        #[cfg(all(py_sys_config = "COUNT_ALLOCS", not(Py_3_9)))]
        pub tp_frees: Py_ssize_t,
        #[cfg(all(py_sys_config = "COUNT_ALLOCS", not(Py_3_9)))]
        pub tp_maxalloc: Py_ssize_t,
        #[cfg(all(py_sys_config = "COUNT_ALLOCS", not(Py_3_9)))]
        pub tp_prev: *mut PyTypeObject,
        #[cfg(all(py_sys_config = "COUNT_ALLOCS", not(Py_3_9)))]
        pub tp_next: *mut PyTypeObject,
    }
    impl Clone for PyTypeObject {
        #[inline]
        fn clone(&self) -> Self {
            *self
        }
    }

    macro_rules! py_type_object_init {
        ($($tail:tt)*) => {
            as_expr! {
                PyTypeObject {
                    ob_base: crate::object::PyVarObject {
                        ob_base: crate::object::PyObject_HEAD_INIT,
                        ob_size: 0
                    },
                    tp_name: 0 as *const c_char,
                    tp_basicsize: 0,
                    tp_itemsize: 0,
                    tp_dealloc: None,
                    tp_getattr: None,
                    tp_setattr: None,
                    tp_repr: None,
                    tp_as_number: 0 as *mut PyNumberMethods,
                    tp_as_sequence: 0 as *mut PySequenceMethods,
                    tp_as_mapping: 0 as *mut PyMappingMethods,
                    tp_hash: None,
                    tp_call: None,
                    tp_str: None,
                    tp_getattro: None,
                    tp_setattro: None,
                    tp_as_buffer: 0 as *mut PyBufferProcs,
                    tp_flags: crate::object::Py_TPFLAGS_DEFAULT,
                    tp_doc: 0 as *const c_char,
                    tp_traverse: None,
                    tp_clear: None,
                    tp_richcompare: None,
                    tp_weaklistoffset: 0,
                    tp_iter: None,
                    tp_iternext: None,
                    tp_methods: 0 as *mut crate::methodobject::PyMethodDef,
                    tp_members: 0 as *mut crate::structmember::PyMemberDef,
                    tp_getset: 0 as *mut crate::descrobject::PyGetSetDef,
                    tp_base: 0 as *mut PyTypeObject,
                    tp_dict: 0 as *mut crate::object::PyObject,
                    tp_descr_get: None,
                    tp_descr_set: None,
                    tp_dictoffset: 0,
                    tp_init: None,
                    tp_alloc: None,
                    tp_new: None,
                    tp_free: None,
                    tp_is_gc: None,
                    tp_bases: 0 as *mut crate::object::PyObject,
                    tp_mro: 0 as *mut crate::object::PyObject,
                    tp_cache: 0 as *mut crate::object::PyObject,
                    tp_subclasses: 0 as *mut crate::object::PyObject,
                    tp_weaklist: 0 as *mut crate::object::PyObject,
                    tp_del: None,
                    tp_version_tag: 0,
                    $($tail)*
                }
            }
        }
    }

    #[cfg(py_sys_config = "COUNT_ALLOCS")]
    macro_rules! py_type_object_init_with_count_allocs {
        ($($tail:tt)*) => {
            py_type_object_init!(
                $($tail)*
                tp_allocs: 0,
                tp_frees: 0,
                tp_maxalloc: 0,
                tp_prev: 0 as *mut PyTypeObject,
                tp_next: 0 as *mut PyTypeObject,
            )
        }
    }

    #[cfg(not(py_sys_config = "COUNT_ALLOCS"))]
    macro_rules! py_type_object_init_with_count_allocs {
        ($($tail:tt)*) => {
            py_type_object_init!($($tail)*)
        }
    }

    #[cfg(Py_3_9)]
    pub const PyTypeObject_INIT: PyTypeObject = py_type_object_init_with_count_allocs!(
        tp_as_async: 0 as *mut PyAsyncMethods,
        tp_vectorcall_offset: 0,
        tp_vectorcall: None,
        tp_finalize: None,
    );

    #[cfg(all(Py_3_8, not(Py_3_9)))]
    pub const PyTypeObject_INIT: PyTypeObject = py_type_object_init_with_count_allocs!(
        tp_print: None,
        tp_as_async: 0 as *mut PyAsyncMethods,
        tp_vectorcall_offset: 0,
        tp_vectorcall: None,
        tp_finalize: None,
    );

    #[cfg(all(Py_3_5, not(Py_3_8)))]
    pub const PyTypeObject_INIT: PyTypeObject = py_type_object_init_with_count_allocs!(
        tp_print: None,
        tp_as_async: 0 as *mut PyAsyncMethods,
        tp_finalize: None,
    );

    #[cfg(all(Py_3_4, not(Py_3_5)))]
    pub const PyTypeObject_INIT: PyTypeObject = py_type_object_init_with_count_allocs!(
        tp_print: None,
        tp_reserved: 0 as *mut c_void,
        tp_finalize: None,
    );

    #[cfg(not(Py_3_4))]
    pub const PyTypeObject_INIT: PyTypeObject = py_type_object_init_with_count_allocs!(
        tp_print: None,
        tp_reserved: 0 as *mut c_void,
    );

    impl PyTypeObject {
        #[inline]
        pub fn init_ob_type(&mut self, type_object: *mut PyTypeObject) {
            self.ob_base.ob_base.ob_type = type_object;
        }
    }

    #[repr(C)]
    #[derive(Copy)]
    pub struct PyHeapTypeObject {
        pub ht_type: PyTypeObject,
        #[cfg(Py_3_5)]
        pub as_async: PyAsyncMethods,
        pub as_number: PyNumberMethods,
        pub as_mapping: PyMappingMethods,
        pub as_sequence: PySequenceMethods,
        pub as_buffer: PyBufferProcs,
        pub ht_name: *mut crate::object::PyObject,
        pub ht_slots: *mut crate::object::PyObject,
        pub ht_qualname: *mut crate::object::PyObject,
        pub ht_cached_keys: *mut c_void,
        #[cfg(Py_3_9)]
        pub ht_module: *mut crate::object::PyObject,
        #[cfg(Py_3_11)]
        _ht_tpname: *mut c_char,
        #[cfg(Py_3_11)]
        _spec_cache: *mut c_void,
    }
    impl Clone for PyHeapTypeObject {
        #[inline]
        fn clone(&self) -> Self {
            *self
        }
    }
    impl Default for PyHeapTypeObject {
        #[inline]
        fn default() -> Self {
            unsafe { core::mem::zeroed() }
        }
    }

    #[inline]
    #[cfg(not(Py_3_11))]
    pub unsafe fn PyHeapType_GET_MEMBERS(
        etype: *mut PyHeapTypeObject,
    ) -> *mut crate::structmember::PyMemberDef {
        (etype as *mut c_char).offset(
            (*crate::object::Py_TYPE(etype as *mut crate::object::PyObject)).tp_basicsize as isize,
        ) as *mut crate::structmember::PyMemberDef
    }
}
#[cfg(not(Py_LIMITED_API))]
pub use self::typeobject::*;

#[repr(C)]
#[derive(Copy)]
pub struct PyType_Slot {
    pub slot: c_int,
    pub pfunc: *mut c_void,
}
impl Clone for PyType_Slot {
    fn clone(&self) -> PyType_Slot {
        *self
    }
}
impl Default for PyType_Slot {
    fn default() -> PyType_Slot {
        unsafe { core::mem::zeroed() }
    }
}

#[repr(C)]
#[derive(Copy)]
pub struct PyType_Spec {
    pub name: *const c_char,
    pub basicsize: c_int,
    pub itemsize: c_int,
    pub flags: c_uint,
    pub slots: *mut PyType_Slot,
}
impl Clone for PyType_Spec {
    fn clone(&self) -> PyType_Spec {
        *self
    }
}
impl Default for PyType_Spec {
    fn default() -> PyType_Spec {
        unsafe { core::mem::zeroed() }
    }
}

#[cfg_attr(windows, link(name = "pythonXY"))]
extern "C" {
    pub fn PyType_FromSpec(arg1: *mut PyType_Spec) -> *mut PyObject;

    //#[cfg(Py_3_3)]
    pub fn PyType_FromSpecWithBases(arg1: *mut PyType_Spec, arg2: *mut PyObject) -> *mut PyObject;

    #[cfg(Py_3_4)]
    pub fn PyType_GetSlot(arg1: *mut PyTypeObject, arg2: c_int) -> *mut c_void;

    #[cfg(Py_3_9)]
    pub fn PyType_FromModuleAndSpec(
        arg1: *mut PyObject,
        arg2: *mut PyType_Spec,
        arg3: *mut PyObject,
    ) -> *mut PyObject;

    #[cfg(Py_3_9)]
    pub fn PyType_GetModule(arg1: *mut PyTypeObject) -> *mut PyObject;

    #[cfg(Py_3_9)]
    pub fn PyType_GetModuleState(arg1: *mut PyTypeObject) -> *mut c_void;

    #[cfg(Py_3_11)]
    pub fn PyType_GetName(arg1: *mut PyTypeObject) -> *mut PyObject;

    #[cfg(Py_3_11)]
    pub fn PyType_GetQualName(arg1: *mut PyTypeObject) -> *mut PyObject;
}

#[cfg_attr(windows, link(name = "pythonXY"))]
extern "C" {
    pub fn PyType_IsSubtype(a: *mut PyTypeObject, b: *mut PyTypeObject) -> c_int;
}

#[inline(always)]
pub unsafe fn PyObject_TypeCheck(ob: *mut PyObject, tp: *mut PyTypeObject) -> c_int {
    (Py_TYPE(ob) == tp || PyType_IsSubtype(Py_TYPE(ob), tp) != 0) as c_int
}

#[cfg_attr(windows, link(name = "pythonXY"))]
extern "C" {
    /// built-in 'type'
    pub static mut PyType_Type: PyTypeObject;
    /// built-in 'object'
    pub static mut PyBaseObject_Type: PyTypeObject;
    /// built-in 'super'
    pub static mut PySuper_Type: PyTypeObject;

    pub fn PyType_GetFlags(arg1: *mut PyTypeObject) -> c_ulong;
}

#[inline(always)]
pub unsafe fn PyType_Check(op: *mut PyObject) -> c_int {
    PyType_FastSubclass(Py_TYPE(op), Py_TPFLAGS_TYPE_SUBCLASS)
}

#[inline(always)]
pub unsafe fn PyType_CheckExact(op: *mut PyObject) -> c_int {
    (Py_TYPE(op) == &mut PyType_Type) as c_int
}

#[cfg_attr(windows, link(name = "pythonXY"))]
extern "C" {
    pub fn PyType_Ready(t: *mut PyTypeObject) -> c_int;
    pub fn PyType_GenericAlloc(t: *mut PyTypeObject, nitems: Py_ssize_t) -> *mut PyObject;
    pub fn PyType_GenericNew(
        t: *mut PyTypeObject,
        args: *mut PyObject,
        kwds: *mut PyObject,
    ) -> *mut PyObject;
    pub fn PyType_ClearCache() -> c_uint;
    pub fn PyType_Modified(t: *mut PyTypeObject);

    #[cfg(not(Py_LIMITED_API))]
    pub fn PyObject_Print(o: *mut PyObject, fp: *mut libc::FILE, flags: c_int) -> c_int;
    pub fn PyObject_Repr(o: *mut PyObject) -> *mut PyObject;
    pub fn PyObject_Str(o: *mut PyObject) -> *mut PyObject;
    pub fn PyObject_ASCII(arg1: *mut PyObject) -> *mut PyObject;
    pub fn PyObject_Bytes(arg1: *mut PyObject) -> *mut PyObject;
    pub fn PyObject_RichCompare(
        arg1: *mut PyObject,
        arg2: *mut PyObject,
        arg3: c_int,
    ) -> *mut PyObject;
    pub fn PyObject_RichCompareBool(arg1: *mut PyObject, arg2: *mut PyObject, arg3: c_int)
        -> c_int;
    pub fn PyObject_GetAttrString(arg1: *mut PyObject, arg2: *const c_char) -> *mut PyObject;
    pub fn PyObject_SetAttrString(
        arg1: *mut PyObject,
        arg2: *const c_char,
        arg3: *mut PyObject,
    ) -> c_int;
    pub fn PyObject_HasAttrString(arg1: *mut PyObject, arg2: *const c_char) -> c_int;
    pub fn PyObject_GetAttr(arg1: *mut PyObject, arg2: *mut PyObject) -> *mut PyObject;
    pub fn PyObject_SetAttr(arg1: *mut PyObject, arg2: *mut PyObject, arg3: *mut PyObject)
        -> c_int;
    pub fn PyObject_HasAttr(arg1: *mut PyObject, arg2: *mut PyObject) -> c_int;
    pub fn PyObject_SelfIter(arg1: *mut PyObject) -> *mut PyObject;

    #[cfg(not(Py_LIMITED_API))]
    pub fn _PyObject_NextNotImplemented(arg1: *mut PyObject) -> *mut PyObject;

    pub fn PyObject_GenericGetAttr(arg1: *mut PyObject, arg2: *mut PyObject) -> *mut PyObject;
    pub fn PyObject_GenericSetAttr(
        arg1: *mut PyObject,
        arg2: *mut PyObject,
        arg3: *mut PyObject,
    ) -> c_int;
    pub fn PyObject_GenericSetDict(
        arg1: *mut PyObject,
        arg2: *mut PyObject,
        arg3: *mut c_void,
    ) -> c_int;
    pub fn PyObject_Hash(arg1: *mut PyObject) -> Py_hash_t;
    pub fn PyObject_HashNotImplemented(arg1: *mut PyObject) -> Py_hash_t;
    pub fn PyObject_IsTrue(arg1: *mut PyObject) -> c_int;
    pub fn PyObject_Not(arg1: *mut PyObject) -> c_int;
    pub fn PyCallable_Check(arg1: *mut PyObject) -> c_int;
    pub fn PyObject_ClearWeakRefs(arg1: *mut PyObject) -> ();
    #[cfg(Py_3_4)]
    #[cfg(not(Py_LIMITED_API))]
    pub fn PyObject_CallFinalizer(arg1: *mut PyObject) -> ();
    #[cfg(Py_3_4)]
    #[cfg(not(Py_LIMITED_API))]
    pub fn PyObject_CallFinalizerFromDealloc(arg1: *mut PyObject) -> c_int;

    pub fn PyObject_Dir(arg1: *mut PyObject) -> *mut PyObject;
    pub fn Py_ReprEnter(arg1: *mut PyObject) -> c_int;
    pub fn Py_ReprLeave(arg1: *mut PyObject) -> ();
}

// Flag bits for printing:
pub const Py_PRINT_RAW: c_int = 1; // No string quotes etc.

/// Disallow creating instances of the type: set tp_new to NULL and don't create
/// the "__new__" key in the type dictionary.
#[cfg(Py_3_10)]
pub const Py_TPFLAGS_DISALLOW_INSTANTIATION: c_ulong = (1 << 7);

/// Set if the type object is immutable: type attributes cannot be set nor deleted
#[cfg(Py_3_10)]
pub const Py_TPFLAGS_IMMUTABLETYPE: c_ulong = (1 << 8);

/// Set if the type object is dynamically allocated
pub const Py_TPFLAGS_HEAPTYPE: c_ulong = (1 << 9);

/// Set if the type allows subclassing
pub const Py_TPFLAGS_BASETYPE: c_ulong = (1 << 10);

#[cfg(all(Py_3_8, not(Py_LIMITED_API)))]
pub const Py_TPFLAGS_HAVE_VECTORCALL: c_ulong = (1 << 11);

/// Set if the type is 'ready' -- fully initialized
pub const Py_TPFLAGS_READY: c_ulong = (1 << 12);

/// Set while the type is being 'readied', to prevent recursive ready calls
pub const Py_TPFLAGS_READYING: c_ulong = (1 << 13);

/// Objects support garbage collection (see objimp.h)
pub const Py_TPFLAGS_HAVE_GC: c_ulong = (1 << 14);

const Py_TPFLAGS_HAVE_STACKLESS_EXTENSION: c_ulong = 0;

#[cfg(Py_3_8)]
pub const Py_TPFLAGS_METHOD_DESCRIPTOR: c_ulong = (1 << 17);

/// Object has up-to-date type attribute cache
pub const Py_TPFLAGS_VALID_VERSION_TAG: c_ulong = (1 << 19);

/* Type is abstract and cannot be instantiated */
pub const Py_TPFLAGS_IS_ABSTRACT: c_ulong = (1 << 20);

/* These flags are used to determine if a type is a subclass. */
pub const Py_TPFLAGS_LONG_SUBCLASS: c_ulong = (1 << 24);
pub const Py_TPFLAGS_LIST_SUBCLASS: c_ulong = (1 << 25);
pub const Py_TPFLAGS_TUPLE_SUBCLASS: c_ulong = (1 << 26);
pub const Py_TPFLAGS_BYTES_SUBCLASS: c_ulong = (1 << 27);
pub const Py_TPFLAGS_UNICODE_SUBCLASS: c_ulong = (1 << 28);
pub const Py_TPFLAGS_DICT_SUBCLASS: c_ulong = (1 << 29);
pub const Py_TPFLAGS_BASE_EXC_SUBCLASS: c_ulong = (1 << 30);
pub const Py_TPFLAGS_TYPE_SUBCLASS: c_ulong = (1 << 31);

#[cfg(not(Py_3_10))]
pub const Py_TPFLAGS_DEFAULT: c_ulong =
    (Py_TPFLAGS_HAVE_STACKLESS_EXTENSION | Py_TPFLAGS_HAVE_VERSION_TAG | 0);

#[cfg(Py_3_10)]
pub const Py_TPFLAGS_DEFAULT: c_ulong =
    (Py_TPFLAGS_HAVE_STACKLESS_EXTENSION | 0);


pub const Py_TPFLAGS_HAVE_FINALIZE: c_ulong = (1 << 0);
pub const Py_TPFLAGS_HAVE_VERSION_TAG: c_ulong = (1 << 18);

#[inline(always)]
#[cfg(Py_LIMITED_API)]
pub unsafe fn PyType_HasFeature(t: *mut PyTypeObject, f: c_ulong) -> c_int {
    ((PyType_GetFlags(t) & f) != 0) as c_int
}

#[inline(always)]
#[cfg(not(Py_LIMITED_API))]
pub unsafe fn PyType_HasFeature(t: *mut PyTypeObject, f: c_ulong) -> c_int {
    (((*t).tp_flags & f) != 0) as c_int
}

#[inline(always)]
pub unsafe fn PyType_FastSubclass(t: *mut PyTypeObject, f: c_ulong) -> c_int {
    PyType_HasFeature(t, f)
}

#[cfg_attr(windows, link(name = "pythonXY"))]
extern "C" {
    pub fn _Py_Dealloc(arg1: *mut PyObject) -> ();
}

// Reference counting macros.
#[inline(always)]
pub unsafe fn Py_INCREF(op: *mut PyObject) {
    if cfg!(py_sys_config = "Py_REF_DEBUG") {
        Py_IncRef(op)
    } else {
        (*op).ob_refcnt += 1
    }
}

#[inline(always)]
pub unsafe fn Py_DECREF(op: *mut PyObject) {
    if cfg!(py_sys_config = "Py_REF_DEBUG") {
        Py_DecRef(op)
    } else {
        (*op).ob_refcnt -= 1;
        if (*op).ob_refcnt == 0 {
            _Py_Dealloc(op)
        }
    }
}

#[inline(always)]
pub unsafe fn Py_CLEAR(op: &mut *mut PyObject) {
    let tmp = *op;
    if !tmp.is_null() {
        *op = ptr::null_mut();
        Py_DECREF(tmp);
    }
}

#[inline(always)]
pub unsafe fn Py_XINCREF(op: *mut PyObject) {
    if !op.is_null() {
        Py_INCREF(op)
    }
}

#[inline(always)]
pub unsafe fn Py_XDECREF(op: *mut PyObject) {
    if !op.is_null() {
        Py_DECREF(op)
    }
}

#[cfg_attr(windows, link(name = "pythonXY"))]
extern "C" {
    pub fn Py_IncRef(o: *mut PyObject);
    pub fn Py_DecRef(o: *mut PyObject);

    #[cfg(Py_3_10)]
    pub fn Py_NewRef(o: *mut PyObject) -> *mut PyObject;
    #[cfg(Py_3_10)]
    pub fn Py_XNewRef(o: *mut PyObject) -> *mut PyObject;

    static mut _Py_NoneStruct: PyObject;
    static mut _Py_NotImplementedStruct: PyObject;
}

#[inline(always)]
pub unsafe fn Py_None() -> *mut PyObject {
    &mut _Py_NoneStruct
}

#[inline(always)]
pub unsafe fn Py_IsNone(x: *mut PyObject) -> c_int {
    (x == Py_None()) as c_int
}

#[inline(always)]
pub unsafe fn Py_NotImplemented() -> *mut PyObject {
    &mut _Py_NotImplementedStruct
}

/* Rich comparison opcodes */
pub const Py_LT: c_int = 0;
pub const Py_LE: c_int = 1;
pub const Py_EQ: c_int = 2;
pub const Py_NE: c_int = 3;
pub const Py_GT: c_int = 4;
pub const Py_GE: c_int = 5;

/* Result of calling PyIter_Send */
#[cfg(Py_3_10)]
#[repr(C)]
pub enum PySendResult {
    PYGEN_RETURN = 0,
    PYGEN_ERROR = -1,
    PYGEN_NEXT = 1,
}