-
Notifications
You must be signed in to change notification settings - Fork 27
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
wheels should refuse to build if universal=1 but c exts are present #29
Comments
The note you copied says that it's for pure python packages that are source compatible across 2 and 3. Wheels are ready for most of their use cases and they do solve problems today. Just because you can't be bothered to setup infrastructure to manage building them on a project of yours that has C exts does not make them useless. |
Mike, wheels already solve a problem - there are projects that do have their own build farms (or a sufficiently large number of volunteers involved), and wheels allow those projects to take the burden of compilation off end users by providing pre-built binaries. For pure Python projects, it also makes it easy to speed up installation for end users, as installing from a wheel file is much faster than installing from source. The challenge is for projects in the middle, where they do have C extensions, but don't have the capacity to provide pre-built wheel files for all supported versions on both Mac OS X and Windows. Since pip will fall back to installing from source if there's no appropriate wheel file available, it's entirely possible to create platform specific wheels for one or two popular OS and version combinations where making things easy for new users is particularly desirable (such as 2.7 and the latest 3.x on Windows), but that's still additional work that volunteers may not have the time or interest to pursue. In those cases, it would be good if pythonwheels.com could offer a mechanism for the maintainers of affected projects to explain the problem, rather than having the site effectively label them as "bad". Reviewing the site, I also realised it inaccurately treats platform and architecture specific builds as inferior to pure Python packages: this is wrong, as the main purpose of wheels is to distribute pre-built binaries (while they do speed things up a bit in the pure Python case, that's a minor benefit compared to being able to skip the compilation step). Those projects should be green, not orange, as they're doing the right thing. That would free up orange to cover the cases where the maintainers have provided an explanation for why wheels aren't going to be available any time soon (and that's usually going to be "waiting on the availability of a public build farm for wheel archives"). A public build farm is a long term plan because it doesn't make sense to have everyone that wants to provide wheel files having to duplicate that infrastructure. However, it's not the only way to create them, publishing platform appropriate wheels does dramatically improve the experience for new users, and it's going to be quite some time before a public build farm is a feasible project for anyone to tackle - however, pythonwheels.com could provide a useful service in gauging interest in such a feature. Note also that requests for behavioural changes in the packaging tools themselves should be directed to distutils-sig and the Python Packaging Authority (e.g. via https://github.com/pypa/packaging-problems) - the pythonwheels site is an unaffiliated project that just monitors publicly available package metadata. |
@ncoghlan Yea I think I mentioned that awhile back when pythonwheels.com was being created. That orange for platform specific Wheels didn't make much sense. It might make sense to make it orange if they don't have Windows wheels or something but in general making it look bad if you have platform specific wheels is wrong. |
OK, we've established a. mike rants like a fool (we knew that) b. pythonwheels.com is a little misleading. So then also my original question: 1. what does "universal=1" mean, 2. if it means, "this is a pure python package", then why the heck does "python setup.py bdist_wheel" package .so files in the wheel file if universal=1? if those two conditions together make no sense, why should it proceed, or alternatively, if "universal=1" + "you have C extensions" does make sense, what does that mean ? |
universal=1 means that this wheel will work on all versions of Python. Generally it's only applicable to pure python wheels but it could also be applicable I suppose if a project has multiple .so's for different platforms inside it's Wheel and selects at runtime when importing which .so to actually import. But yes generally it's only useful for pure python. |
Also see #2 for the orange issue. |
Basically the way Wheels work, is the filename has a number of selectors/compatability tags in them. Pip tries to find the filename with the most specific set of selectors that still matches the current Python. If it can't find one it will fall back to a plain old source install. The universal flag just tells bdist_wheel to use Under the cover Wheels are just zip files which when installed are essentially just unzipped and moved into the proper place. There is no support to compile things or otherwise modify the output. Essentially Wheel can be installed mostly with One great thing that can be done is to upload Windows and maybe OSX wheels for things that require compilation because compiler toolchains on those platforms, especially Windows, can be more complex to set up and a lot of users don't have them. |
yes my original tweets regarding "what is the point?" are certainly more emotional than factual and of course being able to put a platform-specific build up is useful. However I do not see the point of a wheel file for a project that has no C extensions. I also think the "has multiple .so's present and is conceivably "universal"" idea you're getting at is nonexistent enough that there should at least be some kind of warning/ "are you sure you really want this mac-OSX .so to be "universal" and maybe instead you have no idea what you're doing and need to be alerted to that" type of message. A wheel that has .so's for multiple platforms is still not "universal". First of all, there are unlimited unix variants so no amount of .so files can ever be considered "universal", and secondly you'd at least need to see .dlls in that file as well for any semblence of "universal". |
Sure, there probably should be a warning and maybe even a flag to force it in that case. That would belong over on https://bitbucket.org/dholth/wheel. Sorry I didn't mean to sound like I was saying that was a reasonable use case. I was mostly spitballing in a "well here's one situation where maybe it would be useful" sort of way. As far as the point for a pure python project. Wheels install faster, a lot faster. They also have all static metadata which means tooling can introspect them for things like dependency information without executing a setup.py. Installing a sdist involves several subprocess calls to Python each of which has a cost to starting up. Installing a Wheel is unzip and shutil.move (a long with a little bit of extra stuff for shebang rewriting and such). In the long run we'll get an sdist format that also has static metadata but there will always be additional work that has to be done in order to install an sdist, even a pure Python one, that just doesn't exist in a Wheel. |
Oh forgot to mention too, that the "cost" of making a pure Python Wheel is very low so there's little reason not to add one for a pure python project. |
OK great, that is a reason then, I understand. So I think basically pythonwheels.com is a completely confusing and misleading site and someone should put up a site that lays the actual reasons out:
|
Yep, that summarises the situation well - I think Mike's last comment should be used as the basis for clarifying the text on pythonwheels.com itself, rather than it needing it to be done in a new site. I've also filed issue #30, suggesting some changes to the current colour scheme (mostly avoiding the use of red for projects that don't publish wheel files yet). |
One more thing to mention - wheels built using We're supposed to be getting away from implementation-defined to PEP standards-compliant behaviour, so while |
pydist.json is not part of the wheel 1.0 format, and PEP 426 is not an accepted specification. All currently defined aspects of the wheel format are in PEPs 425 and 427. Everything else is currently implementation dependent, and will remain so until PEPs 426, 440 and 459 are accepted. |
Right, but then perhaps |
Vinay, I'll reply over on the bdist_wheel tracker - this really isn't @meshy's problem to worry about :) |
Agreed, though I put it here because I thought the caveat ought to be mentioned on |
Hey everyone! Thanks for the insight into the future plans for packaging! (Build farm -- exciting!)
@ncoghlan Thanks for clarifying that, it is evidently a little unclear on pythonwheels.com, and I will try to see that something is done to make it clearer. I get the impression that all the things that need to be actioned here are being addressed by the ever vigilant @Ian-Foote in #33, so I'm going to close this issue. Thank you all for your participation. |
PS. @zzzeek I'm sorry to hear about the C-extensions in SQLAlchemy. |
as stated on http://pythonwheels.com/:
Note: If your project is python 2 and 3 compatible you can create a universal wheel distribution. Create a file called setup.cfg with the following content and upload your package.
[wheel]
universal = 1
Note: *this is not the solution for packages that have C extensions or other cases where a platform/architecture independent wheel is impossible. *
great, then instead of maintainers putting up useless wheels on pypi and creating confusion, have the wheel builder simply fail when the flag + C extensions are present, rather than causing confusion by building a non-universal wheel file. Per Nick Coghlan (https://twitter.com/ncoghlan_dev/status/437415973943922688):
"Hence why the long term plan is to eventually offer an automated build farm. Going to take a (long) while to get there, though."
what this means is, "wheels aren't ready". I don't understand why we're being bothered with them until they actually solve a problem.
sorry for the rant! just realized nobody's been running SQLAlchemy with C exts for a couple of months, since pip favors the wheel file over the source.
The text was updated successfully, but these errors were encountered: