- PyObject_BorrowedRefalias PyObject_BorrowedRef = Borrowed!PyObject 
- Undocumented in source but is binding to C. You might be able to learn more by searching the web for its name. 
- PyObject_Bytesalias PyObject_Bytes = PyObject_Str 
- PyType_FastSubclassalias PyType_FastSubclass = PyType_HasFeature 
- Undocumented in source but is binding to C. You might be able to learn more by searching the web for its name. 
- allocfuncalias allocfunc = PyObject* function(PyTypeObject*, Py_ssize_t) 
- binaryfuncalias binaryfunc = PyObject* function(PyObject*, PyObject*) 
- charbufferprocalias charbufferproc = Py_ssize_t function(PyObject*, Py_ssize_t, char**) 
- ssize_t-based buffer interface
 Availability: 2.* 
- cmpfuncalias cmpfunc = int function(PyObject*, PyObject*) 
- coercionalias coercion = int function(PyObject**, PyObject**) 
- descrgetfuncalias descrgetfunc = PyObject* function(PyObject*, PyObject*, PyObject*) 
- descrsetfuncalias descrsetfunc = int function(PyObject*, PyObject*, PyObject*) 
- destructoralias destructor = void function(PyObject*) 
- freefuncalias freefunc = void function(void*) 
- getattrfuncalias getattrfunc = PyObject* function(PyObject*, char*) 
- getattrofuncalias getattrofunc = PyObject* function(PyObject*, PyObject*) 
- getbufferprocalias getbufferproc = int function(PyObject*, Py_buffer*, int) 
- getcharbufferprocalias getcharbufferproc = charbufferproc 
- int-based buffer interface
 Availability: 2.4 
- getiterfuncalias getiterfunc = PyObject* function(PyObject*) 
- getreadbufferprocalias getreadbufferproc = readbufferproc 
- getsegcountprocalias getsegcountproc = segcountproc 
- getwritebufferprocalias getwritebufferproc = writebufferproc 
- int-based buffer interface
 Availability: 2.4 
- hashfuncalias hashfunc = Py_hash_t function(PyObject*) 
- initprocalias initproc = int function(PyObject*, PyObject*, PyObject*) 
- inquiryalias inquiry = lenfunc 
- intargfuncalias intargfunc = ssizeargfunc 
- intintargfuncalias intintargfunc = ssizessizeargfunc 
- intintobjargprocalias intintobjargproc = ssizessizeobjargproc 
- intobjargprocalias intobjargproc = ssizeobjargproc 
- iternextfuncalias iternextfunc = PyObject* function(PyObject*) 
- lenfuncalias lenfunc = Py_ssize_t function(PyObject*) 
- newfuncalias newfunc = PyObject* function(PyTypeObject*, PyObject*, PyObject*) 
- objobjargprocalias objobjargproc = int function(PyObject*, PyObject*, PyObject*) 
- objobjprocalias objobjproc = int function(PyObject*, PyObject*) 
- printfuncalias printfunc = int function(PyObject*, FILE*, int) 
- readbufferprocalias readbufferproc = Py_ssize_t function(PyObject*, Py_ssize_t, void**) 
- ssize_t-based buffer interface
 Availability: 2.* 
- releasebufferprocalias releasebufferproc = void function(PyObject*, Py_buffer*) 
- reprfuncalias reprfunc = PyObject* function(PyObject*) 
- richcmpfuncalias richcmpfunc = PyObject* function(PyObject*, PyObject*, int) 
- segcountprocalias segcountproc = Py_ssize_t function(PyObject*, Py_ssize_t*) 
- ssize_t-based buffer interface
 Availability: 2.* 
- setattrfuncalias setattrfunc = int function(PyObject*, char*, PyObject*) 
- setattrofuncalias setattrofunc = int function(PyObject*, PyObject*, PyObject*) 
- ssizeargfuncalias ssizeargfunc = PyObject* function(PyObject*, Py_ssize_t) 
- ssizeobjargprocalias ssizeobjargproc = int function(PyObject*, Py_ssize_t, PyObject*) 
- ssizessizeargfuncalias ssizessizeargfunc = PyObject* function(PyObject*, Py_ssize_t, Py_ssize_t) 
- ssizessizeobjargprocalias ssizessizeobjargproc = int function(PyObject*, Py_ssize_t, Py_ssize_t, PyObject*) 
- ternaryfuncalias ternaryfunc = PyObject* function(PyObject*, PyObject*, PyObject*) 
- traverseprocalias traverseproc = int function(PyObject*, visitproc, void*) 
- unaryfuncalias unaryfunc = PyObject* function(PyObject*) 
- vectorcallfuncalias vectorcallfunc = PyObject* function(PyObject* callable, const(PyObject*)* args, size_t nargsf, PyObject* kwnames) 
- Undocumented in source but is binding to C. You might be able to learn more by searching the web for its name. 
- visitprocalias visitproc = int function(PyObject*, void*) 
- writebufferprocalias writebufferproc = Py_ssize_t function(PyObject*, Py_ssize_t, void**) 
- ssize_t-based buffer interface
 Availability: 2.* 
- PyCallable_Checkint PyCallable_Check(PyObject* ) 
- PyNumber_Coerceint PyNumber_Coerce(PyObject** , PyObject** ) 
- PyNumber_CoerceExint PyNumber_CoerceEx(PyObject** , PyObject** ) 
- PyObject_ASCIIPyObject* PyObject_ASCII(PyObject* ) 
- PyObject_BytesPyObject* PyObject_Bytes(PyObject* ) 
- PyObject_ClearWeakRefsvoid PyObject_ClearWeakRefs(PyObject* ) 
- PyObject_Compareint PyObject_Compare(PyObject* , PyObject* ) 
- PyObject_DirPyObject* PyObject_Dir(PyObject* ) 
- PyObject_Dir(obj) acts like Python __builtin__.dir(obj), returning a
   list of strings.  PyObject_Dir(NULL) is like __builtin__.dir(),
   returning the names of the current locals.  In this case, if there are
   no current locals, NULL is returned, and PyErr_Occurred() is false. 
- PyObject_GenericGetAttrPyObject* PyObject_GenericGetAttr(PyObject* , PyObject* ) 
- PyObject_GenericSetAttrint PyObject_GenericSetAttr(PyObject* , PyObject* , PyObject* ) 
- PyObject_GetAttrPyObject* PyObject_GetAttr(PyObject* , PyObject* ) 
- PyObject_GetAttrStringPyObject* PyObject_GetAttrString(PyObject* , const(char)* ) 
- PyObject_HasAttrint PyObject_HasAttr(PyObject* , PyObject* ) 
- PyObject_HasAttrStringint PyObject_HasAttrString(PyObject* , const(char)* ) 
- PyObject_HashPy_hash_t PyObject_Hash(PyObject* ) 
- PyObject_HashNotImplementedPy_hash_t PyObject_HashNotImplemented(PyObject* ) 
- PyObject_IsTrueint PyObject_IsTrue(PyObject* ) 
- PyObject_Notint PyObject_Not(PyObject* ) 
- PyObject_Printint PyObject_Print(PyObject* , FILE* , int ) 
- PyObject_REPRauto  PyObject_REPR(PyObject* obj) 
- PyObject_ReprPyObject* PyObject_Repr(PyObject* ) 
- PyObject_RichComparePyObject* PyObject_RichCompare(PyObject* , PyObject* , int ) 
- PyObject_RichCompareBoolint PyObject_RichCompareBool(PyObject* , PyObject* , int ) 
- PyObject_SelfIterPyObject* PyObject_SelfIter(PyObject* ) 
- PyObject_SetAttrint PyObject_SetAttr(PyObject* , PyObject* , PyObject* ) 
- PyObject_SetAttrStringint PyObject_SetAttrString(PyObject* , const(char)* , PyObject* ) 
- PyObject_StrPyObject* PyObject_Str(PyObject* ) 
- PyObject_TypeCheckint PyObject_TypeCheck(PyObject* ob, PyTypeObject* tp) 
- PyObject_UnicodePyObject* PyObject_Unicode(PyObject* ) 
- PyType_Checkint PyType_Check(PyObject* op) 
- PyType_CheckExactint PyType_CheckExact(PyObject* op) 
- PyType_ClearCacheuint PyType_ClearCache() 
- PyType_FromSpecPyObject* PyType_FromSpec(PyType_Spec* ) 
- PyType_GenericAllocPyObject* PyType_GenericAlloc(PyTypeObject* , Py_ssize_t ) 
- PyType_GenericNewPyObject* PyType_GenericNew(PyTypeObject* , PyObject* , PyObject* ) 
- PyType_GetFlagsC_long PyType_GetFlags(PyTypeObject* ) 
- PyType_HasFeatureint PyType_HasFeature(PyTypeObject* t, int f) 
- PyType_IsSubtypeint PyType_IsSubtype(PyTypeObject* , PyTypeObject* ) 
- PyType_Modifiedvoid PyType_Modified(PyTypeObject* ) 
- PyType_Readyint PyType_Ready(PyTypeObject* ) 
- Py_DECREFvoid Py_DECREF(PyObject* op) 
- Used to decrement reference counts. Calls the object's deallocator function
when the refcount falls to 0; for objects that don't contain references to
other objects or heap memory this can be the standard function free().
Can be used wherever a void expression is allowed.  The argument must not be a
NULL pointer.  If it may be NULL, use Py_XDECREF instead. 
- Py_DecRefvoid Py_DecRef(PyObject* ) 
- These are provided as conveniences to Python runtime embedders, so that
they can have object code that is not dependent on Python compilation flags. 
- Py_INCREFauto  Py_INCREF(T op) 
- Increment reference counts.  Can be used wherever a void expression is allowed.
The argument must not be a NULL pointer. If it may be NULL, use
Py_XINCREF instead. 
- Py_IncRefvoid Py_IncRef(PyObject* ) 
- These are provided as conveniences to Python runtime embedders, so that
they can have object code that is not dependent on Python compilation flags. 
- Py_NoneBorrowed!PyObject* Py_None() 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- Py_REFCNTauto  Py_REFCNT(T* ob) 
- Py_ReprEnterint Py_ReprEnter(PyObject* ) 
- Py_ReprLeavevoid Py_ReprLeave(PyObject* ) 
- Helpers for printing recursive container types 
- Py_SET_REFCNTvoid Py_SET_REFCNT(T* ob, int refcnt) 
- Py_SET_SIZEvoid Py_SET_SIZE(T* ob, Py_ssize_t size) 
- Py_SET_TYPEvoid Py_SET_TYPE(T* ob, PyTypeObject* tipo) 
- Not part of the python api, but annoying to do without. 
- Py_SIZEauto  Py_SIZE(T* ob) 
- Py_TYPEauto  Py_TYPE(T* ob) 
- Py_XDECREFvoid Py_XDECREF(PyObject* op) 
- Same as Py_DECREF, except is a no-op if op is null. 
- Py_XINCREFauto  Py_XINCREF(T op) 
- Increment reference counts.  Can be used wherever a void expression is allowed.
The argument may be a NULL pointer. 
- _PyObject_LookupSpecialPyObject* _PyObject_LookupSpecial(PyObject* , char* , PyObject** ) 
- _PyObject_StrPyObject* _PyObject_Str(PyObject* ) 
- Availability: 2.5, 2.6, 2.7 
- _PyType_CalculateMetaclassPyTypeObject* _PyType_CalculateMetaclass(PyTypeObject* , PyObject* ) 
- _PyType_LookupPyObject* _PyType_Lookup(PyTypeObject* , PyObject* ) 
- _Py_BreakPointvoid _Py_BreakPoint() 
- _Py_Deallocvoid _Py_Dealloc(PyObject* ) 
- _Py_HashDoublePy_hash_t _Py_HashDouble(double ) 
- _Py_HashPointerPy_hash_t _Py_HashPointer(void* ) 
- _Py_NewReferencevoid _Py_NewReference(PyObject* op) 
- Initializes reference counts to 1, and
in special builds (Py_REF_DEBUG, Py_TRACE_REFS) performs additional
bookkeeping appropriate to the special build. 
- borrowedBorrowed!T* borrowed(T* obj) 
- Convert a python reference to borrowed reference.
(Not part of Python api) 
- PyBUF_ANY_CONTIGUOUSenum PyBUF_ANY_CONTIGUOUS; 
- PyBUF_CONTIGenum PyBUF_CONTIG; 
- PyBUF_CONTIG_ROenum PyBUF_CONTIG_RO; 
- PyBUF_C_CONTIGUOUSenum PyBUF_C_CONTIGUOUS; 
- PyBUF_FORMATenum PyBUF_FORMAT; 
- PyBUF_FULLenum PyBUF_FULL; 
- PyBUF_FULL_ROenum PyBUF_FULL_RO; 
- PyBUF_F_CONTIGUOUSenum PyBUF_F_CONTIGUOUS; 
- PyBUF_INDIRECTenum PyBUF_INDIRECT; 
- PyBUF_NDenum PyBUF_ND; 
- PyBUF_READenum PyBUF_READ; 
- PyBUF_RECORDSenum PyBUF_RECORDS; 
- PyBUF_RECORDS_ROenum PyBUF_RECORDS_RO; 
- PyBUF_SHADOWenum PyBUF_SHADOW; 
- Flags for getting buffers  Availability: >= 2.6 
- PyBUF_SIMPLEenum PyBUF_SIMPLE; 
- PyBUF_STRIDEDenum PyBUF_STRIDED; 
- PyBUF_STRIDED_ROenum PyBUF_STRIDED_RO; 
- PyBUF_STRIDESenum PyBUF_STRIDES; 
- PyBUF_WRITABLEenum PyBUF_WRITABLE; 
- PyBUF_WRITEenum PyBUF_WRITE; 
- PyBUF_WRITEABLEenum PyBUF_WRITEABLE; 
- Flags for getting buffers  Availability: >= 2.6 
- Py_EQenum Py_EQ; 
- Py_GEenum Py_GE; 
- Py_GTenum Py_GT; 
- Py_LEenum Py_LE; 
- Py_LTenum Py_LT; 
- Py_NEenum Py_NE; 
- Py_TPFLAGS_BASE_EXC_SUBCLASSenum Py_TPFLAGS_BASE_EXC_SUBCLASS; 
- These flags are used to determine if a type is a subclass.  Availability: >= 2.6 
- Py_TPFLAGS_BYTES_SUBCLASSenum Py_TPFLAGS_BYTES_SUBCLASS; 
- Undocumented in source but is binding to C. You might be able to learn more by searching the web for its name. 
- Py_TPFLAGS_DEFAULTenum Py_TPFLAGS_DEFAULT; 
- Py_TPFLAGS_DEFAULTenum Py_TPFLAGS_DEFAULT; 
- Py_TPFLAGS_DEFAULT_EXTERNALenum Py_TPFLAGS_DEFAULT_EXTERNAL; 
- Undocumented in source but is binding to C. You might be able to learn more by searching the web for its name. 
- Py_TPFLAGS_DICT_SUBCLASSenum Py_TPFLAGS_DICT_SUBCLASS; 
- These flags are used to determine if a type is a subclass.  Availability: >= 2.6 
- Py_TPFLAGS_HAVE_INDEXenum Py_TPFLAGS_HAVE_INDEX; 
- Objects support nb_index in PyNumberMethods  Availability: 2.* 
- Py_TPFLAGS_HAVE_NEWBUFFERenum Py_TPFLAGS_HAVE_NEWBUFFER; 
- Has the new buffer protocol  Availability: 2.6,2.7 
- Py_TPFLAGS_HAVE_VERSION_TAGenum Py_TPFLAGS_HAVE_VERSION_TAG; 
- Objects support type attribute cache  Availability: >= 2.6 
- Py_TPFLAGS_INT_SUBCLASSenum Py_TPFLAGS_INT_SUBCLASS; 
- These flags are used to determine if a type is a subclass.  Availability: >= 2.6 
- Py_TPFLAGS_IS_ABSTRACTenum Py_TPFLAGS_IS_ABSTRACT; 
- Type is abstract and cannot be instantiated  Availability: >= 2.6 
- Py_TPFLAGS_LIST_SUBCLASSenum Py_TPFLAGS_LIST_SUBCLASS; 
- Py_TPFLAGS_LONG_SUBCLASSenum Py_TPFLAGS_LONG_SUBCLASS; 
- These flags are used to determine if a type is a subclass.  Availability: >= 2.6 
- Py_TPFLAGS_STRING_SUBCLASSenum Py_TPFLAGS_STRING_SUBCLASS; 
- Undocumented in source but is binding to C. You might be able to learn more by searching the web for its name. 
- Py_TPFLAGS_TUPLE_SUBCLASSenum Py_TPFLAGS_TUPLE_SUBCLASS; 
- Py_TPFLAGS_TYPE_SUBCLASSenum Py_TPFLAGS_TYPE_SUBCLASS; 
- Py_TPFLAGS_UNICODE_SUBCLASSenum Py_TPFLAGS_UNICODE_SUBCLASS; 
- These flags are used to determine if a type is a subclass.  Availability: >= 2.6 
- Py_TPFLAGS_VALID_VERSION_TAGenum Py_TPFLAGS_VALID_VERSION_TAG; 
- Objects support type attribute cache  Availability: >= 2.6 
Mirror object.h
Object and type object interface
Objects are structures allocated on the heap. Special rules apply to the use of objects to ensure they are properly garbage-collected. Objects are never allocated statically or on the stack; they must be accessed through special macros and functions only. (Type objects are exceptions to the first rule; the standard types are represented by statically initialized type objects, although work on type/class unification for Python 2.2 made it possible to have heap-allocated type objects too).
An object has a 'reference count' that is increased or decreased when a pointer to the object is copied or deleted; when the reference count reaches zero there are no references to the object left and it can be removed from the heap.
An object has a 'type' that determines what it represents and what kind of data it contains. An object's type is fixed when it is created. Types themselves are represented as objects; an object contains a pointer to the corresponding type object. The type itself has a type pointer pointing to the object representing the type 'type', which contains a pointer to itself!).
Objects do not float around in memory; once allocated an object keeps the same size and address. Objects that must hold variable-size data can contain pointers to variable-size parts of the object. Not all objects of the same type have the same size; but the size cannot change after allocation. (These restrictions are made so a reference to an object can be simply a pointer -- moving an object would require updating all the pointers, and changing an object's size would require moving it if there was another object right next to it.)
Objects are always accessed through pointers of the type 'PyObject *'. The type 'PyObject' is a structure that only contains the reference count and the type pointer. The actual memory allocated for an object contains other data that can only be accessed after casting the pointer to a pointer to a longer structure type. This longer type must start with the reference count and type fields; the macro PyObject_HEAD should be used for this (to accommodate for future changes). The implementation of a particular object type can cast the object pointer to the proper type and back.
A standard interface exists for objects that contain an array of items whose size is determined when the object is allocated.