diff options
author | Fred Drake <fdrake@acm.org> | 2000-09-08 22:54:53 (GMT) |
---|---|---|
committer | Fred Drake <fdrake@acm.org> | 2000-09-08 22:54:53 (GMT) |
commit | 1c258036474b70c8c59c0be62cb8b97f94463fe3 (patch) | |
tree | 1c02d37b64bf337a77b7491853aa32bfa6d3ed20 | |
parent | e1c9e85559cf5292d992312cc3049794746b4aa3 (diff) | |
download | cpython-1c258036474b70c8c59c0be62cb8b97f94463fe3.zip cpython-1c258036474b70c8c59c0be62cb8b97f94463fe3.tar.gz cpython-1c258036474b70c8c59c0be62cb8b97f94463fe3.tar.bz2 |
Add a brief section on linking Python as an embedded scripting language.
This closes SourceForge bug #110833.
-rw-r--r-- | Doc/ext/ext.tex | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/Doc/ext/ext.tex b/Doc/ext/ext.tex index 2aef7e8..d54b78c 100644 --- a/Doc/ext/ext.tex +++ b/Doc/ext/ext.tex @@ -2111,4 +2111,41 @@ will need to write the main program in \Cpp{}, and use the \Cpp{} compiler to compile and link your program. There is no need to recompile Python itself using \Cpp{}. + +\section{Linking Requirements + \label{link-reqs}} + +While the \program{configure} script shipped with the Python sources +will correctly build Python to export the symbols needed by +dynamically linked extensions, this is not automatically inherited by +applications which embed the Python library statically, at least on +\UNIX. This is an issue when the application is linked to the static +runtime library (\file{libpython.a}) and needs to load dynamic +extensions (implemented as \file{.so} files). + +The problem is that some entry points are defined by the Python +runtime solely for extension modules to use. If the embedding +application does not use any of these entry points, some linkers will +not include those entries in the symbol table of the finished +executable. Some additional options are needed to inform the linker +not to remove these symbols. + +Determining the right options to use for any given platform can be +quite difficult, but fortunately the Python configuration already has +those values. To retrieve them from an installed Python interpreter, +start an interactive interpreter and have a short session like this: + +\begin{verbatim} +>>> import distutils.sysconfig +>>> distutils.sysconfig.LINKFORSHARED +'-Xlinker -export-dynamic' +\end{verbatim} +\refstmodindex{distutils.sysconfig} + +The contents of the string presented will be the options that should +be used. If the string is empty, there's no need to add any +additional options. The \constant{LINKFORSHARED} definition +corresponds to the variable of the same name in Python's top-level +\file{Makefile}. + \end{document} |