-
-
Notifications
You must be signed in to change notification settings - Fork 105
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
Provide python executable compiled with enable-shared #595
Comments
All of the symbols are in the |
@jakirkham Thanks for the suggestion. I think currently the library I'm trying to use links against libpython. It does so somehow using a cmake script. Do you know if I need to recompile or if I can patch the library to point to the python executable? |
Sometimes build scripts can be tricked by creating a symlink from |
At least on my platform (OSX arm64), it fails. Build script: # LIBPATH=.../libpython3.10.dylib
# EXECPATH=.../python3.10
mv $LIBPATH $LIBPATH.tmp
trap "mv $LIBPATH.tmp $LIBPATH" EXIT
ln -s $EXECPATH $LIBPATH
...
(cmake) Output:
|
- Find Python functions in the interpreter binary itself rather than trying to find libpython.dylib, because this doesn't exist when using Conda. (conda-forge/python-feedstock#595 (comment)) - Increase the stack size of both the Python main thread and the OS main thread to 16MiB, to match what Python normally uses on macOS. (https://github.com/python/cpython/blob/3.11/configure#L11038) - Check whether dlfcn and pthread function calls actually succeeds. Emit error messages and exit on failure rather than continuing the program (which generally leads to segfaults). - Fix pixelated shadow in the icon. PiperOrigin-RevId: 517390522 Change-Id: Ib91679b4baa63bac5f6b5893e634712d72161ea5
Comment:
Related: #222 (comment) .
My use-case: lammps/lammps#3520
This could be provided as a subpackage, say python-shared, and install a python.VERSION_shared that the user could symlink or put in front of $PATH, as needed.
I would have built it myself but I am a bit lost since building this recipe with enable-shared is not being easy.
The usual ways of debugging a failing conda build do not work with this package: conda debug ends up giving me an environment where there's no script to activate the environment and no build script either, perhaps because the recipe has multiple outputs and conda debug does not know what to do with it.
So far had to remove the libpython-static output, make the recipe a single output recipe, move
build_base.sh
tobuild.sh
, edit outscript:build.sh
, comment outrm .../libpython(...)$VERSION(...).a
in build_shared, and add f toln -sf ../../libpython${VERABI}.a libpython${VERABI}.a
in build_static.The last hurdle is that after building, conda build packages it, where it alters the paths that libraries/execs refer too ( I'm not very knowledgeable about this) and it fails with this message, which I guess has to do with signing in osx-arm64.
PS: fixed it by editing conda-builld/.../post.py conda/conda-build#4392 (comment)
Tests do not pass (tkinter something), but I installed the package anyways and for my use-case it seems to function
PS: does not.
conda_build_config.yaml
included in the repo overrode the one I had in my home folder, so it did not pick up on theopenssl==1.1
constraint and then when I replaced the python in my installation with the shared one it complained it could not findlibssl.3.dylib
.After fixing that, for some reason 'libffi.7.dylib' was required by 'import _ctypes', which I fixed in the install environment by symlinking 'libffi.8.dylib' to 'libffi.7.dylib'.
The text was updated successfully, but these errors were encountered: