blob: 039289a0b2192abbe941f5eb4941fee156f1a036 [file] [log] [blame]
Georg Brandl71515ca2009-05-17 12:29:12 +00001:mod:`ctypes` --- A foreign function library for Python
2=======================================================
Georg Brandl116aa622007-08-15 14:28:22 +00003
4.. module:: ctypes
5 :synopsis: A foreign function library for Python.
6.. moduleauthor:: Thomas Heller <theller@python.net>
7
8
Georg Brandl116aa622007-08-15 14:28:22 +00009``ctypes`` is a foreign function library for Python. It provides C compatible
Benjamin Peterson3e4f0552008-09-02 00:31:15 +000010data types, and allows calling functions in DLLs or shared libraries. It can be
Georg Brandl116aa622007-08-15 14:28:22 +000011used to wrap these libraries in pure Python.
12
13
14.. _ctypes-ctypes-tutorial:
15
16ctypes tutorial
17---------------
18
19Note: The code samples in this tutorial use ``doctest`` to make sure that they
20actually work. Since some code samples behave differently under Linux, Windows,
21or Mac OS X, they contain doctest directives in comments.
22
Benjamin Peterson3e4f0552008-09-02 00:31:15 +000023Note: Some code samples reference the ctypes :class:`c_int` type. This type is
24an alias for the :class:`c_long` type on 32-bit systems. So, you should not be
Georg Brandl116aa622007-08-15 14:28:22 +000025confused if :class:`c_long` is printed if you would expect :class:`c_int` ---
26they are actually the same type.
27
28
29.. _ctypes-loading-dynamic-link-libraries:
30
31Loading dynamic link libraries
32^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
33
Benjamin Peterson3e4f0552008-09-02 00:31:15 +000034``ctypes`` exports the *cdll*, and on Windows *windll* and *oledll*
35objects, for loading dynamic link libraries.
Georg Brandl116aa622007-08-15 14:28:22 +000036
37You load libraries by accessing them as attributes of these objects. *cdll*
38loads libraries which export functions using the standard ``cdecl`` calling
39convention, while *windll* libraries call functions using the ``stdcall``
40calling convention. *oledll* also uses the ``stdcall`` calling convention, and
41assumes the functions return a Windows :class:`HRESULT` error code. The error
Thomas Heller2fadaa22008-06-16 19:56:33 +000042code is used to automatically raise a :class:`WindowsError` exception when
Georg Brandl116aa622007-08-15 14:28:22 +000043the function call fails.
44
45Here are some examples for Windows. Note that ``msvcrt`` is the MS standard C
46library containing most standard C functions, and uses the cdecl calling
47convention::
48
49 >>> from ctypes import *
Georg Brandl6911e3c2007-09-04 07:15:32 +000050 >>> print(windll.kernel32) # doctest: +WINDOWS
Georg Brandl116aa622007-08-15 14:28:22 +000051 <WinDLL 'kernel32', handle ... at ...>
Georg Brandl6911e3c2007-09-04 07:15:32 +000052 >>> print(cdll.msvcrt) # doctest: +WINDOWS
Georg Brandl116aa622007-08-15 14:28:22 +000053 <CDLL 'msvcrt', handle ... at ...>
54 >>> libc = cdll.msvcrt # doctest: +WINDOWS
55 >>>
56
Thomas Heller2fadaa22008-06-16 19:56:33 +000057Windows appends the usual ``.dll`` file suffix automatically.
Georg Brandl116aa622007-08-15 14:28:22 +000058
59On Linux, it is required to specify the filename *including* the extension to
Thomas Heller2fadaa22008-06-16 19:56:33 +000060load a library, so attribute access can not be used to load libraries. Either the
Georg Brandl116aa622007-08-15 14:28:22 +000061:meth:`LoadLibrary` method of the dll loaders should be used, or you should load
62the library by creating an instance of CDLL by calling the constructor::
63
64 >>> cdll.LoadLibrary("libc.so.6") # doctest: +LINUX
65 <CDLL 'libc.so.6', handle ... at ...>
66 >>> libc = CDLL("libc.so.6") # doctest: +LINUX
67 >>> libc # doctest: +LINUX
68 <CDLL 'libc.so.6', handle ... at ...>
69 >>>
70
Christian Heimes5b5e81c2007-12-31 16:14:33 +000071.. XXX Add section for Mac OS X.
Georg Brandl116aa622007-08-15 14:28:22 +000072
73
74.. _ctypes-accessing-functions-from-loaded-dlls:
75
76Accessing functions from loaded dlls
77^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
78
79Functions are accessed as attributes of dll objects::
80
81 >>> from ctypes import *
82 >>> libc.printf
83 <_FuncPtr object at 0x...>
Georg Brandl6911e3c2007-09-04 07:15:32 +000084 >>> print(windll.kernel32.GetModuleHandleA) # doctest: +WINDOWS
Georg Brandl116aa622007-08-15 14:28:22 +000085 <_FuncPtr object at 0x...>
Georg Brandl6911e3c2007-09-04 07:15:32 +000086 >>> print(windll.kernel32.MyOwnFunction) # doctest: +WINDOWS
Georg Brandl116aa622007-08-15 14:28:22 +000087 Traceback (most recent call last):
88 File "<stdin>", line 1, in ?
89 File "ctypes.py", line 239, in __getattr__
90 func = _StdcallFuncPtr(name, self)
91 AttributeError: function 'MyOwnFunction' not found
92 >>>
93
94Note that win32 system dlls like ``kernel32`` and ``user32`` often export ANSI
95as well as UNICODE versions of a function. The UNICODE version is exported with
96an ``W`` appended to the name, while the ANSI version is exported with an ``A``
97appended to the name. The win32 ``GetModuleHandle`` function, which returns a
98*module handle* for a given module name, has the following C prototype, and a
99macro is used to expose one of them as ``GetModuleHandle`` depending on whether
100UNICODE is defined or not::
101
102 /* ANSI version */
103 HMODULE GetModuleHandleA(LPCSTR lpModuleName);
104 /* UNICODE version */
105 HMODULE GetModuleHandleW(LPCWSTR lpModuleName);
106
107*windll* does not try to select one of them by magic, you must access the
108version you need by specifying ``GetModuleHandleA`` or ``GetModuleHandleW``
Thomas Heller2fadaa22008-06-16 19:56:33 +0000109explicitly, and then call it with strings or unicode strings
Georg Brandl116aa622007-08-15 14:28:22 +0000110respectively.
111
112Sometimes, dlls export functions with names which aren't valid Python
113identifiers, like ``"??2@YAPAXI@Z"``. In this case you have to use ``getattr``
114to retrieve the function::
115
116 >>> getattr(cdll.msvcrt, "??2@YAPAXI@Z") # doctest: +WINDOWS
117 <_FuncPtr object at 0x...>
118 >>>
119
120On Windows, some dlls export functions not by name but by ordinal. These
121functions can be accessed by indexing the dll object with the ordinal number::
122
123 >>> cdll.kernel32[1] # doctest: +WINDOWS
124 <_FuncPtr object at 0x...>
125 >>> cdll.kernel32[0] # doctest: +WINDOWS
126 Traceback (most recent call last):
127 File "<stdin>", line 1, in ?
128 File "ctypes.py", line 310, in __getitem__
129 func = _StdcallFuncPtr(name, self)
130 AttributeError: function ordinal 0 not found
131 >>>
132
133
134.. _ctypes-calling-functions:
135
136Calling functions
137^^^^^^^^^^^^^^^^^
138
139You can call these functions like any other Python callable. This example uses
140the ``time()`` function, which returns system time in seconds since the Unix
141epoch, and the ``GetModuleHandleA()`` function, which returns a win32 module
142handle.
143
144This example calls both functions with a NULL pointer (``None`` should be used
145as the NULL pointer)::
146
Georg Brandl6911e3c2007-09-04 07:15:32 +0000147 >>> print(libc.time(None)) # doctest: +SKIP
Georg Brandl116aa622007-08-15 14:28:22 +0000148 1150640792
Georg Brandl6911e3c2007-09-04 07:15:32 +0000149 >>> print(hex(windll.kernel32.GetModuleHandleA(None))) # doctest: +WINDOWS
Georg Brandl116aa622007-08-15 14:28:22 +0000150 0x1d000000
151 >>>
152
153``ctypes`` tries to protect you from calling functions with the wrong number of
154arguments or the wrong calling convention. Unfortunately this only works on
155Windows. It does this by examining the stack after the function returns, so
156although an error is raised the function *has* been called::
157
158 >>> windll.kernel32.GetModuleHandleA() # doctest: +WINDOWS
159 Traceback (most recent call last):
160 File "<stdin>", line 1, in ?
161 ValueError: Procedure probably called with not enough arguments (4 bytes missing)
162 >>> windll.kernel32.GetModuleHandleA(0, 0) # doctest: +WINDOWS
163 Traceback (most recent call last):
164 File "<stdin>", line 1, in ?
165 ValueError: Procedure probably called with too many arguments (4 bytes in excess)
166 >>>
167
168The same exception is raised when you call an ``stdcall`` function with the
169``cdecl`` calling convention, or vice versa::
170
171 >>> cdll.kernel32.GetModuleHandleA(None) # doctest: +WINDOWS
172 Traceback (most recent call last):
173 File "<stdin>", line 1, in ?
174 ValueError: Procedure probably called with not enough arguments (4 bytes missing)
175 >>>
176
177 >>> windll.msvcrt.printf("spam") # doctest: +WINDOWS
178 Traceback (most recent call last):
179 File "<stdin>", line 1, in ?
180 ValueError: Procedure probably called with too many arguments (4 bytes in excess)
181 >>>
182
183To find out the correct calling convention you have to look into the C header
184file or the documentation for the function you want to call.
185
186On Windows, ``ctypes`` uses win32 structured exception handling to prevent
187crashes from general protection faults when functions are called with invalid
188argument values::
189
190 >>> windll.kernel32.GetModuleHandleA(32) # doctest: +WINDOWS
191 Traceback (most recent call last):
192 File "<stdin>", line 1, in ?
193 WindowsError: exception: access violation reading 0x00000020
194 >>>
195
196There are, however, enough ways to crash Python with ``ctypes``, so you should
197be careful anyway.
198
Georg Brandl5c106642007-11-29 17:41:05 +0000199``None``, integers, byte strings and unicode strings are the only native
Georg Brandl116aa622007-08-15 14:28:22 +0000200Python objects that can directly be used as parameters in these function calls.
201``None`` is passed as a C ``NULL`` pointer, byte strings and unicode strings are
202passed as pointer to the memory block that contains their data (``char *`` or
Georg Brandl5c106642007-11-29 17:41:05 +0000203``wchar_t *``). Python integers are passed as the platforms
Georg Brandl116aa622007-08-15 14:28:22 +0000204default C ``int`` type, their value is masked to fit into the C type.
205
206Before we move on calling functions with other parameter types, we have to learn
207more about ``ctypes`` data types.
208
209
210.. _ctypes-fundamental-data-types:
211
212Fundamental data types
213^^^^^^^^^^^^^^^^^^^^^^
214
215``ctypes`` defines a number of primitive C compatible data types :
216
217 +----------------------+--------------------------------+----------------------------+
218 | ctypes type | C type | Python type |
219 +======================+================================+============================+
220 | :class:`c_char` | ``char`` | 1-character string |
221 +----------------------+--------------------------------+----------------------------+
222 | :class:`c_wchar` | ``wchar_t`` | 1-character unicode string |
223 +----------------------+--------------------------------+----------------------------+
Georg Brandl5c106642007-11-29 17:41:05 +0000224 | :class:`c_byte` | ``char`` | int |
Georg Brandl116aa622007-08-15 14:28:22 +0000225 +----------------------+--------------------------------+----------------------------+
Georg Brandl5c106642007-11-29 17:41:05 +0000226 | :class:`c_ubyte` | ``unsigned char`` | int |
Georg Brandl116aa622007-08-15 14:28:22 +0000227 +----------------------+--------------------------------+----------------------------+
Georg Brandl5c106642007-11-29 17:41:05 +0000228 | :class:`c_short` | ``short`` | int |
Georg Brandl116aa622007-08-15 14:28:22 +0000229 +----------------------+--------------------------------+----------------------------+
Georg Brandl5c106642007-11-29 17:41:05 +0000230 | :class:`c_ushort` | ``unsigned short`` | int |
Georg Brandl116aa622007-08-15 14:28:22 +0000231 +----------------------+--------------------------------+----------------------------+
Georg Brandl5c106642007-11-29 17:41:05 +0000232 | :class:`c_int` | ``int`` | int |
Georg Brandl116aa622007-08-15 14:28:22 +0000233 +----------------------+--------------------------------+----------------------------+
Georg Brandl5c106642007-11-29 17:41:05 +0000234 | :class:`c_uint` | ``unsigned int`` | int |
Georg Brandl116aa622007-08-15 14:28:22 +0000235 +----------------------+--------------------------------+----------------------------+
Georg Brandl5c106642007-11-29 17:41:05 +0000236 | :class:`c_long` | ``long`` | int |
Georg Brandl116aa622007-08-15 14:28:22 +0000237 +----------------------+--------------------------------+----------------------------+
Georg Brandl5c106642007-11-29 17:41:05 +0000238 | :class:`c_ulong` | ``unsigned long`` | int |
Georg Brandl116aa622007-08-15 14:28:22 +0000239 +----------------------+--------------------------------+----------------------------+
Georg Brandl5c106642007-11-29 17:41:05 +0000240 | :class:`c_longlong` | ``__int64`` or ``long long`` | int |
Georg Brandl116aa622007-08-15 14:28:22 +0000241 +----------------------+--------------------------------+----------------------------+
Georg Brandl5c106642007-11-29 17:41:05 +0000242 | :class:`c_ulonglong` | ``unsigned __int64`` or | int |
Georg Brandl116aa622007-08-15 14:28:22 +0000243 | | ``unsigned long long`` | |
244 +----------------------+--------------------------------+----------------------------+
245 | :class:`c_float` | ``float`` | float |
246 +----------------------+--------------------------------+----------------------------+
247 | :class:`c_double` | ``double`` | float |
248 +----------------------+--------------------------------+----------------------------+
Thomas Wouters89d996e2007-09-08 17:39:28 +0000249 | :class:`c_longdouble`| ``long double`` | float |
250 +----------------------+--------------------------------+----------------------------+
Georg Brandl116aa622007-08-15 14:28:22 +0000251 | :class:`c_char_p` | ``char *`` (NUL terminated) | string or ``None`` |
252 +----------------------+--------------------------------+----------------------------+
253 | :class:`c_wchar_p` | ``wchar_t *`` (NUL terminated) | unicode or ``None`` |
254 +----------------------+--------------------------------+----------------------------+
Georg Brandl5c106642007-11-29 17:41:05 +0000255 | :class:`c_void_p` | ``void *`` | int or ``None`` |
Georg Brandl116aa622007-08-15 14:28:22 +0000256 +----------------------+--------------------------------+----------------------------+
257
258
259All these types can be created by calling them with an optional initializer of
260the correct type and value::
261
262 >>> c_int()
263 c_long(0)
264 >>> c_char_p("Hello, World")
265 c_char_p('Hello, World')
266 >>> c_ushort(-3)
267 c_ushort(65533)
268 >>>
269
270Since these types are mutable, their value can also be changed afterwards::
271
272 >>> i = c_int(42)
Georg Brandl6911e3c2007-09-04 07:15:32 +0000273 >>> print(i)
Georg Brandl116aa622007-08-15 14:28:22 +0000274 c_long(42)
Georg Brandl6911e3c2007-09-04 07:15:32 +0000275 >>> print(i.value)
Georg Brandl116aa622007-08-15 14:28:22 +0000276 42
277 >>> i.value = -99
Georg Brandl6911e3c2007-09-04 07:15:32 +0000278 >>> print(i.value)
Georg Brandl116aa622007-08-15 14:28:22 +0000279 -99
280 >>>
281
282Assigning a new value to instances of the pointer types :class:`c_char_p`,
283:class:`c_wchar_p`, and :class:`c_void_p` changes the *memory location* they
284point to, *not the contents* of the memory block (of course not, because Python
285strings are immutable)::
286
287 >>> s = "Hello, World"
288 >>> c_s = c_char_p(s)
Georg Brandl6911e3c2007-09-04 07:15:32 +0000289 >>> print(c_s)
Georg Brandl116aa622007-08-15 14:28:22 +0000290 c_char_p('Hello, World')
291 >>> c_s.value = "Hi, there"
Georg Brandl6911e3c2007-09-04 07:15:32 +0000292 >>> print(c_s)
Georg Brandl116aa622007-08-15 14:28:22 +0000293 c_char_p('Hi, there')
Georg Brandl6911e3c2007-09-04 07:15:32 +0000294 >>> print(s) # first string is unchanged
Georg Brandl116aa622007-08-15 14:28:22 +0000295 Hello, World
296 >>>
297
298You should be careful, however, not to pass them to functions expecting pointers
299to mutable memory. If you need mutable memory blocks, ctypes has a
300``create_string_buffer`` function which creates these in various ways. The
301current memory block contents can be accessed (or changed) with the ``raw``
302property; if you want to access it as NUL terminated string, use the ``value``
303property::
304
305 >>> from ctypes import *
306 >>> p = create_string_buffer(3) # create a 3 byte buffer, initialized to NUL bytes
Georg Brandl6911e3c2007-09-04 07:15:32 +0000307 >>> print(sizeof(p), repr(p.raw))
Georg Brandl116aa622007-08-15 14:28:22 +0000308 3 '\x00\x00\x00'
309 >>> p = create_string_buffer("Hello") # create a buffer containing a NUL terminated string
Georg Brandl6911e3c2007-09-04 07:15:32 +0000310 >>> print(sizeof(p), repr(p.raw))
Georg Brandl116aa622007-08-15 14:28:22 +0000311 6 'Hello\x00'
Georg Brandl6911e3c2007-09-04 07:15:32 +0000312 >>> print(repr(p.value))
Georg Brandl116aa622007-08-15 14:28:22 +0000313 'Hello'
314 >>> p = create_string_buffer("Hello", 10) # create a 10 byte buffer
Georg Brandl6911e3c2007-09-04 07:15:32 +0000315 >>> print(sizeof(p), repr(p.raw))
Georg Brandl116aa622007-08-15 14:28:22 +0000316 10 'Hello\x00\x00\x00\x00\x00'
Benjamin Peterson3e4f0552008-09-02 00:31:15 +0000317 >>> p.value = "Hi"
Georg Brandl6911e3c2007-09-04 07:15:32 +0000318 >>> print(sizeof(p), repr(p.raw))
Georg Brandl116aa622007-08-15 14:28:22 +0000319 10 'Hi\x00lo\x00\x00\x00\x00\x00'
320 >>>
321
322The ``create_string_buffer`` function replaces the ``c_buffer`` function (which
323is still available as an alias), as well as the ``c_string`` function from
324earlier ctypes releases. To create a mutable memory block containing unicode
325characters of the C type ``wchar_t`` use the ``create_unicode_buffer`` function.
326
327
328.. _ctypes-calling-functions-continued:
329
330Calling functions, continued
331^^^^^^^^^^^^^^^^^^^^^^^^^^^^
332
333Note that printf prints to the real standard output channel, *not* to
334``sys.stdout``, so these examples will only work at the console prompt, not from
335within *IDLE* or *PythonWin*::
336
337 >>> printf = libc.printf
338 >>> printf("Hello, %s\n", "World!")
339 Hello, World!
340 14
Georg Brandl8a1e4c42009-05-25 21:13:36 +0000341 >>> printf("Hello, %S\n", u"World!")
Georg Brandl116aa622007-08-15 14:28:22 +0000342 Hello, World!
Georg Brandl8a1e4c42009-05-25 21:13:36 +0000343 14
Georg Brandl116aa622007-08-15 14:28:22 +0000344 >>> printf("%d bottles of beer\n", 42)
345 42 bottles of beer
346 19
347 >>> printf("%f bottles of beer\n", 42.5)
348 Traceback (most recent call last):
349 File "<stdin>", line 1, in ?
350 ArgumentError: argument 2: exceptions.TypeError: Don't know how to convert parameter 2
351 >>>
352
353As has been mentioned before, all Python types except integers, strings, and
354unicode strings have to be wrapped in their corresponding ``ctypes`` type, so
355that they can be converted to the required C data type::
356
357 >>> printf("An int %d, a double %f\n", 1234, c_double(3.14))
Georg Brandl8a1e4c42009-05-25 21:13:36 +0000358 An int 1234, a double 3.140000
Georg Brandl116aa622007-08-15 14:28:22 +0000359 31
360 >>>
361
362
363.. _ctypes-calling-functions-with-own-custom-data-types:
364
365Calling functions with your own custom data types
366^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
367
368You can also customize ``ctypes`` argument conversion to allow instances of your
369own classes be used as function arguments. ``ctypes`` looks for an
370:attr:`_as_parameter_` attribute and uses this as the function argument. Of
371course, it must be one of integer, string, or unicode::
372
373 >>> class Bottles(object):
374 ... def __init__(self, number):
375 ... self._as_parameter_ = number
376 ...
377 >>> bottles = Bottles(42)
378 >>> printf("%d bottles of beer\n", bottles)
379 42 bottles of beer
380 19
381 >>>
382
383If you don't want to store the instance's data in the :attr:`_as_parameter_`
384instance variable, you could define a ``property`` which makes the data
Thomas Woutersed03b412007-08-28 21:37:11 +0000385available.
Georg Brandl116aa622007-08-15 14:28:22 +0000386
387
388.. _ctypes-specifying-required-argument-types:
389
390Specifying the required argument types (function prototypes)
391^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
392
393It is possible to specify the required argument types of functions exported from
394DLLs by setting the :attr:`argtypes` attribute.
395
396:attr:`argtypes` must be a sequence of C data types (the ``printf`` function is
397probably not a good example here, because it takes a variable number and
398different types of parameters depending on the format string, on the other hand
399this is quite handy to experiment with this feature)::
400
401 >>> printf.argtypes = [c_char_p, c_char_p, c_int, c_double]
402 >>> printf("String '%s', Int %d, Double %f\n", "Hi", 10, 2.2)
403 String 'Hi', Int 10, Double 2.200000
404 37
405 >>>
406
407Specifying a format protects against incompatible argument types (just as a
408prototype for a C function), and tries to convert the arguments to valid types::
409
410 >>> printf("%d %d %d", 1, 2, 3)
411 Traceback (most recent call last):
412 File "<stdin>", line 1, in ?
413 ArgumentError: argument 2: exceptions.TypeError: wrong type
Georg Brandl8a1e4c42009-05-25 21:13:36 +0000414 >>> printf("%s %d %f\n", "X", 2, 3)
415 X 2 3.000000
416 13
Georg Brandl116aa622007-08-15 14:28:22 +0000417 >>>
418
419If you have defined your own classes which you pass to function calls, you have
420to implement a :meth:`from_param` class method for them to be able to use them
421in the :attr:`argtypes` sequence. The :meth:`from_param` class method receives
422the Python object passed to the function call, it should do a typecheck or
423whatever is needed to make sure this object is acceptable, and then return the
Thomas Heller2fadaa22008-06-16 19:56:33 +0000424object itself, its :attr:`_as_parameter_` attribute, or whatever you want to
Georg Brandl116aa622007-08-15 14:28:22 +0000425pass as the C function argument in this case. Again, the result should be an
Thomas Heller2fadaa22008-06-16 19:56:33 +0000426integer, string, unicode, a ``ctypes`` instance, or an object with an
Georg Brandl116aa622007-08-15 14:28:22 +0000427:attr:`_as_parameter_` attribute.
428
429
430.. _ctypes-return-types:
431
432Return types
433^^^^^^^^^^^^
434
435By default functions are assumed to return the C ``int`` type. Other return
436types can be specified by setting the :attr:`restype` attribute of the function
437object.
438
439Here is a more advanced example, it uses the ``strchr`` function, which expects
440a string pointer and a char, and returns a pointer to a string::
441
442 >>> strchr = libc.strchr
443 >>> strchr("abcdef", ord("d")) # doctest: +SKIP
444 8059983
445 >>> strchr.restype = c_char_p # c_char_p is a pointer to a string
446 >>> strchr("abcdef", ord("d"))
447 'def'
Georg Brandl6911e3c2007-09-04 07:15:32 +0000448 >>> print(strchr("abcdef", ord("x")))
Georg Brandl116aa622007-08-15 14:28:22 +0000449 None
450 >>>
451
452If you want to avoid the ``ord("x")`` calls above, you can set the
453:attr:`argtypes` attribute, and the second argument will be converted from a
454single character Python string into a C char::
455
456 >>> strchr.restype = c_char_p
457 >>> strchr.argtypes = [c_char_p, c_char]
458 >>> strchr("abcdef", "d")
459 'def'
460 >>> strchr("abcdef", "def")
461 Traceback (most recent call last):
462 File "<stdin>", line 1, in ?
463 ArgumentError: argument 2: exceptions.TypeError: one character string expected
Georg Brandl6911e3c2007-09-04 07:15:32 +0000464 >>> print(strchr("abcdef", "x"))
Georg Brandl116aa622007-08-15 14:28:22 +0000465 None
466 >>> strchr("abcdef", "d")
467 'def'
468 >>>
469
470You can also use a callable Python object (a function or a class for example) as
471the :attr:`restype` attribute, if the foreign function returns an integer. The
472callable will be called with the ``integer`` the C function returns, and the
473result of this call will be used as the result of your function call. This is
474useful to check for error return values and automatically raise an exception::
475
476 >>> GetModuleHandle = windll.kernel32.GetModuleHandleA # doctest: +WINDOWS
477 >>> def ValidHandle(value):
478 ... if value == 0:
479 ... raise WinError()
480 ... return value
481 ...
482 >>>
483 >>> GetModuleHandle.restype = ValidHandle # doctest: +WINDOWS
484 >>> GetModuleHandle(None) # doctest: +WINDOWS
485 486539264
486 >>> GetModuleHandle("something silly") # doctest: +WINDOWS
487 Traceback (most recent call last):
488 File "<stdin>", line 1, in ?
489 File "<stdin>", line 3, in ValidHandle
490 WindowsError: [Errno 126] The specified module could not be found.
491 >>>
492
493``WinError`` is a function which will call Windows ``FormatMessage()`` api to
494get the string representation of an error code, and *returns* an exception.
495``WinError`` takes an optional error code parameter, if no one is used, it calls
496:func:`GetLastError` to retrieve it.
497
498Please note that a much more powerful error checking mechanism is available
499through the :attr:`errcheck` attribute; see the reference manual for details.
500
501
502.. _ctypes-passing-pointers:
503
504Passing pointers (or: passing parameters by reference)
505^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
506
507Sometimes a C api function expects a *pointer* to a data type as parameter,
508probably to write into the corresponding location, or if the data is too large
509to be passed by value. This is also known as *passing parameters by reference*.
510
511``ctypes`` exports the :func:`byref` function which is used to pass parameters
512by reference. The same effect can be achieved with the ``pointer`` function,
513although ``pointer`` does a lot more work since it constructs a real pointer
514object, so it is faster to use :func:`byref` if you don't need the pointer
515object in Python itself::
516
517 >>> i = c_int()
518 >>> f = c_float()
519 >>> s = create_string_buffer('\000' * 32)
Georg Brandl6911e3c2007-09-04 07:15:32 +0000520 >>> print(i.value, f.value, repr(s.value))
Georg Brandl116aa622007-08-15 14:28:22 +0000521 0 0.0 ''
522 >>> libc.sscanf("1 3.14 Hello", "%d %f %s",
523 ... byref(i), byref(f), s)
524 3
Georg Brandl6911e3c2007-09-04 07:15:32 +0000525 >>> print(i.value, f.value, repr(s.value))
Georg Brandl116aa622007-08-15 14:28:22 +0000526 1 3.1400001049 'Hello'
527 >>>
528
529
530.. _ctypes-structures-unions:
531
532Structures and unions
533^^^^^^^^^^^^^^^^^^^^^
534
535Structures and unions must derive from the :class:`Structure` and :class:`Union`
536base classes which are defined in the ``ctypes`` module. Each subclass must
537define a :attr:`_fields_` attribute. :attr:`_fields_` must be a list of
538*2-tuples*, containing a *field name* and a *field type*.
539
540The field type must be a ``ctypes`` type like :class:`c_int`, or any other
541derived ``ctypes`` type: structure, union, array, pointer.
542
543Here is a simple example of a POINT structure, which contains two integers named
544``x`` and ``y``, and also shows how to initialize a structure in the
545constructor::
546
547 >>> from ctypes import *
548 >>> class POINT(Structure):
549 ... _fields_ = [("x", c_int),
550 ... ("y", c_int)]
551 ...
552 >>> point = POINT(10, 20)
Georg Brandl6911e3c2007-09-04 07:15:32 +0000553 >>> print(point.x, point.y)
Georg Brandl116aa622007-08-15 14:28:22 +0000554 10 20
555 >>> point = POINT(y=5)
Georg Brandl6911e3c2007-09-04 07:15:32 +0000556 >>> print(point.x, point.y)
Georg Brandl116aa622007-08-15 14:28:22 +0000557 0 5
558 >>> POINT(1, 2, 3)
559 Traceback (most recent call last):
560 File "<stdin>", line 1, in ?
561 ValueError: too many initializers
562 >>>
563
564You can, however, build much more complicated structures. Structures can itself
565contain other structures by using a structure as a field type.
566
567Here is a RECT structure which contains two POINTs named ``upperleft`` and
568``lowerright`` ::
569
570 >>> class RECT(Structure):
571 ... _fields_ = [("upperleft", POINT),
572 ... ("lowerright", POINT)]
573 ...
574 >>> rc = RECT(point)
Georg Brandl6911e3c2007-09-04 07:15:32 +0000575 >>> print(rc.upperleft.x, rc.upperleft.y)
Georg Brandl116aa622007-08-15 14:28:22 +0000576 0 5
Georg Brandl6911e3c2007-09-04 07:15:32 +0000577 >>> print(rc.lowerright.x, rc.lowerright.y)
Georg Brandl116aa622007-08-15 14:28:22 +0000578 0 0
579 >>>
580
581Nested structures can also be initialized in the constructor in several ways::
582
583 >>> r = RECT(POINT(1, 2), POINT(3, 4))
584 >>> r = RECT((1, 2), (3, 4))
585
Georg Brandl9afde1c2007-11-01 20:32:30 +0000586Field :term:`descriptor`\s can be retrieved from the *class*, they are useful
587for debugging because they can provide useful information::
Georg Brandl116aa622007-08-15 14:28:22 +0000588
Georg Brandl6911e3c2007-09-04 07:15:32 +0000589 >>> print(POINT.x)
Georg Brandl116aa622007-08-15 14:28:22 +0000590 <Field type=c_long, ofs=0, size=4>
Georg Brandl6911e3c2007-09-04 07:15:32 +0000591 >>> print(POINT.y)
Georg Brandl116aa622007-08-15 14:28:22 +0000592 <Field type=c_long, ofs=4, size=4>
593 >>>
594
595
596.. _ctypes-structureunion-alignment-byte-order:
597
598Structure/union alignment and byte order
599^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
600
601By default, Structure and Union fields are aligned in the same way the C
Thomas Woutersed03b412007-08-28 21:37:11 +0000602compiler does it. It is possible to override this behavior be specifying a
Georg Brandl116aa622007-08-15 14:28:22 +0000603:attr:`_pack_` class attribute in the subclass definition. This must be set to a
604positive integer and specifies the maximum alignment for the fields. This is
605what ``#pragma pack(n)`` also does in MSVC.
606
607``ctypes`` uses the native byte order for Structures and Unions. To build
608structures with non-native byte order, you can use one of the
609BigEndianStructure, LittleEndianStructure, BigEndianUnion, and LittleEndianUnion
610base classes. These classes cannot contain pointer fields.
611
612
613.. _ctypes-bit-fields-in-structures-unions:
614
615Bit fields in structures and unions
616^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
617
618It is possible to create structures and unions containing bit fields. Bit fields
619are only possible for integer fields, the bit width is specified as the third
620item in the :attr:`_fields_` tuples::
621
622 >>> class Int(Structure):
623 ... _fields_ = [("first_16", c_int, 16),
624 ... ("second_16", c_int, 16)]
625 ...
Georg Brandl6911e3c2007-09-04 07:15:32 +0000626 >>> print(Int.first_16)
Georg Brandl116aa622007-08-15 14:28:22 +0000627 <Field type=c_long, ofs=0:0, bits=16>
Georg Brandl6911e3c2007-09-04 07:15:32 +0000628 >>> print(Int.second_16)
Georg Brandl116aa622007-08-15 14:28:22 +0000629 <Field type=c_long, ofs=0:16, bits=16>
630 >>>
631
632
633.. _ctypes-arrays:
634
635Arrays
636^^^^^^
637
638Arrays are sequences, containing a fixed number of instances of the same type.
639
640The recommended way to create array types is by multiplying a data type with a
641positive integer::
642
643 TenPointsArrayType = POINT * 10
644
Thomas Woutersed03b412007-08-28 21:37:11 +0000645Here is an example of an somewhat artificial data type, a structure containing 4
Georg Brandl116aa622007-08-15 14:28:22 +0000646POINTs among other stuff::
647
648 >>> from ctypes import *
649 >>> class POINT(Structure):
650 ... _fields_ = ("x", c_int), ("y", c_int)
651 ...
652 >>> class MyStruct(Structure):
653 ... _fields_ = [("a", c_int),
654 ... ("b", c_float),
655 ... ("point_array", POINT * 4)]
656 >>>
Georg Brandl6911e3c2007-09-04 07:15:32 +0000657 >>> print(len(MyStruct().point_array))
Georg Brandl116aa622007-08-15 14:28:22 +0000658 4
659 >>>
660
661Instances are created in the usual way, by calling the class::
662
663 arr = TenPointsArrayType()
664 for pt in arr:
Georg Brandl6911e3c2007-09-04 07:15:32 +0000665 print(pt.x, pt.y)
Georg Brandl116aa622007-08-15 14:28:22 +0000666
667The above code print a series of ``0 0`` lines, because the array contents is
668initialized to zeros.
669
670Initializers of the correct type can also be specified::
671
672 >>> from ctypes import *
673 >>> TenIntegers = c_int * 10
674 >>> ii = TenIntegers(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
Georg Brandl6911e3c2007-09-04 07:15:32 +0000675 >>> print(ii)
Georg Brandl116aa622007-08-15 14:28:22 +0000676 <c_long_Array_10 object at 0x...>
Georg Brandl6911e3c2007-09-04 07:15:32 +0000677 >>> for i in ii: print(i, end=" ")
Georg Brandl116aa622007-08-15 14:28:22 +0000678 ...
679 1 2 3 4 5 6 7 8 9 10
680 >>>
681
682
683.. _ctypes-pointers:
684
685Pointers
686^^^^^^^^
687
688Pointer instances are created by calling the ``pointer`` function on a
689``ctypes`` type::
690
691 >>> from ctypes import *
692 >>> i = c_int(42)
693 >>> pi = pointer(i)
694 >>>
695
696Pointer instances have a ``contents`` attribute which returns the object to
697which the pointer points, the ``i`` object above::
698
699 >>> pi.contents
700 c_long(42)
701 >>>
702
703Note that ``ctypes`` does not have OOR (original object return), it constructs a
704new, equivalent object each time you retrieve an attribute::
705
706 >>> pi.contents is i
707 False
708 >>> pi.contents is pi.contents
709 False
710 >>>
711
712Assigning another :class:`c_int` instance to the pointer's contents attribute
713would cause the pointer to point to the memory location where this is stored::
714
715 >>> i = c_int(99)
716 >>> pi.contents = i
717 >>> pi.contents
718 c_long(99)
719 >>>
720
Thomas Heller2fadaa22008-06-16 19:56:33 +0000721.. XXX Document dereferencing pointers, and that it is preferred over the .contents attribute.
722
Georg Brandl116aa622007-08-15 14:28:22 +0000723Pointer instances can also be indexed with integers::
724
725 >>> pi[0]
726 99
727 >>>
728
729Assigning to an integer index changes the pointed to value::
730
Georg Brandl6911e3c2007-09-04 07:15:32 +0000731 >>> print(i)
Georg Brandl116aa622007-08-15 14:28:22 +0000732 c_long(99)
733 >>> pi[0] = 22
Georg Brandl6911e3c2007-09-04 07:15:32 +0000734 >>> print(i)
Georg Brandl116aa622007-08-15 14:28:22 +0000735 c_long(22)
736 >>>
737
738It is also possible to use indexes different from 0, but you must know what
739you're doing, just as in C: You can access or change arbitrary memory locations.
740Generally you only use this feature if you receive a pointer from a C function,
741and you *know* that the pointer actually points to an array instead of a single
742item.
743
744Behind the scenes, the ``pointer`` function does more than simply create pointer
745instances, it has to create pointer *types* first. This is done with the
746``POINTER`` function, which accepts any ``ctypes`` type, and returns a new
747type::
748
749 >>> PI = POINTER(c_int)
750 >>> PI
751 <class 'ctypes.LP_c_long'>
752 >>> PI(42)
753 Traceback (most recent call last):
754 File "<stdin>", line 1, in ?
755 TypeError: expected c_long instead of int
756 >>> PI(c_int(42))
757 <ctypes.LP_c_long object at 0x...>
758 >>>
759
760Calling the pointer type without an argument creates a ``NULL`` pointer.
761``NULL`` pointers have a ``False`` boolean value::
762
763 >>> null_ptr = POINTER(c_int)()
Georg Brandl6911e3c2007-09-04 07:15:32 +0000764 >>> print(bool(null_ptr))
Georg Brandl116aa622007-08-15 14:28:22 +0000765 False
766 >>>
767
768``ctypes`` checks for ``NULL`` when dereferencing pointers (but dereferencing
Thomas Heller2fadaa22008-06-16 19:56:33 +0000769invalid non-\ ``NULL`` pointers would crash Python)::
Georg Brandl116aa622007-08-15 14:28:22 +0000770
771 >>> null_ptr[0]
772 Traceback (most recent call last):
773 ....
774 ValueError: NULL pointer access
775 >>>
776
777 >>> null_ptr[0] = 1234
778 Traceback (most recent call last):
779 ....
780 ValueError: NULL pointer access
781 >>>
782
783
784.. _ctypes-type-conversions:
785
786Type conversions
787^^^^^^^^^^^^^^^^
788
789Usually, ctypes does strict type checking. This means, if you have
790``POINTER(c_int)`` in the :attr:`argtypes` list of a function or as the type of
791a member field in a structure definition, only instances of exactly the same
792type are accepted. There are some exceptions to this rule, where ctypes accepts
793other objects. For example, you can pass compatible array instances instead of
794pointer types. So, for ``POINTER(c_int)``, ctypes accepts an array of c_int::
795
796 >>> class Bar(Structure):
797 ... _fields_ = [("count", c_int), ("values", POINTER(c_int))]
798 ...
799 >>> bar = Bar()
800 >>> bar.values = (c_int * 3)(1, 2, 3)
801 >>> bar.count = 3
802 >>> for i in range(bar.count):
Georg Brandl6911e3c2007-09-04 07:15:32 +0000803 ... print(bar.values[i])
Georg Brandl116aa622007-08-15 14:28:22 +0000804 ...
805 1
806 2
807 3
808 >>>
809
810To set a POINTER type field to ``NULL``, you can assign ``None``::
811
812 >>> bar.values = None
813 >>>
814
Thomas Heller2fadaa22008-06-16 19:56:33 +0000815.. XXX list other conversions...
Georg Brandl116aa622007-08-15 14:28:22 +0000816
Thomas Heller2fadaa22008-06-16 19:56:33 +0000817Sometimes you have instances of incompatible types. In C, you can cast one
Georg Brandl116aa622007-08-15 14:28:22 +0000818type into another type. ``ctypes`` provides a ``cast`` function which can be
819used in the same way. The ``Bar`` structure defined above accepts
820``POINTER(c_int)`` pointers or :class:`c_int` arrays for its ``values`` field,
821but not instances of other types::
822
823 >>> bar.values = (c_byte * 4)()
824 Traceback (most recent call last):
825 File "<stdin>", line 1, in ?
826 TypeError: incompatible types, c_byte_Array_4 instance instead of LP_c_long instance
827 >>>
828
829For these cases, the ``cast`` function is handy.
830
831The ``cast`` function can be used to cast a ctypes instance into a pointer to a
832different ctypes data type. ``cast`` takes two parameters, a ctypes object that
833is or can be converted to a pointer of some kind, and a ctypes pointer type. It
834returns an instance of the second argument, which references the same memory
835block as the first argument::
836
837 >>> a = (c_byte * 4)()
838 >>> cast(a, POINTER(c_int))
839 <ctypes.LP_c_long object at ...>
840 >>>
841
842So, ``cast`` can be used to assign to the ``values`` field of ``Bar`` the
843structure::
844
845 >>> bar = Bar()
846 >>> bar.values = cast((c_byte * 4)(), POINTER(c_int))
Georg Brandl6911e3c2007-09-04 07:15:32 +0000847 >>> print(bar.values[0])
Georg Brandl116aa622007-08-15 14:28:22 +0000848 0
849 >>>
850
851
852.. _ctypes-incomplete-types:
853
854Incomplete Types
855^^^^^^^^^^^^^^^^
856
857*Incomplete Types* are structures, unions or arrays whose members are not yet
858specified. In C, they are specified by forward declarations, which are defined
859later::
860
861 struct cell; /* forward declaration */
862
863 struct {
864 char *name;
865 struct cell *next;
866 } cell;
867
868The straightforward translation into ctypes code would be this, but it does not
869work::
870
871 >>> class cell(Structure):
872 ... _fields_ = [("name", c_char_p),
873 ... ("next", POINTER(cell))]
874 ...
875 Traceback (most recent call last):
876 File "<stdin>", line 1, in ?
877 File "<stdin>", line 2, in cell
878 NameError: name 'cell' is not defined
879 >>>
880
881because the new ``class cell`` is not available in the class statement itself.
882In ``ctypes``, we can define the ``cell`` class and set the :attr:`_fields_`
883attribute later, after the class statement::
884
885 >>> from ctypes import *
886 >>> class cell(Structure):
887 ... pass
888 ...
889 >>> cell._fields_ = [("name", c_char_p),
890 ... ("next", POINTER(cell))]
891 >>>
892
893Lets try it. We create two instances of ``cell``, and let them point to each
894other, and finally follow the pointer chain a few times::
895
896 >>> c1 = cell()
897 >>> c1.name = "foo"
898 >>> c2 = cell()
899 >>> c2.name = "bar"
900 >>> c1.next = pointer(c2)
901 >>> c2.next = pointer(c1)
902 >>> p = c1
903 >>> for i in range(8):
Georg Brandl6911e3c2007-09-04 07:15:32 +0000904 ... print(p.name, end=" ")
Georg Brandl116aa622007-08-15 14:28:22 +0000905 ... p = p.next[0]
906 ...
907 foo bar foo bar foo bar foo bar
Benjamin Peterson3e4f0552008-09-02 00:31:15 +0000908 >>>
Georg Brandl116aa622007-08-15 14:28:22 +0000909
910
911.. _ctypes-callback-functions:
912
913Callback functions
914^^^^^^^^^^^^^^^^^^
915
916``ctypes`` allows to create C callable function pointers from Python callables.
917These are sometimes called *callback functions*.
918
919First, you must create a class for the callback function, the class knows the
920calling convention, the return type, and the number and types of arguments this
921function will receive.
922
923The CFUNCTYPE factory function creates types for callback functions using the
924normal cdecl calling convention, and, on Windows, the WINFUNCTYPE factory
925function creates types for callback functions using the stdcall calling
926convention.
927
928Both of these factory functions are called with the result type as first
929argument, and the callback functions expected argument types as the remaining
930arguments.
931
932I will present an example here which uses the standard C library's :func:`qsort`
933function, this is used to sort items with the help of a callback function.
934:func:`qsort` will be used to sort an array of integers::
935
936 >>> IntArray5 = c_int * 5
937 >>> ia = IntArray5(5, 1, 7, 33, 99)
938 >>> qsort = libc.qsort
939 >>> qsort.restype = None
940 >>>
941
942:func:`qsort` must be called with a pointer to the data to sort, the number of
943items in the data array, the size of one item, and a pointer to the comparison
944function, the callback. The callback will then be called with two pointers to
945items, and it must return a negative integer if the first item is smaller than
946the second, a zero if they are equal, and a positive integer else.
947
948So our callback function receives pointers to integers, and must return an
949integer. First we create the ``type`` for the callback function::
950
951 >>> CMPFUNC = CFUNCTYPE(c_int, POINTER(c_int), POINTER(c_int))
952 >>>
953
954For the first implementation of the callback function, we simply print the
955arguments we get, and return 0 (incremental development ;-)::
956
957 >>> def py_cmp_func(a, b):
Georg Brandl6911e3c2007-09-04 07:15:32 +0000958 ... print("py_cmp_func", a, b)
Georg Brandl116aa622007-08-15 14:28:22 +0000959 ... return 0
960 ...
961 >>>
962
963Create the C callable callback::
964
965 >>> cmp_func = CMPFUNC(py_cmp_func)
966 >>>
967
968And we're ready to go::
969
970 >>> qsort(ia, len(ia), sizeof(c_int), cmp_func) # doctest: +WINDOWS
971 py_cmp_func <ctypes.LP_c_long object at 0x00...> <ctypes.LP_c_long object at 0x00...>
972 py_cmp_func <ctypes.LP_c_long object at 0x00...> <ctypes.LP_c_long object at 0x00...>
973 py_cmp_func <ctypes.LP_c_long object at 0x00...> <ctypes.LP_c_long object at 0x00...>
974 py_cmp_func <ctypes.LP_c_long object at 0x00...> <ctypes.LP_c_long object at 0x00...>
975 py_cmp_func <ctypes.LP_c_long object at 0x00...> <ctypes.LP_c_long object at 0x00...>
976 py_cmp_func <ctypes.LP_c_long object at 0x00...> <ctypes.LP_c_long object at 0x00...>
977 py_cmp_func <ctypes.LP_c_long object at 0x00...> <ctypes.LP_c_long object at 0x00...>
978 py_cmp_func <ctypes.LP_c_long object at 0x00...> <ctypes.LP_c_long object at 0x00...>
979 py_cmp_func <ctypes.LP_c_long object at 0x00...> <ctypes.LP_c_long object at 0x00...>
980 py_cmp_func <ctypes.LP_c_long object at 0x00...> <ctypes.LP_c_long object at 0x00...>
981 >>>
982
983We know how to access the contents of a pointer, so lets redefine our callback::
984
985 >>> def py_cmp_func(a, b):
Georg Brandl6911e3c2007-09-04 07:15:32 +0000986 ... print("py_cmp_func", a[0], b[0])
Georg Brandl116aa622007-08-15 14:28:22 +0000987 ... return 0
988 ...
989 >>> cmp_func = CMPFUNC(py_cmp_func)
990 >>>
991
992Here is what we get on Windows::
993
994 >>> qsort(ia, len(ia), sizeof(c_int), cmp_func) # doctest: +WINDOWS
995 py_cmp_func 7 1
996 py_cmp_func 33 1
997 py_cmp_func 99 1
998 py_cmp_func 5 1
999 py_cmp_func 7 5
1000 py_cmp_func 33 5
1001 py_cmp_func 99 5
1002 py_cmp_func 7 99
1003 py_cmp_func 33 99
1004 py_cmp_func 7 33
1005 >>>
1006
1007It is funny to see that on linux the sort function seems to work much more
1008efficient, it is doing less comparisons::
1009
1010 >>> qsort(ia, len(ia), sizeof(c_int), cmp_func) # doctest: +LINUX
1011 py_cmp_func 5 1
1012 py_cmp_func 33 99
1013 py_cmp_func 7 33
1014 py_cmp_func 5 7
1015 py_cmp_func 1 7
1016 >>>
1017
1018Ah, we're nearly done! The last step is to actually compare the two items and
1019return a useful result::
1020
1021 >>> def py_cmp_func(a, b):
Georg Brandl6911e3c2007-09-04 07:15:32 +00001022 ... print("py_cmp_func", a[0], b[0])
Georg Brandl116aa622007-08-15 14:28:22 +00001023 ... return a[0] - b[0]
1024 ...
1025 >>>
1026
1027Final run on Windows::
1028
1029 >>> qsort(ia, len(ia), sizeof(c_int), CMPFUNC(py_cmp_func)) # doctest: +WINDOWS
1030 py_cmp_func 33 7
1031 py_cmp_func 99 33
1032 py_cmp_func 5 99
1033 py_cmp_func 1 99
1034 py_cmp_func 33 7
1035 py_cmp_func 1 33
1036 py_cmp_func 5 33
1037 py_cmp_func 5 7
1038 py_cmp_func 1 7
1039 py_cmp_func 5 1
1040 >>>
1041
1042and on Linux::
1043
1044 >>> qsort(ia, len(ia), sizeof(c_int), CMPFUNC(py_cmp_func)) # doctest: +LINUX
1045 py_cmp_func 5 1
1046 py_cmp_func 33 99
1047 py_cmp_func 7 33
1048 py_cmp_func 1 7
1049 py_cmp_func 5 7
1050 >>>
1051
1052It is quite interesting to see that the Windows :func:`qsort` function needs
1053more comparisons than the linux version!
1054
1055As we can easily check, our array is sorted now::
1056
Georg Brandl6911e3c2007-09-04 07:15:32 +00001057 >>> for i in ia: print(i, end=" ")
Georg Brandl116aa622007-08-15 14:28:22 +00001058 ...
1059 1 5 7 33 99
1060 >>>
1061
1062**Important note for callback functions:**
1063
1064Make sure you keep references to CFUNCTYPE objects as long as they are used from
1065C code. ``ctypes`` doesn't, and if you don't, they may be garbage collected,
1066crashing your program when a callback is made.
1067
1068
1069.. _ctypes-accessing-values-exported-from-dlls:
1070
1071Accessing values exported from dlls
1072^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1073
Thomas Heller2fadaa22008-06-16 19:56:33 +00001074Some shared libraries not only export functions, they also export variables. An
Georg Brandl116aa622007-08-15 14:28:22 +00001075example in the Python library itself is the ``Py_OptimizeFlag``, an integer set
1076to 0, 1, or 2, depending on the :option:`-O` or :option:`-OO` flag given on
1077startup.
1078
1079``ctypes`` can access values like this with the :meth:`in_dll` class methods of
1080the type. *pythonapi* is a predefined symbol giving access to the Python C
1081api::
1082
1083 >>> opt_flag = c_int.in_dll(pythonapi, "Py_OptimizeFlag")
Georg Brandl6911e3c2007-09-04 07:15:32 +00001084 >>> print(opt_flag)
Georg Brandl116aa622007-08-15 14:28:22 +00001085 c_long(0)
1086 >>>
1087
1088If the interpreter would have been started with :option:`-O`, the sample would
1089have printed ``c_long(1)``, or ``c_long(2)`` if :option:`-OO` would have been
1090specified.
1091
1092An extended example which also demonstrates the use of pointers accesses the
1093``PyImport_FrozenModules`` pointer exported by Python.
1094
1095Quoting the Python docs: *This pointer is initialized to point to an array of
1096"struct _frozen" records, terminated by one whose members are all NULL or zero.
1097When a frozen module is imported, it is searched in this table. Third-party code
1098could play tricks with this to provide a dynamically created collection of
1099frozen modules.*
1100
1101So manipulating this pointer could even prove useful. To restrict the example
1102size, we show only how this table can be read with ``ctypes``::
1103
1104 >>> from ctypes import *
1105 >>>
1106 >>> class struct_frozen(Structure):
1107 ... _fields_ = [("name", c_char_p),
1108 ... ("code", POINTER(c_ubyte)),
1109 ... ("size", c_int)]
1110 ...
1111 >>>
1112
1113We have defined the ``struct _frozen`` data type, so we can get the pointer to
1114the table::
1115
1116 >>> FrozenTable = POINTER(struct_frozen)
1117 >>> table = FrozenTable.in_dll(pythonapi, "PyImport_FrozenModules")
1118 >>>
1119
1120Since ``table`` is a ``pointer`` to the array of ``struct_frozen`` records, we
1121can iterate over it, but we just have to make sure that our loop terminates,
1122because pointers have no size. Sooner or later it would probably crash with an
1123access violation or whatever, so it's better to break out of the loop when we
1124hit the NULL entry::
1125
1126 >>> for item in table:
Georg Brandl6911e3c2007-09-04 07:15:32 +00001127 ... print(item.name, item.size)
Georg Brandl116aa622007-08-15 14:28:22 +00001128 ... if item.name is None:
1129 ... break
1130 ...
1131 __hello__ 104
1132 __phello__ -104
1133 __phello__.spam 104
1134 None 0
1135 >>>
1136
1137The fact that standard Python has a frozen module and a frozen package
Thomas Woutersed03b412007-08-28 21:37:11 +00001138(indicated by the negative size member) is not well known, it is only used for
Georg Brandl116aa622007-08-15 14:28:22 +00001139testing. Try it out with ``import __hello__`` for example.
1140
1141
1142.. _ctypes-surprises:
1143
1144Surprises
1145^^^^^^^^^
1146
1147There are some edges in ``ctypes`` where you may be expect something else than
1148what actually happens.
1149
1150Consider the following example::
1151
1152 >>> from ctypes import *
1153 >>> class POINT(Structure):
1154 ... _fields_ = ("x", c_int), ("y", c_int)
1155 ...
1156 >>> class RECT(Structure):
1157 ... _fields_ = ("a", POINT), ("b", POINT)
1158 ...
1159 >>> p1 = POINT(1, 2)
1160 >>> p2 = POINT(3, 4)
1161 >>> rc = RECT(p1, p2)
Georg Brandl6911e3c2007-09-04 07:15:32 +00001162 >>> print(rc.a.x, rc.a.y, rc.b.x, rc.b.y)
Georg Brandl116aa622007-08-15 14:28:22 +00001163 1 2 3 4
1164 >>> # now swap the two points
1165 >>> rc.a, rc.b = rc.b, rc.a
Georg Brandl6911e3c2007-09-04 07:15:32 +00001166 >>> print(rc.a.x, rc.a.y, rc.b.x, rc.b.y)
Georg Brandl116aa622007-08-15 14:28:22 +00001167 3 4 3 4
1168 >>>
1169
1170Hm. We certainly expected the last statement to print ``3 4 1 2``. What
Thomas Woutersed03b412007-08-28 21:37:11 +00001171happened? Here are the steps of the ``rc.a, rc.b = rc.b, rc.a`` line above::
Georg Brandl116aa622007-08-15 14:28:22 +00001172
1173 >>> temp0, temp1 = rc.b, rc.a
1174 >>> rc.a = temp0
1175 >>> rc.b = temp1
1176 >>>
1177
1178Note that ``temp0`` and ``temp1`` are objects still using the internal buffer of
1179the ``rc`` object above. So executing ``rc.a = temp0`` copies the buffer
1180contents of ``temp0`` into ``rc`` 's buffer. This, in turn, changes the
1181contents of ``temp1``. So, the last assignment ``rc.b = temp1``, doesn't have
1182the expected effect.
1183
Thomas Woutersed03b412007-08-28 21:37:11 +00001184Keep in mind that retrieving sub-objects from Structure, Unions, and Arrays
1185doesn't *copy* the sub-object, instead it retrieves a wrapper object accessing
Georg Brandl116aa622007-08-15 14:28:22 +00001186the root-object's underlying buffer.
1187
1188Another example that may behave different from what one would expect is this::
1189
1190 >>> s = c_char_p()
1191 >>> s.value = "abc def ghi"
1192 >>> s.value
1193 'abc def ghi'
1194 >>> s.value is s.value
1195 False
1196 >>>
1197
1198Why is it printing ``False``? ctypes instances are objects containing a memory
Georg Brandl9afde1c2007-11-01 20:32:30 +00001199block plus some :term:`descriptor`\s accessing the contents of the memory.
1200Storing a Python object in the memory block does not store the object itself,
1201instead the ``contents`` of the object is stored. Accessing the contents again
1202constructs a new Python object each time!
Georg Brandl116aa622007-08-15 14:28:22 +00001203
1204
1205.. _ctypes-variable-sized-data-types:
1206
1207Variable-sized data types
1208^^^^^^^^^^^^^^^^^^^^^^^^^
1209
Benjamin Petersonfa0d7032009-06-01 22:42:33 +00001210``ctypes`` provides some support for variable-sized arrays and structures.
Georg Brandl116aa622007-08-15 14:28:22 +00001211
1212The ``resize`` function can be used to resize the memory buffer of an existing
1213ctypes object. The function takes the object as first argument, and the
1214requested size in bytes as the second argument. The memory block cannot be made
1215smaller than the natural memory block specified by the objects type, a
1216``ValueError`` is raised if this is tried::
1217
1218 >>> short_array = (c_short * 4)()
Georg Brandl6911e3c2007-09-04 07:15:32 +00001219 >>> print(sizeof(short_array))
Georg Brandl116aa622007-08-15 14:28:22 +00001220 8
1221 >>> resize(short_array, 4)
1222 Traceback (most recent call last):
1223 ...
1224 ValueError: minimum size is 8
1225 >>> resize(short_array, 32)
1226 >>> sizeof(short_array)
1227 32
1228 >>> sizeof(type(short_array))
1229 8
1230 >>>
1231
1232This is nice and fine, but how would one access the additional elements
1233contained in this array? Since the type still only knows about 4 elements, we
1234get errors accessing other elements::
1235
1236 >>> short_array[:]
1237 [0, 0, 0, 0]
1238 >>> short_array[7]
1239 Traceback (most recent call last):
1240 ...
1241 IndexError: invalid index
1242 >>>
1243
1244Another way to use variable-sized data types with ``ctypes`` is to use the
1245dynamic nature of Python, and (re-)define the data type after the required size
1246is already known, on a case by case basis.
1247
1248
Georg Brandl116aa622007-08-15 14:28:22 +00001249.. _ctypes-ctypes-reference:
1250
1251ctypes reference
1252----------------
1253
1254
1255.. _ctypes-finding-shared-libraries:
1256
1257Finding shared libraries
1258^^^^^^^^^^^^^^^^^^^^^^^^
1259
1260When programming in a compiled language, shared libraries are accessed when
1261compiling/linking a program, and when the program is run.
1262
1263The purpose of the ``find_library`` function is to locate a library in a way
1264similar to what the compiler does (on platforms with several versions of a
1265shared library the most recent should be loaded), while the ctypes library
1266loaders act like when a program is run, and call the runtime loader directly.
1267
1268The ``ctypes.util`` module provides a function which can help to determine the
1269library to load.
1270
1271
1272.. data:: find_library(name)
Benjamin Peterson5c6d7872009-02-06 02:40:07 +00001273 :module: ctypes.util
Georg Brandl116aa622007-08-15 14:28:22 +00001274 :noindex:
1275
1276 Try to find a library and return a pathname. *name* is the library name without
1277 any prefix like *lib*, suffix like ``.so``, ``.dylib`` or version number (this
1278 is the form used for the posix linker option :option:`-l`). If no library can
1279 be found, returns ``None``.
1280
Thomas Woutersed03b412007-08-28 21:37:11 +00001281The exact functionality is system dependent.
Georg Brandl116aa622007-08-15 14:28:22 +00001282
1283On Linux, ``find_library`` tries to run external programs (/sbin/ldconfig, gcc,
1284and objdump) to find the library file. It returns the filename of the library
Thomas Woutersed03b412007-08-28 21:37:11 +00001285file. Here are some examples::
Georg Brandl116aa622007-08-15 14:28:22 +00001286
1287 >>> from ctypes.util import find_library
1288 >>> find_library("m")
1289 'libm.so.6'
1290 >>> find_library("c")
1291 'libc.so.6'
1292 >>> find_library("bz2")
1293 'libbz2.so.1.0'
1294 >>>
1295
1296On OS X, ``find_library`` tries several predefined naming schemes and paths to
Thomas Woutersed03b412007-08-28 21:37:11 +00001297locate the library, and returns a full pathname if successful::
Georg Brandl116aa622007-08-15 14:28:22 +00001298
1299 >>> from ctypes.util import find_library
1300 >>> find_library("c")
1301 '/usr/lib/libc.dylib'
1302 >>> find_library("m")
1303 '/usr/lib/libm.dylib'
1304 >>> find_library("bz2")
1305 '/usr/lib/libbz2.dylib'
1306 >>> find_library("AGL")
1307 '/System/Library/Frameworks/AGL.framework/AGL'
1308 >>>
1309
1310On Windows, ``find_library`` searches along the system search path, and returns
1311the full pathname, but since there is no predefined naming scheme a call like
1312``find_library("c")`` will fail and return ``None``.
1313
1314If wrapping a shared library with ``ctypes``, it *may* be better to determine
1315the shared library name at development type, and hardcode that into the wrapper
1316module instead of using ``find_library`` to locate the library at runtime.
1317
1318
1319.. _ctypes-loading-shared-libraries:
1320
1321Loading shared libraries
1322^^^^^^^^^^^^^^^^^^^^^^^^
1323
1324There are several ways to loaded shared libraries into the Python process. One
1325way is to instantiate one of the following classes:
1326
1327
Thomas Hellerb795f5282008-06-10 15:26:58 +00001328.. class:: CDLL(name, mode=DEFAULT_MODE, handle=None, use_errno=False, use_last_error=False)
Georg Brandl116aa622007-08-15 14:28:22 +00001329
1330 Instances of this class represent loaded shared libraries. Functions in these
1331 libraries use the standard C calling convention, and are assumed to return
1332 ``int``.
1333
1334
Thomas Hellerb795f5282008-06-10 15:26:58 +00001335.. class:: OleDLL(name, mode=DEFAULT_MODE, handle=None, use_errno=False, use_last_error=False)
Georg Brandl116aa622007-08-15 14:28:22 +00001336
1337 Windows only: Instances of this class represent loaded shared libraries,
1338 functions in these libraries use the ``stdcall`` calling convention, and are
1339 assumed to return the windows specific :class:`HRESULT` code. :class:`HRESULT`
1340 values contain information specifying whether the function call failed or
1341 succeeded, together with additional error code. If the return value signals a
1342 failure, an :class:`WindowsError` is automatically raised.
1343
1344
Thomas Hellerb795f5282008-06-10 15:26:58 +00001345.. class:: WinDLL(name, mode=DEFAULT_MODE, handle=None, use_errno=False, use_last_error=False)
Georg Brandl116aa622007-08-15 14:28:22 +00001346
1347 Windows only: Instances of this class represent loaded shared libraries,
1348 functions in these libraries use the ``stdcall`` calling convention, and are
1349 assumed to return ``int`` by default.
1350
1351 On Windows CE only the standard calling convention is used, for convenience the
1352 :class:`WinDLL` and :class:`OleDLL` use the standard calling convention on this
1353 platform.
1354
Georg Brandl9afde1c2007-11-01 20:32:30 +00001355The Python :term:`global interpreter lock` is released before calling any
1356function exported by these libraries, and reacquired afterwards.
Georg Brandl116aa622007-08-15 14:28:22 +00001357
1358
1359.. class:: PyDLL(name, mode=DEFAULT_MODE, handle=None)
1360
1361 Instances of this class behave like :class:`CDLL` instances, except that the
1362 Python GIL is *not* released during the function call, and after the function
1363 execution the Python error flag is checked. If the error flag is set, a Python
1364 exception is raised.
1365
1366 Thus, this is only useful to call Python C api functions directly.
1367
1368All these classes can be instantiated by calling them with at least one
1369argument, the pathname of the shared library. If you have an existing handle to
Benjamin Peterson4469d0c2008-11-30 22:46:23 +00001370an already loaded shared library, it can be passed as the ``handle`` named
Georg Brandl116aa622007-08-15 14:28:22 +00001371parameter, otherwise the underlying platforms ``dlopen`` or :meth:`LoadLibrary`
1372function is used to load the library into the process, and to get a handle to
1373it.
1374
1375The *mode* parameter can be used to specify how the library is loaded. For
1376details, consult the ``dlopen(3)`` manpage, on Windows, *mode* is ignored.
1377
Georg Brandl36ab1ef2009-01-03 21:17:04 +00001378The *use_errno* parameter, when set to True, enables a ctypes mechanism that
1379allows to access the system :data:`errno` error number in a safe way.
1380:mod:`ctypes` maintains a thread-local copy of the systems :data:`errno`
1381variable; if you call foreign functions created with ``use_errno=True`` then the
1382:data:`errno` value before the function call is swapped with the ctypes private
1383copy, the same happens immediately after the function call.
Thomas Hellerb795f5282008-06-10 15:26:58 +00001384
Georg Brandl36ab1ef2009-01-03 21:17:04 +00001385The function :func:`ctypes.get_errno` returns the value of the ctypes private
1386copy, and the function :func:`ctypes.set_errno` changes the ctypes private copy
1387to a new value and returns the former value.
Thomas Hellerb795f5282008-06-10 15:26:58 +00001388
Georg Brandl36ab1ef2009-01-03 21:17:04 +00001389The *use_last_error* parameter, when set to True, enables the same mechanism for
1390the Windows error code which is managed by the :func:`GetLastError` and
1391:func:`SetLastError` Windows API functions; :func:`ctypes.get_last_error` and
1392:func:`ctypes.set_last_error` are used to request and change the ctypes private
1393copy of the windows error code.
Thomas Hellerb795f5282008-06-10 15:26:58 +00001394
Georg Brandl116aa622007-08-15 14:28:22 +00001395.. data:: RTLD_GLOBAL
1396 :noindex:
1397
1398 Flag to use as *mode* parameter. On platforms where this flag is not available,
1399 it is defined as the integer zero.
1400
1401
1402.. data:: RTLD_LOCAL
1403 :noindex:
1404
1405 Flag to use as *mode* parameter. On platforms where this is not available, it
1406 is the same as *RTLD_GLOBAL*.
1407
1408
1409.. data:: DEFAULT_MODE
1410 :noindex:
1411
1412 The default mode which is used to load shared libraries. On OSX 10.3, this is
1413 *RTLD_GLOBAL*, otherwise it is the same as *RTLD_LOCAL*.
1414
1415Instances of these classes have no public methods, however :meth:`__getattr__`
Thomas Woutersed03b412007-08-28 21:37:11 +00001416and :meth:`__getitem__` have special behavior: functions exported by the shared
Georg Brandl116aa622007-08-15 14:28:22 +00001417library can be accessed as attributes of by index. Please note that both
1418:meth:`__getattr__` and :meth:`__getitem__` cache their result, so calling them
1419repeatedly returns the same object each time.
1420
1421The following public attributes are available, their name starts with an
1422underscore to not clash with exported function names:
1423
1424
1425.. attribute:: PyDLL._handle
1426
1427 The system handle used to access the library.
1428
1429
1430.. attribute:: PyDLL._name
1431
Thomas Woutersed03b412007-08-28 21:37:11 +00001432 The name of the library passed in the constructor.
Georg Brandl116aa622007-08-15 14:28:22 +00001433
1434Shared libraries can also be loaded by using one of the prefabricated objects,
1435which are instances of the :class:`LibraryLoader` class, either by calling the
1436:meth:`LoadLibrary` method, or by retrieving the library as attribute of the
1437loader instance.
1438
1439
1440.. class:: LibraryLoader(dlltype)
1441
1442 Class which loads shared libraries. ``dlltype`` should be one of the
1443 :class:`CDLL`, :class:`PyDLL`, :class:`WinDLL`, or :class:`OleDLL` types.
1444
Thomas Woutersed03b412007-08-28 21:37:11 +00001445 :meth:`__getattr__` has special behavior: It allows to load a shared library by
Georg Brandl116aa622007-08-15 14:28:22 +00001446 accessing it as attribute of a library loader instance. The result is cached,
1447 so repeated attribute accesses return the same library each time.
1448
1449
Benjamin Petersone41251e2008-04-25 01:59:09 +00001450 .. method:: LoadLibrary(name)
Georg Brandl116aa622007-08-15 14:28:22 +00001451
Benjamin Petersone41251e2008-04-25 01:59:09 +00001452 Load a shared library into the process and return it. This method always
1453 returns a new instance of the library.
Georg Brandl116aa622007-08-15 14:28:22 +00001454
1455These prefabricated library loaders are available:
1456
1457
1458.. data:: cdll
1459 :noindex:
1460
1461 Creates :class:`CDLL` instances.
1462
1463
1464.. data:: windll
1465 :noindex:
1466
1467 Windows only: Creates :class:`WinDLL` instances.
1468
1469
1470.. data:: oledll
1471 :noindex:
1472
1473 Windows only: Creates :class:`OleDLL` instances.
1474
1475
1476.. data:: pydll
1477 :noindex:
1478
1479 Creates :class:`PyDLL` instances.
1480
1481For accessing the C Python api directly, a ready-to-use Python shared library
1482object is available:
1483
1484
1485.. data:: pythonapi
1486 :noindex:
1487
1488 An instance of :class:`PyDLL` that exposes Python C api functions as attributes.
1489 Note that all these functions are assumed to return C ``int``, which is of
1490 course not always the truth, so you have to assign the correct :attr:`restype`
1491 attribute to use these functions.
1492
1493
1494.. _ctypes-foreign-functions:
1495
1496Foreign functions
1497^^^^^^^^^^^^^^^^^
1498
1499As explained in the previous section, foreign functions can be accessed as
1500attributes of loaded shared libraries. The function objects created in this way
1501by default accept any number of arguments, accept any ctypes data instances as
1502arguments, and return the default result type specified by the library loader.
1503They are instances of a private class:
1504
1505
1506.. class:: _FuncPtr
1507
1508 Base class for C callable foreign functions.
1509
Benjamin Petersone41251e2008-04-25 01:59:09 +00001510 Instances of foreign functions are also C compatible data types; they
1511 represent C function pointers.
Georg Brandl116aa622007-08-15 14:28:22 +00001512
Benjamin Petersone41251e2008-04-25 01:59:09 +00001513 This behavior can be customized by assigning to special attributes of the
1514 foreign function object.
Georg Brandl116aa622007-08-15 14:28:22 +00001515
1516
Benjamin Petersone41251e2008-04-25 01:59:09 +00001517 .. attribute:: restype
Georg Brandl116aa622007-08-15 14:28:22 +00001518
Benjamin Petersone41251e2008-04-25 01:59:09 +00001519 Assign a ctypes type to specify the result type of the foreign function.
1520 Use ``None`` for ``void`` a function not returning anything.
Georg Brandl116aa622007-08-15 14:28:22 +00001521
Benjamin Petersone41251e2008-04-25 01:59:09 +00001522 It is possible to assign a callable Python object that is not a ctypes
1523 type, in this case the function is assumed to return a C ``int``, and the
1524 callable will be called with this integer, allowing to do further
1525 processing or error checking. Using this is deprecated, for more flexible
1526 post processing or error checking use a ctypes data type as
1527 :attr:`restype` and assign a callable to the :attr:`errcheck` attribute.
Georg Brandl116aa622007-08-15 14:28:22 +00001528
1529
Benjamin Petersone41251e2008-04-25 01:59:09 +00001530 .. attribute:: argtypes
Georg Brandl116aa622007-08-15 14:28:22 +00001531
Benjamin Petersone41251e2008-04-25 01:59:09 +00001532 Assign a tuple of ctypes types to specify the argument types that the
1533 function accepts. Functions using the ``stdcall`` calling convention can
1534 only be called with the same number of arguments as the length of this
1535 tuple; functions using the C calling convention accept additional,
1536 unspecified arguments as well.
Georg Brandl116aa622007-08-15 14:28:22 +00001537
Benjamin Petersone41251e2008-04-25 01:59:09 +00001538 When a foreign function is called, each actual argument is passed to the
1539 :meth:`from_param` class method of the items in the :attr:`argtypes`
1540 tuple, this method allows to adapt the actual argument to an object that
1541 the foreign function accepts. For example, a :class:`c_char_p` item in
1542 the :attr:`argtypes` tuple will convert a unicode string passed as
1543 argument into an byte string using ctypes conversion rules.
Georg Brandl116aa622007-08-15 14:28:22 +00001544
Benjamin Petersone41251e2008-04-25 01:59:09 +00001545 New: It is now possible to put items in argtypes which are not ctypes
1546 types, but each item must have a :meth:`from_param` method which returns a
1547 value usable as argument (integer, string, ctypes instance). This allows
1548 to define adapters that can adapt custom objects as function parameters.
Georg Brandl116aa622007-08-15 14:28:22 +00001549
1550
Benjamin Petersone41251e2008-04-25 01:59:09 +00001551 .. attribute:: errcheck
Georg Brandl116aa622007-08-15 14:28:22 +00001552
Benjamin Petersone41251e2008-04-25 01:59:09 +00001553 Assign a Python function or another callable to this attribute. The
1554 callable will be called with three or more arguments:
Georg Brandl116aa622007-08-15 14:28:22 +00001555
Amaury Forgeot d'Arcfdfe62d2008-06-17 20:36:03 +00001556 .. function:: callable(result, func, arguments)
1557 :noindex:
Georg Brandl116aa622007-08-15 14:28:22 +00001558
Amaury Forgeot d'Arcfdfe62d2008-06-17 20:36:03 +00001559 ``result`` is what the foreign function returns, as specified
1560 by the :attr:`restype` attribute.
Georg Brandl116aa622007-08-15 14:28:22 +00001561
Amaury Forgeot d'Arcfdfe62d2008-06-17 20:36:03 +00001562 ``func`` is the foreign function object itself, this allows
1563 to reuse the same callable object to check or post process
1564 the results of several functions.
Georg Brandl116aa622007-08-15 14:28:22 +00001565
Amaury Forgeot d'Arcfdfe62d2008-06-17 20:36:03 +00001566 ``arguments`` is a tuple containing the parameters originally
1567 passed to the function call, this allows to specialize the
1568 behavior on the arguments used.
Georg Brandl116aa622007-08-15 14:28:22 +00001569
Amaury Forgeot d'Arcfdfe62d2008-06-17 20:36:03 +00001570 The object that this function returns will be returned from the
1571 foreign function call, but it can also check the result value
1572 and raise an exception if the foreign function call failed.
Georg Brandl116aa622007-08-15 14:28:22 +00001573
1574
1575.. exception:: ArgumentError()
1576
1577 This exception is raised when a foreign function call cannot convert one of the
1578 passed arguments.
1579
1580
1581.. _ctypes-function-prototypes:
1582
1583Function prototypes
1584^^^^^^^^^^^^^^^^^^^
1585
1586Foreign functions can also be created by instantiating function prototypes.
1587Function prototypes are similar to function prototypes in C; they describe a
1588function (return type, argument types, calling convention) without defining an
1589implementation. The factory functions must be called with the desired result
1590type and the argument types of the function.
1591
1592
Thomas Hellerb795f5282008-06-10 15:26:58 +00001593.. function:: CFUNCTYPE(restype, *argtypes, use_errno=False, use_last_error=False)
Georg Brandl116aa622007-08-15 14:28:22 +00001594
1595 The returned function prototype creates functions that use the standard C
Georg Brandl36ab1ef2009-01-03 21:17:04 +00001596 calling convention. The function will release the GIL during the call. If
1597 *use_errno* is set to True, the ctypes private copy of the system
1598 :data:`errno` variable is exchanged with the real :data:`errno` value bafore
1599 and after the call; *use_last_error* does the same for the Windows error
1600 code.
Thomas Hellerb795f5282008-06-10 15:26:58 +00001601
Georg Brandl116aa622007-08-15 14:28:22 +00001602
Thomas Hellerb795f5282008-06-10 15:26:58 +00001603.. function:: WINFUNCTYPE(restype, *argtypes, use_errno=False, use_last_error=False)
Georg Brandl116aa622007-08-15 14:28:22 +00001604
1605 Windows only: The returned function prototype creates functions that use the
Georg Brandl36ab1ef2009-01-03 21:17:04 +00001606 ``stdcall`` calling convention, except on Windows CE where
1607 :func:`WINFUNCTYPE` is the same as :func:`CFUNCTYPE`. The function will
1608 release the GIL during the call. *use_errno* and *use_last_error* have the
1609 same meaning as above.
Georg Brandl116aa622007-08-15 14:28:22 +00001610
1611
1612.. function:: PYFUNCTYPE(restype, *argtypes)
1613
1614 The returned function prototype creates functions that use the Python calling
1615 convention. The function will *not* release the GIL during the call.
1616
Thomas Heller2fadaa22008-06-16 19:56:33 +00001617Function prototypes created by these factory functions can be instantiated in
1618different ways, depending on the type and number of the parameters in the call:
Georg Brandl116aa622007-08-15 14:28:22 +00001619
1620
Thomas Heller2fadaa22008-06-16 19:56:33 +00001621 .. function:: prototype(address)
1622 :noindex:
1623 :module:
Georg Brandl116aa622007-08-15 14:28:22 +00001624
Thomas Heller2fadaa22008-06-16 19:56:33 +00001625 Returns a foreign function at the specified address which must be an integer.
Georg Brandl116aa622007-08-15 14:28:22 +00001626
1627
Thomas Heller2fadaa22008-06-16 19:56:33 +00001628 .. function:: prototype(callable)
1629 :noindex:
1630 :module:
Georg Brandl116aa622007-08-15 14:28:22 +00001631
Thomas Heller2fadaa22008-06-16 19:56:33 +00001632 Create a C callable function (a callback function) from a Python ``callable``.
Georg Brandl116aa622007-08-15 14:28:22 +00001633
1634
Thomas Heller2fadaa22008-06-16 19:56:33 +00001635 .. function:: prototype(func_spec[, paramflags])
1636 :noindex:
1637 :module:
Georg Brandl116aa622007-08-15 14:28:22 +00001638
Thomas Heller2fadaa22008-06-16 19:56:33 +00001639 Returns a foreign function exported by a shared library. ``func_spec`` must be a
1640 2-tuple ``(name_or_ordinal, library)``. The first item is the name of the
1641 exported function as string, or the ordinal of the exported function as small
1642 integer. The second item is the shared library instance.
Georg Brandl116aa622007-08-15 14:28:22 +00001643
1644
Thomas Heller2fadaa22008-06-16 19:56:33 +00001645 .. function:: prototype(vtbl_index, name[, paramflags[, iid]])
1646 :noindex:
1647 :module:
Georg Brandl116aa622007-08-15 14:28:22 +00001648
Thomas Heller2fadaa22008-06-16 19:56:33 +00001649 Returns a foreign function that will call a COM method. ``vtbl_index`` is the
1650 index into the virtual function table, a small non-negative integer. *name* is
1651 name of the COM method. *iid* is an optional pointer to the interface identifier
1652 which is used in extended error reporting.
Georg Brandl116aa622007-08-15 14:28:22 +00001653
Thomas Heller2fadaa22008-06-16 19:56:33 +00001654 COM methods use a special calling convention: They require a pointer to the COM
1655 interface as first argument, in addition to those parameters that are specified
1656 in the :attr:`argtypes` tuple.
Georg Brandl116aa622007-08-15 14:28:22 +00001657
Thomas Heller2fadaa22008-06-16 19:56:33 +00001658 The optional *paramflags* parameter creates foreign function wrappers with much
1659 more functionality than the features described above.
Georg Brandl116aa622007-08-15 14:28:22 +00001660
Thomas Heller2fadaa22008-06-16 19:56:33 +00001661 *paramflags* must be a tuple of the same length as :attr:`argtypes`.
Georg Brandl116aa622007-08-15 14:28:22 +00001662
Thomas Heller2fadaa22008-06-16 19:56:33 +00001663 Each item in this tuple contains further information about a parameter, it must
1664 be a tuple containing one, two, or three items.
Georg Brandl116aa622007-08-15 14:28:22 +00001665
Thomas Heller2fadaa22008-06-16 19:56:33 +00001666 The first item is an integer containing a combination of direction
1667 flags for the parameter:
Georg Brandl116aa622007-08-15 14:28:22 +00001668
Thomas Heller2fadaa22008-06-16 19:56:33 +00001669 1
1670 Specifies an input parameter to the function.
Georg Brandl116aa622007-08-15 14:28:22 +00001671
Thomas Heller2fadaa22008-06-16 19:56:33 +00001672 2
1673 Output parameter. The foreign function fills in a value.
Georg Brandl116aa622007-08-15 14:28:22 +00001674
Thomas Heller2fadaa22008-06-16 19:56:33 +00001675 4
1676 Input parameter which defaults to the integer zero.
Georg Brandl116aa622007-08-15 14:28:22 +00001677
Thomas Heller2fadaa22008-06-16 19:56:33 +00001678 The optional second item is the parameter name as string. If this is specified,
1679 the foreign function can be called with named parameters.
Georg Brandl116aa622007-08-15 14:28:22 +00001680
Thomas Heller2fadaa22008-06-16 19:56:33 +00001681 The optional third item is the default value for this parameter.
Georg Brandl116aa622007-08-15 14:28:22 +00001682
1683This example demonstrates how to wrap the Windows ``MessageBoxA`` function so
1684that it supports default parameters and named arguments. The C declaration from
1685the windows header file is this::
1686
1687 WINUSERAPI int WINAPI
1688 MessageBoxA(
1689 HWND hWnd ,
1690 LPCSTR lpText,
1691 LPCSTR lpCaption,
1692 UINT uType);
1693
Thomas Heller2fadaa22008-06-16 19:56:33 +00001694Here is the wrapping with ``ctypes``::
Georg Brandl116aa622007-08-15 14:28:22 +00001695
Thomas Heller2fadaa22008-06-16 19:56:33 +00001696 >>> from ctypes import c_int, WINFUNCTYPE, windll
1697 >>> from ctypes.wintypes import HWND, LPCSTR, UINT
1698 >>> prototype = WINFUNCTYPE(c_int, HWND, LPCSTR, LPCSTR, UINT)
1699 >>> paramflags = (1, "hwnd", 0), (1, "text", "Hi"), (1, "caption", None), (1, "flags", 0)
1700 >>> MessageBox = prototype(("MessageBoxA", windll.user32), paramflags)
1701 >>>
Georg Brandl116aa622007-08-15 14:28:22 +00001702
1703The MessageBox foreign function can now be called in these ways::
1704
1705 >>> MessageBox()
1706 >>> MessageBox(text="Spam, spam, spam")
1707 >>> MessageBox(flags=2, text="foo bar")
1708 >>>
1709
1710A second example demonstrates output parameters. The win32 ``GetWindowRect``
1711function retrieves the dimensions of a specified window by copying them into
1712``RECT`` structure that the caller has to supply. Here is the C declaration::
1713
1714 WINUSERAPI BOOL WINAPI
1715 GetWindowRect(
1716 HWND hWnd,
1717 LPRECT lpRect);
1718
Thomas Heller2fadaa22008-06-16 19:56:33 +00001719Here is the wrapping with ``ctypes``::
Georg Brandl116aa622007-08-15 14:28:22 +00001720
Thomas Heller2fadaa22008-06-16 19:56:33 +00001721 >>> from ctypes import POINTER, WINFUNCTYPE, windll, WinError
1722 >>> from ctypes.wintypes import BOOL, HWND, RECT
1723 >>> prototype = WINFUNCTYPE(BOOL, HWND, POINTER(RECT))
1724 >>> paramflags = (1, "hwnd"), (2, "lprect")
1725 >>> GetWindowRect = prototype(("GetWindowRect", windll.user32), paramflags)
1726 >>>
Georg Brandl116aa622007-08-15 14:28:22 +00001727
1728Functions with output parameters will automatically return the output parameter
1729value if there is a single one, or a tuple containing the output parameter
1730values when there are more than one, so the GetWindowRect function now returns a
1731RECT instance, when called.
1732
1733Output parameters can be combined with the :attr:`errcheck` protocol to do
1734further output processing and error checking. The win32 ``GetWindowRect`` api
1735function returns a ``BOOL`` to signal success or failure, so this function could
1736do the error checking, and raises an exception when the api call failed::
1737
1738 >>> def errcheck(result, func, args):
1739 ... if not result:
1740 ... raise WinError()
1741 ... return args
Thomas Heller2fadaa22008-06-16 19:56:33 +00001742 ...
Georg Brandl116aa622007-08-15 14:28:22 +00001743 >>> GetWindowRect.errcheck = errcheck
1744 >>>
1745
1746If the :attr:`errcheck` function returns the argument tuple it receives
1747unchanged, ``ctypes`` continues the normal processing it does on the output
1748parameters. If you want to return a tuple of window coordinates instead of a
1749``RECT`` instance, you can retrieve the fields in the function and return them
1750instead, the normal processing will no longer take place::
1751
1752 >>> def errcheck(result, func, args):
1753 ... if not result:
1754 ... raise WinError()
1755 ... rc = args[1]
1756 ... return rc.left, rc.top, rc.bottom, rc.right
Thomas Heller2fadaa22008-06-16 19:56:33 +00001757 ...
Georg Brandl116aa622007-08-15 14:28:22 +00001758 >>> GetWindowRect.errcheck = errcheck
1759 >>>
1760
1761
1762.. _ctypes-utility-functions:
1763
1764Utility functions
1765^^^^^^^^^^^^^^^^^
1766
1767
1768.. function:: addressof(obj)
1769
1770 Returns the address of the memory buffer as integer. ``obj`` must be an
1771 instance of a ctypes type.
1772
1773
1774.. function:: alignment(obj_or_type)
1775
1776 Returns the alignment requirements of a ctypes type. ``obj_or_type`` must be a
1777 ctypes type or instance.
1778
1779
Amaury Forgeot d'Arcfdfe62d2008-06-17 20:36:03 +00001780.. function:: byref(obj[, offset])
Georg Brandl116aa622007-08-15 14:28:22 +00001781
Amaury Forgeot d'Arcfdfe62d2008-06-17 20:36:03 +00001782 Returns a light-weight pointer to ``obj``, which must be an
Georg Brandl2ee470f2008-07-16 12:55:28 +00001783 instance of a ctypes type. ``offset`` defaults to zero, and must be
1784 an integer that will be added to the internal pointer value.
Amaury Forgeot d'Arcfdfe62d2008-06-17 20:36:03 +00001785
1786 ``byref(obj, offset)`` corresponds to this C code::
1787
1788 (((char *)&obj) + offset)
1789
1790 The returned object can only be used as a foreign function call
1791 parameter. It behaves similar to ``pointer(obj)``, but the
1792 construction is a lot faster.
Georg Brandl116aa622007-08-15 14:28:22 +00001793
1794
1795.. function:: cast(obj, type)
1796
1797 This function is similar to the cast operator in C. It returns a new instance of
1798 ``type`` which points to the same memory block as ``obj``. ``type`` must be a
1799 pointer type, and ``obj`` must be an object that can be interpreted as a
1800 pointer.
1801
1802
1803.. function:: create_string_buffer(init_or_size[, size])
1804
1805 This function creates a mutable character buffer. The returned object is a
1806 ctypes array of :class:`c_char`.
1807
1808 ``init_or_size`` must be an integer which specifies the size of the array, or a
1809 string which will be used to initialize the array items.
1810
1811 If a string is specified as first argument, the buffer is made one item larger
1812 than the length of the string so that the last element in the array is a NUL
1813 termination character. An integer can be passed as second argument which allows
1814 to specify the size of the array if the length of the string should not be used.
1815
1816 If the first parameter is a unicode string, it is converted into an 8-bit string
1817 according to ctypes conversion rules.
1818
1819
1820.. function:: create_unicode_buffer(init_or_size[, size])
1821
1822 This function creates a mutable unicode character buffer. The returned object is
1823 a ctypes array of :class:`c_wchar`.
1824
1825 ``init_or_size`` must be an integer which specifies the size of the array, or a
1826 unicode string which will be used to initialize the array items.
1827
1828 If a unicode string is specified as first argument, the buffer is made one item
1829 larger than the length of the string so that the last element in the array is a
1830 NUL termination character. An integer can be passed as second argument which
1831 allows to specify the size of the array if the length of the string should not
1832 be used.
1833
1834 If the first parameter is a 8-bit string, it is converted into an unicode string
1835 according to ctypes conversion rules.
1836
1837
1838.. function:: DllCanUnloadNow()
1839
Thomas Woutersed03b412007-08-28 21:37:11 +00001840 Windows only: This function is a hook which allows to implement in-process COM
Georg Brandl116aa622007-08-15 14:28:22 +00001841 servers with ctypes. It is called from the DllCanUnloadNow function that the
1842 _ctypes extension dll exports.
1843
1844
1845.. function:: DllGetClassObject()
1846
Thomas Woutersed03b412007-08-28 21:37:11 +00001847 Windows only: This function is a hook which allows to implement in-process COM
Georg Brandl116aa622007-08-15 14:28:22 +00001848 servers with ctypes. It is called from the DllGetClassObject function that the
1849 ``_ctypes`` extension dll exports.
1850
Thomas Heller2fadaa22008-06-16 19:56:33 +00001851.. function:: find_library(name)
1852 :module: ctypes.util
1853
Georg Brandl36ab1ef2009-01-03 21:17:04 +00001854 Try to find a library and return a pathname. *name* is the library name
Benjamin Peterson28d88b42009-01-09 03:03:23 +00001855 without any prefix like ``lib``, suffix like ``.so``, ``.dylib`` or version
Georg Brandl36ab1ef2009-01-03 21:17:04 +00001856 number (this is the form used for the posix linker option :option:`-l`). If
1857 no library can be found, returns ``None``.
Thomas Heller2fadaa22008-06-16 19:56:33 +00001858
1859 The exact functionality is system dependent.
1860
Thomas Heller2fadaa22008-06-16 19:56:33 +00001861
1862.. function:: find_msvcrt()
1863 :module: ctypes.util
1864
1865 Windows only: return the filename of the VC runtype library used
1866 by Python, and by the extension modules. If the name of the
1867 library cannot be determined, ``None`` is returned.
1868
1869 If you need to free memory, for example, allocated by an extension
1870 module with a call to the ``free(void *)``, it is important that you
1871 use the function in the same library that allocated the memory.
1872
Georg Brandl116aa622007-08-15 14:28:22 +00001873.. function:: FormatError([code])
1874
1875 Windows only: Returns a textual description of the error code. If no error code
1876 is specified, the last error code is used by calling the Windows api function
1877 GetLastError.
1878
1879
1880.. function:: GetLastError()
1881
1882 Windows only: Returns the last error code set by Windows in the calling thread.
Thomas Hellerb795f5282008-06-10 15:26:58 +00001883 This function calls the Windows `GetLastError()` function directly,
1884 it does not return the ctypes-private copy of the error code.
Georg Brandl116aa622007-08-15 14:28:22 +00001885
Thomas Hellerb795f5282008-06-10 15:26:58 +00001886.. function:: get_errno()
1887
1888 Returns the current value of the ctypes-private copy of the system
Georg Brandl36ab1ef2009-01-03 21:17:04 +00001889 :data:`errno` variable in the calling thread.
Thomas Hellerb795f5282008-06-10 15:26:58 +00001890
Thomas Hellerb795f5282008-06-10 15:26:58 +00001891.. function:: get_last_error()
1892
1893 Windows only: returns the current value of the ctypes-private copy of the system
Georg Brandl36ab1ef2009-01-03 21:17:04 +00001894 :data:`LastError` variable in the calling thread.
Thomas Hellerb795f5282008-06-10 15:26:58 +00001895
Georg Brandl116aa622007-08-15 14:28:22 +00001896.. function:: memmove(dst, src, count)
1897
1898 Same as the standard C memmove library function: copies *count* bytes from
1899 ``src`` to *dst*. *dst* and ``src`` must be integers or ctypes instances that
1900 can be converted to pointers.
1901
1902
1903.. function:: memset(dst, c, count)
1904
1905 Same as the standard C memset library function: fills the memory block at
1906 address *dst* with *count* bytes of value *c*. *dst* must be an integer
1907 specifying an address, or a ctypes instance.
1908
1909
1910.. function:: POINTER(type)
1911
1912 This factory function creates and returns a new ctypes pointer type. Pointer
1913 types are cached an reused internally, so calling this function repeatedly is
1914 cheap. type must be a ctypes type.
1915
1916
1917.. function:: pointer(obj)
1918
1919 This function creates a new pointer instance, pointing to ``obj``. The returned
1920 object is of the type POINTER(type(obj)).
1921
1922 Note: If you just want to pass a pointer to an object to a foreign function
1923 call, you should use ``byref(obj)`` which is much faster.
1924
1925
1926.. function:: resize(obj, size)
1927
1928 This function resizes the internal memory buffer of obj, which must be an
1929 instance of a ctypes type. It is not possible to make the buffer smaller than
1930 the native size of the objects type, as given by sizeof(type(obj)), but it is
1931 possible to enlarge the buffer.
1932
1933
1934.. function:: set_conversion_mode(encoding, errors)
1935
1936 This function sets the rules that ctypes objects use when converting between
1937 8-bit strings and unicode strings. encoding must be a string specifying an
1938 encoding, like ``'utf-8'`` or ``'mbcs'``, errors must be a string specifying the
1939 error handling on encoding/decoding errors. Examples of possible values are
1940 ``"strict"``, ``"replace"``, or ``"ignore"``.
1941
1942 ``set_conversion_mode`` returns a 2-tuple containing the previous conversion
1943 rules. On windows, the initial conversion rules are ``('mbcs', 'ignore')``, on
1944 other systems ``('ascii', 'strict')``.
1945
1946
Thomas Hellerb795f5282008-06-10 15:26:58 +00001947.. function:: set_errno(value)
1948
Georg Brandl36ab1ef2009-01-03 21:17:04 +00001949 Set the current value of the ctypes-private copy of the system :data:`errno`
1950 variable in the calling thread to *value* and return the previous value.
Thomas Hellerb795f5282008-06-10 15:26:58 +00001951
Thomas Hellerb795f5282008-06-10 15:26:58 +00001952.. function:: set_last_error(value)
1953
Georg Brandl36ab1ef2009-01-03 21:17:04 +00001954 Windows only: set the current value of the ctypes-private copy of the system
1955 :data:`LastError` variable in the calling thread to *value* and return the
1956 previous value.
Thomas Hellerb795f5282008-06-10 15:26:58 +00001957
Georg Brandl116aa622007-08-15 14:28:22 +00001958.. function:: sizeof(obj_or_type)
1959
1960 Returns the size in bytes of a ctypes type or instance memory buffer. Does the
1961 same as the C ``sizeof()`` function.
1962
1963
1964.. function:: string_at(address[, size])
1965
1966 This function returns the string starting at memory address address. If size
1967 is specified, it is used as size, otherwise the string is assumed to be
1968 zero-terminated.
1969
1970
1971.. function:: WinError(code=None, descr=None)
1972
1973 Windows only: this function is probably the worst-named thing in ctypes. It
1974 creates an instance of WindowsError. If *code* is not specified,
1975 ``GetLastError`` is called to determine the error code. If ``descr`` is not
Thomas Woutersed03b412007-08-28 21:37:11 +00001976 specified, :func:`FormatError` is called to get a textual description of the
Georg Brandl116aa622007-08-15 14:28:22 +00001977 error.
1978
1979
1980.. function:: wstring_at(address)
1981
1982 This function returns the wide character string starting at memory address
1983 ``address`` as unicode string. If ``size`` is specified, it is used as the
1984 number of characters of the string, otherwise the string is assumed to be
1985 zero-terminated.
1986
1987
1988.. _ctypes-data-types:
1989
1990Data types
1991^^^^^^^^^^
1992
1993
1994.. class:: _CData
1995
1996 This non-public class is the common base class of all ctypes data types. Among
1997 other things, all ctypes type instances contain a memory block that hold C
1998 compatible data; the address of the memory block is returned by the
1999 ``addressof()`` helper function. Another instance variable is exposed as
2000 :attr:`_objects`; this contains other Python objects that need to be kept alive
2001 in case the memory block contains pointers.
2002
Benjamin Petersone41251e2008-04-25 01:59:09 +00002003 Common methods of ctypes data types, these are all class methods (to be
2004 exact, they are methods of the :term:`metaclass`):
Georg Brandl116aa622007-08-15 14:28:22 +00002005
2006
Christian Heimes81ee3ef2008-05-04 22:42:01 +00002007 .. method:: _CData.from_buffer(source[, offset])
2008
2009 This method returns a ctypes instance that shares the buffer of
2010 the ``source`` object. The ``source`` object must support the
2011 writeable buffer interface. The optional ``offset`` parameter
2012 specifies an offset into the source buffer in bytes; the default
2013 is zero. If the source buffer is not large enough a ValueError
2014 is raised.
2015
Christian Heimes81ee3ef2008-05-04 22:42:01 +00002016
2017 .. method:: _CData.from_buffer_copy(source[, offset])
2018
Benjamin Peterson3e4f0552008-09-02 00:31:15 +00002019 This method creates a ctypes instance, copying the buffer from
Christian Heimes81ee3ef2008-05-04 22:42:01 +00002020 the source object buffer which must be readable. The optional
2021 ``offset`` parameter specifies an offset into the source buffer
2022 in bytes; the default is zero. If the source buffer is not
2023 large enough a ValueError is raised.
2024
Christian Heimes81ee3ef2008-05-04 22:42:01 +00002025
Benjamin Petersone41251e2008-04-25 01:59:09 +00002026 .. method:: from_address(address)
Georg Brandl116aa622007-08-15 14:28:22 +00002027
Benjamin Petersone41251e2008-04-25 01:59:09 +00002028 This method returns a ctypes type instance using the memory specified by
2029 address which must be an integer.
Georg Brandl116aa622007-08-15 14:28:22 +00002030
2031
Benjamin Petersone41251e2008-04-25 01:59:09 +00002032 .. method:: from_param(obj)
Georg Brandl116aa622007-08-15 14:28:22 +00002033
Benjamin Peterson3e4f0552008-09-02 00:31:15 +00002034 This method adapts *obj* to a ctypes type. It is called with the actual
2035 object used in a foreign function call when the type is present in the
2036 foreign function's :attr:`argtypes` tuple; it must return an object that
2037 can be used as a function call parameter.
Georg Brandl116aa622007-08-15 14:28:22 +00002038
Benjamin Peterson3e4f0552008-09-02 00:31:15 +00002039 All ctypes data types have a default implementation of this classmethod
2040 that normally returns ``obj`` if that is an instance of the type. Some
Benjamin Petersone41251e2008-04-25 01:59:09 +00002041 types accept other objects as well.
Georg Brandl116aa622007-08-15 14:28:22 +00002042
2043
Benjamin Petersone41251e2008-04-25 01:59:09 +00002044 .. method:: in_dll(library, name)
Georg Brandl116aa622007-08-15 14:28:22 +00002045
Benjamin Petersone41251e2008-04-25 01:59:09 +00002046 This method returns a ctypes type instance exported by a shared
2047 library. *name* is the name of the symbol that exports the data, *library*
2048 is the loaded shared library.
Georg Brandl116aa622007-08-15 14:28:22 +00002049
2050
Benjamin Petersone41251e2008-04-25 01:59:09 +00002051 Common instance variables of ctypes data types:
Georg Brandl116aa622007-08-15 14:28:22 +00002052
2053
Benjamin Petersone41251e2008-04-25 01:59:09 +00002054 .. attribute:: _b_base_
Georg Brandl116aa622007-08-15 14:28:22 +00002055
Benjamin Petersone41251e2008-04-25 01:59:09 +00002056 Sometimes ctypes data instances do not own the memory block they contain,
2057 instead they share part of the memory block of a base object. The
2058 :attr:`_b_base_` read-only member is the root ctypes object that owns the
2059 memory block.
Georg Brandl116aa622007-08-15 14:28:22 +00002060
2061
Benjamin Petersone41251e2008-04-25 01:59:09 +00002062 .. attribute:: _b_needsfree_
Georg Brandl116aa622007-08-15 14:28:22 +00002063
Benjamin Petersone41251e2008-04-25 01:59:09 +00002064 This read-only variable is true when the ctypes data instance has
2065 allocated the memory block itself, false otherwise.
2066
2067
2068 .. attribute:: _objects
2069
2070 This member is either ``None`` or a dictionary containing Python objects
2071 that need to be kept alive so that the memory block contents is kept
2072 valid. This object is only exposed for debugging; never modify the
2073 contents of this dictionary.
Georg Brandl116aa622007-08-15 14:28:22 +00002074
2075
2076.. _ctypes-fundamental-data-types-2:
2077
2078Fundamental data types
2079^^^^^^^^^^^^^^^^^^^^^^
2080
2081
2082.. class:: _SimpleCData
2083
Benjamin Peterson35e8c462008-04-24 02:34:53 +00002084 This non-public class is the base class of all fundamental ctypes data
2085 types. It is mentioned here because it contains the common attributes of the
2086 fundamental ctypes data types. ``_SimpleCData`` is a subclass of ``_CData``,
2087 so it inherits their methods and attributes. ctypes data types that are not
2088 and do not contain pointers can now be pickled.
Thomas Heller13394e92008-02-13 20:40:44 +00002089
Benjamin Petersone41251e2008-04-25 01:59:09 +00002090 Instances have a single attribute:
Georg Brandl116aa622007-08-15 14:28:22 +00002091
2092
Benjamin Petersone41251e2008-04-25 01:59:09 +00002093 .. attribute:: value
Georg Brandl116aa622007-08-15 14:28:22 +00002094
Benjamin Petersone41251e2008-04-25 01:59:09 +00002095 This attribute contains the actual value of the instance. For integer and
2096 pointer types, it is an integer, for character types, it is a single
2097 character string, for character pointer types it is a Python string or
2098 unicode string.
Georg Brandl116aa622007-08-15 14:28:22 +00002099
Benjamin Petersone41251e2008-04-25 01:59:09 +00002100 When the ``value`` attribute is retrieved from a ctypes instance, usually
2101 a new object is returned each time. ``ctypes`` does *not* implement
2102 original object return, always a new object is constructed. The same is
2103 true for all other ctypes object instances.
Georg Brandl116aa622007-08-15 14:28:22 +00002104
2105Fundamental data types, when returned as foreign function call results, or, for
2106example, by retrieving structure field members or array items, are transparently
2107converted to native Python types. In other words, if a foreign function has a
2108:attr:`restype` of :class:`c_char_p`, you will always receive a Python string,
2109*not* a :class:`c_char_p` instance.
2110
Thomas Woutersed03b412007-08-28 21:37:11 +00002111Subclasses of fundamental data types do *not* inherit this behavior. So, if a
Georg Brandl116aa622007-08-15 14:28:22 +00002112foreign functions :attr:`restype` is a subclass of :class:`c_void_p`, you will
2113receive an instance of this subclass from the function call. Of course, you can
2114get the value of the pointer by accessing the ``value`` attribute.
2115
2116These are the fundamental ctypes data types:
2117
2118
2119.. class:: c_byte
2120
2121 Represents the C signed char datatype, and interprets the value as small
2122 integer. The constructor accepts an optional integer initializer; no overflow
2123 checking is done.
2124
2125
2126.. class:: c_char
2127
2128 Represents the C char datatype, and interprets the value as a single character.
2129 The constructor accepts an optional string initializer, the length of the string
2130 must be exactly one character.
2131
2132
2133.. class:: c_char_p
2134
2135 Represents the C char \* datatype, which must be a pointer to a zero-terminated
2136 string. The constructor accepts an integer address, or a string.
2137
2138
2139.. class:: c_double
2140
2141 Represents the C double datatype. The constructor accepts an optional float
2142 initializer.
2143
2144
Thomas Wouters89d996e2007-09-08 17:39:28 +00002145.. class:: c_longdouble
2146
2147 Represents the C long double datatype. The constructor accepts an
2148 optional float initializer. On platforms where ``sizeof(long
2149 double) == sizeof(double)`` it is an alias to :class:`c_double`.
2150
Georg Brandl116aa622007-08-15 14:28:22 +00002151.. class:: c_float
2152
Thomas Wouters89d996e2007-09-08 17:39:28 +00002153 Represents the C float datatype. The constructor accepts an optional float
Georg Brandl116aa622007-08-15 14:28:22 +00002154 initializer.
2155
2156
2157.. class:: c_int
2158
2159 Represents the C signed int datatype. The constructor accepts an optional
2160 integer initializer; no overflow checking is done. On platforms where
2161 ``sizeof(int) == sizeof(long)`` it is an alias to :class:`c_long`.
2162
2163
2164.. class:: c_int8
2165
2166 Represents the C 8-bit ``signed int`` datatype. Usually an alias for
2167 :class:`c_byte`.
2168
2169
2170.. class:: c_int16
2171
2172 Represents the C 16-bit signed int datatype. Usually an alias for
2173 :class:`c_short`.
2174
2175
2176.. class:: c_int32
2177
2178 Represents the C 32-bit signed int datatype. Usually an alias for
2179 :class:`c_int`.
2180
2181
2182.. class:: c_int64
2183
2184 Represents the C 64-bit ``signed int`` datatype. Usually an alias for
2185 :class:`c_longlong`.
2186
2187
2188.. class:: c_long
2189
2190 Represents the C ``signed long`` datatype. The constructor accepts an optional
2191 integer initializer; no overflow checking is done.
2192
2193
2194.. class:: c_longlong
2195
2196 Represents the C ``signed long long`` datatype. The constructor accepts an
2197 optional integer initializer; no overflow checking is done.
2198
2199
2200.. class:: c_short
2201
2202 Represents the C ``signed short`` datatype. The constructor accepts an optional
2203 integer initializer; no overflow checking is done.
2204
2205
2206.. class:: c_size_t
2207
2208 Represents the C ``size_t`` datatype.
2209
2210
2211.. class:: c_ubyte
2212
2213 Represents the C ``unsigned char`` datatype, it interprets the value as small
2214 integer. The constructor accepts an optional integer initializer; no overflow
2215 checking is done.
2216
2217
2218.. class:: c_uint
2219
2220 Represents the C ``unsigned int`` datatype. The constructor accepts an optional
2221 integer initializer; no overflow checking is done. On platforms where
2222 ``sizeof(int) == sizeof(long)`` it is an alias for :class:`c_ulong`.
2223
2224
2225.. class:: c_uint8
2226
2227 Represents the C 8-bit unsigned int datatype. Usually an alias for
2228 :class:`c_ubyte`.
2229
2230
2231.. class:: c_uint16
2232
2233 Represents the C 16-bit unsigned int datatype. Usually an alias for
2234 :class:`c_ushort`.
2235
2236
2237.. class:: c_uint32
2238
2239 Represents the C 32-bit unsigned int datatype. Usually an alias for
2240 :class:`c_uint`.
2241
2242
2243.. class:: c_uint64
2244
2245 Represents the C 64-bit unsigned int datatype. Usually an alias for
2246 :class:`c_ulonglong`.
2247
2248
2249.. class:: c_ulong
2250
2251 Represents the C ``unsigned long`` datatype. The constructor accepts an optional
2252 integer initializer; no overflow checking is done.
2253
2254
2255.. class:: c_ulonglong
2256
2257 Represents the C ``unsigned long long`` datatype. The constructor accepts an
2258 optional integer initializer; no overflow checking is done.
2259
2260
2261.. class:: c_ushort
2262
2263 Represents the C ``unsigned short`` datatype. The constructor accepts an
2264 optional integer initializer; no overflow checking is done.
2265
2266
2267.. class:: c_void_p
2268
2269 Represents the C ``void *`` type. The value is represented as integer. The
2270 constructor accepts an optional integer initializer.
2271
2272
2273.. class:: c_wchar
2274
2275 Represents the C ``wchar_t`` datatype, and interprets the value as a single
2276 character unicode string. The constructor accepts an optional string
2277 initializer, the length of the string must be exactly one character.
2278
2279
2280.. class:: c_wchar_p
2281
2282 Represents the C ``wchar_t *`` datatype, which must be a pointer to a
2283 zero-terminated wide character string. The constructor accepts an integer
2284 address, or a string.
2285
2286
2287.. class:: c_bool
2288
2289 Represent the C ``bool`` datatype (more accurately, _Bool from C99). Its value
2290 can be True or False, and the constructor accepts any object that has a truth
2291 value.
2292
Georg Brandl116aa622007-08-15 14:28:22 +00002293
2294.. class:: HRESULT
2295
2296 Windows only: Represents a :class:`HRESULT` value, which contains success or
2297 error information for a function or method call.
2298
2299
2300.. class:: py_object
2301
2302 Represents the C ``PyObject *`` datatype. Calling this without an argument
2303 creates a ``NULL`` ``PyObject *`` pointer.
2304
2305The ``ctypes.wintypes`` module provides quite some other Windows specific data
2306types, for example ``HWND``, ``WPARAM``, or ``DWORD``. Some useful structures
2307like ``MSG`` or ``RECT`` are also defined.
2308
2309
2310.. _ctypes-structured-data-types:
2311
2312Structured data types
2313^^^^^^^^^^^^^^^^^^^^^
2314
2315
2316.. class:: Union(*args, **kw)
2317
2318 Abstract base class for unions in native byte order.
2319
2320
2321.. class:: BigEndianStructure(*args, **kw)
2322
2323 Abstract base class for structures in *big endian* byte order.
2324
2325
2326.. class:: LittleEndianStructure(*args, **kw)
2327
2328 Abstract base class for structures in *little endian* byte order.
2329
2330Structures with non-native byte order cannot contain pointer type fields, or any
2331other data types containing pointer type fields.
2332
2333
2334.. class:: Structure(*args, **kw)
2335
2336 Abstract base class for structures in *native* byte order.
2337
Benjamin Petersone41251e2008-04-25 01:59:09 +00002338 Concrete structure and union types must be created by subclassing one of these
2339 types, and at least define a :attr:`_fields_` class variable. ``ctypes`` will
2340 create :term:`descriptor`\s which allow reading and writing the fields by direct
2341 attribute accesses. These are the
Georg Brandl116aa622007-08-15 14:28:22 +00002342
2343
Benjamin Petersone41251e2008-04-25 01:59:09 +00002344 .. attribute:: _fields_
Georg Brandl116aa622007-08-15 14:28:22 +00002345
Benjamin Petersone41251e2008-04-25 01:59:09 +00002346 A sequence defining the structure fields. The items must be 2-tuples or
2347 3-tuples. The first item is the name of the field, the second item
2348 specifies the type of the field; it can be any ctypes data type.
Georg Brandl116aa622007-08-15 14:28:22 +00002349
Benjamin Petersone41251e2008-04-25 01:59:09 +00002350 For integer type fields like :class:`c_int`, a third optional item can be
2351 given. It must be a small positive integer defining the bit width of the
2352 field.
Georg Brandl116aa622007-08-15 14:28:22 +00002353
Benjamin Petersone41251e2008-04-25 01:59:09 +00002354 Field names must be unique within one structure or union. This is not
2355 checked, only one field can be accessed when names are repeated.
Georg Brandl116aa622007-08-15 14:28:22 +00002356
Benjamin Petersone41251e2008-04-25 01:59:09 +00002357 It is possible to define the :attr:`_fields_` class variable *after* the
2358 class statement that defines the Structure subclass, this allows to create
2359 data types that directly or indirectly reference themselves::
Georg Brandl116aa622007-08-15 14:28:22 +00002360
Benjamin Petersone41251e2008-04-25 01:59:09 +00002361 class List(Structure):
2362 pass
2363 List._fields_ = [("pnext", POINTER(List)),
2364 ...
2365 ]
Georg Brandl116aa622007-08-15 14:28:22 +00002366
Benjamin Petersone41251e2008-04-25 01:59:09 +00002367 The :attr:`_fields_` class variable must, however, be defined before the
2368 type is first used (an instance is created, ``sizeof()`` is called on it,
2369 and so on). Later assignments to the :attr:`_fields_` class variable will
2370 raise an AttributeError.
Georg Brandl116aa622007-08-15 14:28:22 +00002371
Benjamin Petersone41251e2008-04-25 01:59:09 +00002372 Structure and union subclass constructors accept both positional and named
2373 arguments. Positional arguments are used to initialize the fields in the
2374 same order as they appear in the :attr:`_fields_` definition, named
2375 arguments are used to initialize the fields with the corresponding name.
Georg Brandl116aa622007-08-15 14:28:22 +00002376
Benjamin Petersone41251e2008-04-25 01:59:09 +00002377 It is possible to defined sub-subclasses of structure types, they inherit
2378 the fields of the base class plus the :attr:`_fields_` defined in the
2379 sub-subclass, if any.
Georg Brandl116aa622007-08-15 14:28:22 +00002380
2381
Benjamin Petersone41251e2008-04-25 01:59:09 +00002382 .. attribute:: _pack_
Georg Brandl116aa622007-08-15 14:28:22 +00002383
Benjamin Petersone41251e2008-04-25 01:59:09 +00002384 An optional small integer that allows to override the alignment of
2385 structure fields in the instance. :attr:`_pack_` must already be defined
2386 when :attr:`_fields_` is assigned, otherwise it will have no effect.
Georg Brandl116aa622007-08-15 14:28:22 +00002387
2388
Benjamin Petersone41251e2008-04-25 01:59:09 +00002389 .. attribute:: _anonymous_
Georg Brandl116aa622007-08-15 14:28:22 +00002390
Benjamin Petersone41251e2008-04-25 01:59:09 +00002391 An optional sequence that lists the names of unnamed (anonymous) fields.
2392 ``_anonymous_`` must be already defined when :attr:`_fields_` is assigned,
2393 otherwise it will have no effect.
Georg Brandl116aa622007-08-15 14:28:22 +00002394
Benjamin Petersone41251e2008-04-25 01:59:09 +00002395 The fields listed in this variable must be structure or union type fields.
2396 ``ctypes`` will create descriptors in the structure type that allows to
2397 access the nested fields directly, without the need to create the
2398 structure or union field.
Georg Brandl116aa622007-08-15 14:28:22 +00002399
Benjamin Petersone41251e2008-04-25 01:59:09 +00002400 Here is an example type (Windows)::
Georg Brandl116aa622007-08-15 14:28:22 +00002401
Benjamin Petersone41251e2008-04-25 01:59:09 +00002402 class _U(Union):
2403 _fields_ = [("lptdesc", POINTER(TYPEDESC)),
2404 ("lpadesc", POINTER(ARRAYDESC)),
2405 ("hreftype", HREFTYPE)]
Georg Brandl116aa622007-08-15 14:28:22 +00002406
Benjamin Petersone41251e2008-04-25 01:59:09 +00002407 class TYPEDESC(Structure):
Benjamin Petersonb58dda72009-01-18 22:27:04 +00002408 _anonymous_ = ("u",)
Benjamin Petersone41251e2008-04-25 01:59:09 +00002409 _fields_ = [("u", _U),
2410 ("vt", VARTYPE)]
Georg Brandl116aa622007-08-15 14:28:22 +00002411
Georg Brandl116aa622007-08-15 14:28:22 +00002412
Benjamin Petersone41251e2008-04-25 01:59:09 +00002413 The ``TYPEDESC`` structure describes a COM data type, the ``vt`` field
2414 specifies which one of the union fields is valid. Since the ``u`` field
2415 is defined as anonymous field, it is now possible to access the members
2416 directly off the TYPEDESC instance. ``td.lptdesc`` and ``td.u.lptdesc``
2417 are equivalent, but the former is faster since it does not need to create
2418 a temporary union instance::
Georg Brandl116aa622007-08-15 14:28:22 +00002419
Benjamin Petersone41251e2008-04-25 01:59:09 +00002420 td = TYPEDESC()
2421 td.vt = VT_PTR
2422 td.lptdesc = POINTER(some_type)
2423 td.u.lptdesc = POINTER(some_type)
Georg Brandl116aa622007-08-15 14:28:22 +00002424
2425It is possible to defined sub-subclasses of structures, they inherit the fields
2426of the base class. If the subclass definition has a separate :attr:`_fields_`
2427variable, the fields specified in this are appended to the fields of the base
2428class.
2429
2430Structure and union constructors accept both positional and keyword arguments.
2431Positional arguments are used to initialize member fields in the same order as
2432they are appear in :attr:`_fields_`. Keyword arguments in the constructor are
2433interpreted as attribute assignments, so they will initialize :attr:`_fields_`
2434with the same name, or create new attributes for names not present in
2435:attr:`_fields_`.
2436
2437
2438.. _ctypes-arrays-pointers:
2439
2440Arrays and pointers
2441^^^^^^^^^^^^^^^^^^^
2442
2443Not yet written - please see the sections :ref:`ctypes-pointers` and
2444section :ref:`ctypes-arrays` in the tutorial.
2445