diff options
author | Benjamin Peterson <benjamin@python.org> | 2015-01-05 20:38:46 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2015-01-05 20:38:46 (GMT) |
commit | 0258c5de8b1df2691a227ec55d8853e74d7004e1 (patch) | |
tree | 612cd8f86d0b217b3ef166220f443c3de28a125f | |
parent | 7b4b28469b0c7b588f371d19fb4da90d63787b09 (diff) | |
download | cpython-0258c5de8b1df2691a227ec55d8853e74d7004e1.zip cpython-0258c5de8b1df2691a227ec55d8853e74d7004e1.tar.gz cpython-0258c5de8b1df2691a227ec55d8853e74d7004e1.tar.bz2 |
emphasize that cffi is better than extension modules for portability
-rw-r--r-- | Doc/extending/extending.rst | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/Doc/extending/extending.rst b/Doc/extending/extending.rst index 5488ce9..4b23463 100644 --- a/Doc/extending/extending.rst +++ b/Doc/extending/extending.rst @@ -20,12 +20,17 @@ source file by including the header ``"Python.h"``. The compilation of an extension module depends on its intended use as well as on your system setup; details are given in later chapters. -Do note that if your use case is calling C library functions or system calls, -you should consider using the :mod:`ctypes` module rather than writing custom -C code. Not only does :mod:`ctypes` let you write Python code to interface -with C code, but it is more portable between implementations of Python than -writing and compiling an extension module which typically ties you to CPython. +.. note:: + The C extension interface is specific to CPython, and extension modules do + not work on other Python implementations. In many cases, it is possible to + avoid writing C extensions and preserve portability to other implementations. + For example, if your use case is calling C library functions or system calls, + you should consider using the :mod:`ctypes` module or the `cffi + <http://cffi.readthedocs.org>`_ library rather than writing custom C code. + These modules let you write Python code to interface with C code and are more + portable between implementations of Python than writing and compiling a C + extension module. .. _extending-simpleexample: |