Python | Opaque Pointers in C extension modules
Let’s discuss an extension module that needs to handle a pointer to a C data structure, without exposing any internal details of the structure to Python. Opaque data structures can be easily handled by wrapping them inside capsule objects as shown in the code snippet below.
Code #1 :
Refer Prev Article to find the distance() function – Using C codes in Python.
Code #2 : Code given is an extension code that wraps the Point structure and
distance() function using capsules.
Code #3 : Using the above function in Python
pt1 : <capsule object "Point" at 0x1004ea330> pt2 : <capsule object "Point" at 0x1005d1db0> Distance : 2.8284271247461903
- Capsules are similar to a typed C pointer.
- They hold a generic pointer along with an identifying name and can be easily created using the
PyCapsule_GetPointer()function is used to extract the pointer contained inside a capsule.
- Garbage collection and memory management is a tricky part that concerns about the capsules.
PyPoint_FromPoint()function accepts a must_free argument that indicates whether the underlying Point * structure is to be collected when the capsule is destroyed.