-
Notifications
You must be signed in to change notification settings - Fork 156
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
Fix for bigsur #386
Fix for bigsur #386
Conversation
@Czaki what information do you need?
Do you need a dylib compiled for Big Sur? With any specific settings? |
Co-authored-by: FX Coudert <fxcoudert@gmail.com>
I would like to have such a file to add it to But from your response, I see that they not change binary representation. |
The file produced is available (for a couple of days) at: https://filesender.renater.fr/?s=download&token=f2be417a-d8f1-40c6-a984-fb89fc679426 It's produced on Big Sur 11.0.1 with Xcode 12.2. It has:
|
A file compiled on macOS 11.1 (beta) with Xcode 12.3 (beta) and the 11.1 (beta) SDK has:
You will find 3 files compiled on that platform here: one for arm, one of Intel, one fat.
There are available here: https://filesender.renater.fr/?s=download&token=d22c471a-7db4-4094-985c-d9dcafc1ce63 I hope that helps. If you have more specific requirements, please let me know. |
if fat is now selected as architecture for macos x86_64 and arm packed wheel? Up to this moment, wheel does not support arm detection from wheel. |
See also #387. |
arm64 is already handled correctly by wheel/macosx_libfile.py because that code doesn't look at the CPU architecture but does handle fat binaries. |
Ok. I was work on this in matthew-brett/delocate#61 and matthew-brett/delocate#68. But it was not finished because of a lack of macOS knowledge and access to macOS hardware with different systems. But I think that at this moment it should be added. If someone installs universal python but builds libraries only for arm it should not have a universal platform tag. |
I guess I miscommunicated, its getting late for me. Wheel already handles "universal2" binaries, except for the issue with the deployment target described in #387. To demonstrate: https://pypi.org/project/pyobjc-core/#files. The latest release includes a "universal2" wheel that worked out of the box once the PR for macOS 11 was merged. |
You can not calculate the minimum version per files. It is bad idea. Calculate maximum per file for given architecture and minimum per architecture seams good. |
Is this PR ready for merging? If not, mark it as a draft PR. |
@agronholm For me it is ready but @ronaldoussoren has some requests. Merging this will allow creating bugfix release which fixes build on macOS 11 bigsur. But if you prefer to wait on a full fix (where the decision about calculates the platform tag needs to be done) I could change this to draft. |
How long do you think the full fix would take? |
I do not know. It depends on how long will take a discussion. I rather prefer to create more wheel than @ronaldoussoren approach. |
Wheels can already not work, I recently installed a wheel that required me to install homebrew and a particular homebrew package. IMHO that's not something this package should try to protect against. My questions are in a separate issue, IMHO that discussion is not blocking for this PR. |
The question is how this bug is handled. If it is an ugly long stack trace or a simple message prepared by the package maintainer. @agronholm I suggest merging it and create a bugfix release. Then there be the next PR for the final solution. |
Thanks. |
Fix for issue #385
@fxcoudert @ronaldoussoren could you test it?
This PR still does not have tests for
extract_macosx_min_system_version
function. To add such a test I need some files compiled for the BigSur system.