-
Notifications
You must be signed in to change notification settings - Fork 212
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
nanobind: limited_api
not propagated to nanobind static library build
#1758
Comments
Well. It would be the latter, of course. The original limited API handling in meson didn't foresee the use of static libraries using the cpython API and implemented an express mode for extension modules but nothing for common utility libraries such as nanobind. This could be manually handled via hardcoded flags but we should probably add an API for it. This was discussed in the "implementation of nanobind" PR if I recall correctly but I don't know that anyone opened a dedicated tracking ticket for it. |
Glad you have been enjoying the wrapper! As far as the issue is concerned, I think this goes back to @wjakob callout before #1726 was merged, which I never followed up on nanobind uses its own internal macro when free-threaded builds are used, so I think we need to define Drawing inspiration from the conversation upstream in mesonbuild/meson#13656, I think something to the effect of: freethreaded = py.get_variable('Py_GIL_DISABLED', '') != ''
if freethreaded
add_project_arguments('-DNB_FREE_THREADED', language : 'cpp')
endif might do the trick in the configuration. Would you be able to try that out and push up a PR if it works? |
That would work for free threading, but wouldn't help with the limited API, right? I don't think anything useful about the limited API is exposed through Similarly, for the limited API, what if the define was propagated through the py = import('python').find_installation()
py_dep = py.dependency(limited_api : '3.12')
nanobind_lib = static_library(
...
dependencies: [py_dep, ...],
) Would that make sense? In this case, the This also wouldn't cover the case where someone wanted the |
Ah....sorry I mixed up the discussions. I should have read more closely. Here's some discussion around this in the original PR: I'm less knowledgeable about how this is handled in Meson / CPython so I will defer to the opinion of others here |
Hi @WillAyd,
Thank you for the excellent nanobind wrapper! I'm running into an issue when compiling limited API extensions that you might have some insight into. If I have a
meson.build
snippet like this:The compiler output shows that
src/example.cpp
is built with-DPy_LIMITED_API=0x030c0000
, but nanobind itself is not. For example:When building wheels this way, this leads to
abi3audit
violations, which is how I noticed this.So my question is: what's the right way to build the
nanobind_dep
static lib itself with the limited API flag?I poked around in the Meson source a bit, and it looks like
limited_api
mostly just sets-DPy_LIMITED_API
to the right hex value in thec_args
andcpp_args
of the shared extension (here). It doesn't seem like anything there knows about dependencies.So the question seems to be how to get the right
Py_LIMITED_API
value to pass tonanobind_dep
. Maybe it could be extracted from theextension_module
args (doesn't seem super clean), or maybe it could be exposed somewhere by Meson itself?The text was updated successfully, but these errors were encountered: