The Python/C API Release 3.6.0

The Python/C API Release 3.6.0

The Python/C API Release 3.6.0 Guido van Rossum and the Python development team March 05, 2017 Python Software Foundation Email: [email protected] CONTENTS 1 Introduction 3 1.1 Include Files...............................................3 1.2 Objects, Types and Reference Counts..................................4 1.3 Exceptions................................................7 1.4 Embedding Python............................................9 1.5 Debugging Builds............................................ 10 2 Stable Application Binary Interface 11 3 The Very High Level Layer 13 4 Reference Counting 19 5 Exception Handling 21 5.1 Printing and clearing........................................... 21 5.2 Raising exceptions............................................ 22 5.3 Issuing warnings............................................. 24 5.4 Querying the error indicator....................................... 25 5.5 Signal Handling............................................. 26 5.6 Exception Classes............................................ 27 5.7 Exception Objects............................................ 27 5.8 Unicode Exception Objects....................................... 28 5.9 Recursion Control............................................ 29 5.10 Standard Exceptions........................................... 29 6 Utilities 33 6.1 Operating System Utilities........................................ 33 6.2 System Functions............................................. 34 6.3 Process Control.............................................. 35 6.4 Importing Modules............................................ 36 6.5 Data marshalling support......................................... 39 6.6 Parsing arguments and building values................................. 40 6.7 String conversion and formatting.................................... 48 6.8 Reflection................................................. 49 6.9 Codec registry and support functions.................................. 50 7 Abstract Objects Layer 53 7.1 Object Protocol.............................................. 53 7.2 Number Protocol............................................. 57 7.3 Sequence Protocol............................................ 60 7.4 Mapping Protocol............................................ 62 i 7.5 Iterator Protocol............................................. 62 7.6 Buffer Protocol.............................................. 63 7.7 Old Buffer Protocol........................................... 69 8 Concrete Objects Layer 71 8.1 Fundamental Objects........................................... 71 8.2 Numeric Objects............................................. 73 8.3 Sequence Objects............................................. 78 8.4 Container Objects............................................ 102 8.5 Function Objects............................................. 106 8.6 Other Objects............................................... 110 9 Initialization, Finalization, and Threads 125 9.1 Initializing and finalizing the interpreter................................. 125 9.2 Process-wide parameters......................................... 126 9.3 Thread State and the Global Interpreter Lock.............................. 129 9.4 Sub-interpreter support.......................................... 134 9.5 Asynchronous Notifications....................................... 135 9.6 Profiling and Tracing........................................... 135 9.7 Advanced Debugger Support....................................... 137 10 Memory Management 139 10.1 Overview................................................. 139 10.2 Raw Memory Interface.......................................... 140 10.3 Memory Interface............................................ 141 10.4 Customize Memory Allocators...................................... 142 10.5 The pymalloc allocator.......................................... 143 10.6 Examples................................................. 144 11 Object Implementation Support 147 11.1 Allocating Objects on the Heap..................................... 147 11.2 Common Object Structures....................................... 148 11.3 Type Objects............................................... 151 11.4 Number Object Structures........................................ 165 11.5 Mapping Object Structures........................................ 166 11.6 Sequence Object Structures....................................... 166 11.7 Buffer Object Structures......................................... 167 11.8 Async Object Structures......................................... 168 11.9 Supporting Cyclic Garbage Collection.................................. 169 12 API and ABI Versioning 171 A Glossary 173 B About these documents 185 B.1 Contributors to the Python Documentation............................... 185 C History and License 187 C.1 History of the software.......................................... 187 C.2 Terms and conditions for accessing or otherwise using Python..................... 188 C.3 Licenses and Acknowledgements for Incorporated Software...................... 191 D Copyright 205 Index 207 ii The Python/C API, Release 3.6.0 This manual documents the API used by C and C++ programmers who want to write extension modules or embed Python. It is a companion to extending-index, which describes the general principles of extension writing but does not document the API functions in detail. CONTENTS 1 The Python/C API, Release 3.6.0 2 CONTENTS CHAPTER ONE INTRODUCTION The Application Programmer’s Interface to Python gives C and C++ programmers access to the Python interpreter at a variety of levels. The API is equally usable from C++, but for brevity it is generally referred to as the Python/C API. There are two fundamentally different reasons for using the Python/C API. The first reason is to write extension modules for specific purposes; these are C modules that extend the Python interpreter. This is probably the most common use. The second reason is to use Python as a component in a larger application; this technique is generally referred to as embedding Python in an application. Writing an extension module is a relatively well-understood process, where a “cookbook” approach works well. There are several tools that automate the process to some extent. While people have embedded Python in other applications since its early existence, the process of embedding Python is less straightforward than writing an extension. Many API functions are useful independent of whether you’re embedding or extending Python; moreover, most ap- plications that embed Python will need to provide a custom extension as well, so it’s probably a good idea to become familiar with writing an extension before attempting to embed Python in a real application. 1.1 Include Files All function, type and macro definitions needed to use the Python/C API are included in your code by the following line: #include "Python.h" This implies inclusion of the following standard headers: <stdio.h>, <string.h>, <errno.h>, <limits.h>, <assert.h> and <stdlib.h> (if available). Note: Since Python may define some pre-processor definitions which affect the standard headers on some systems, you must include Python.h before any standard headers are included. All user visible names defined by Python.h (except those defined by the included standard headers) have one of the prefixes Py or _Py. Names beginning with _Py are for internal use by the Python implementation and should not be used by extension writers. Structure member names do not have a reserved prefix. Important: user code should never define names that begin with Py or _Py. This confuses the reader, and jeopardizes the portability of the user code to future Python versions, which may define additional names beginning with one of these prefixes. The header files are typically installed with Python. On Unix, these are located in the directories prefix/include/pythonversion/ and exec_prefix/include/pythonversion/, where prefix and exec_prefix are defined by the corresponding parameters to Python’s configure script and version is ’%d.%d’ % sys.version_info[:2]. On Windows, the headers are installed in prefix/include, where prefix is the installation directory specified to the installer. 3 The Python/C API, Release 3.6.0 To include the headers, place both directories (if different) on your compiler’s search path for includes. Do not place the parent directories on the search path and then use #include <pythonX.Y/Python.h>; this will break on multi-platform builds since the platform independent headers under prefix include the platform specific headers from exec_prefix. C++ users should note that though the API is defined entirely using C, the header files do properly declare the entry points to be extern "C", so there is no need to do anything special to use the API from C++. 1.2 Objects, Types and Reference Counts Most Python/C API functions have one or more arguments as well as a return value of type PyObject*. This type is a pointer to an opaque data type representing an arbitrary Python object. Since all Python object types are treated the same way by the Python language in most situations (e.g., assignments, scope rules, and argument passing), it is only fitting that they should be represented by a single C type. Almost all Python objects live on the heap: you never declare an automatic or static variable of type PyObject, only pointer variables of type PyObject* can be declared. The sole exception are the type objects; since these must never be deallocated, they are typically

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    226 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us