aboutsummaryrefslogtreecommitdiff
path: root/docs
diff options
context:
space:
mode:
authorEli Schwartz <eschwartz@archlinux.org>2022-04-18 22:27:09 -0400
committerXavier Claessens <xclaesse@gmail.com>2022-05-09 10:49:04 -0400
commitaa874ea0d020aee90595c2adfb43866fcaabfdb7 (patch)
tree2ac79d646259bfb338ccc3ccbf2cd2fc80b30296 /docs
parent7c4087ace5b3b1c8669d7afd2b6fbcc0c816f1d4 (diff)
downloadmeson-aa874ea0d020aee90595c2adfb43866fcaabfdb7.zip
meson-aa874ea0d020aee90595c2adfb43866fcaabfdb7.tar.gz
meson-aa874ea0d020aee90595c2adfb43866fcaabfdb7.tar.bz2
python module: default extensions to hidden symbol visibility
python compiled extensions should never need to expose any symbol other than PyInit_* which is declared with default visibility via PyMODINIT_FUNC on supported compilers. Thus, a reasonably sane default is to mark any other symbols as hidden, while still respecting any manually specified visibility. Gate this on the version of python itself, as not all versions decorate PyMODINIT_FUNC properly.
Diffstat (limited to 'docs')
-rw-r--r--docs/markdown/Python-module.md6
-rw-r--r--docs/markdown/snippets/python-extension-module-visibility.md12
2 files changed, 18 insertions, 0 deletions
diff --git a/docs/markdown/Python-module.md b/docs/markdown/Python-module.md
index 0602955..8809fd0 100644
--- a/docs/markdown/Python-module.md
+++ b/docs/markdown/Python-module.md
@@ -93,6 +93,12 @@ the addition of the following:
it will be appended to that location. This keyword argument is
mutually exclusive with `install_dir`
+Additionally, the following diverge from [[shared_module]]'s default behavior:
+
+- `gnu_symbol_visibility`: if unset, it will default to `'hidden'` on versions
+ of Python that support this (the python headers define `PyMODINIT_FUNC` has
+ default visibility).
+
`extension_module` does not add any dependencies to the library so
user may need to add `dependencies : py_installation.dependency()`,
see [[dependency]].
diff --git a/docs/markdown/snippets/python-extension-module-visibility.md b/docs/markdown/snippets/python-extension-module-visibility.md
new file mode 100644
index 0000000..ed1fc48
--- /dev/null
+++ b/docs/markdown/snippets/python-extension-module-visibility.md
@@ -0,0 +1,12 @@
+## Python extension modules now build with hidden visibility
+
+Python extension modules are usually expected to only export a single symbol,
+decorated with the `PyMODINIT_FUNC` macro and providing the module entry point.
+On versions of python >= 3.9, the python headers contain GNU symbol visibility
+attributes to mark the init function with default visibility; it is then safe
+to set the [[shared_module]] inherited kwarg `gnu_symbol_visibility: 'hidden'`.
+
+In the interest of doing the right thing out of the box, this is now the
+default for extension modules for found installations that are new enough to
+have this set, which is not expected to break anything, but remains possible to
+set explicitly (in which case that will take precedence).