<p dir="ltr">On the one hand, it's easy to see the allure of a zipimport-able format. Grab a file, import it, use functionality straight away. It has an attraction of self-containedness. On the other hand, python's dynamic nature means that things are not as simple as Java jar's as Donald points out. I agree that wheels shouldn't officially support this feature wholesale. However, perhaps they could do so conditionally? E.g. designate some mechanism by which it is possible to inspect a wheel and determine that it intends to explicitly be zipimport compatible. A prime candidate would be that the wheel is of a purelib in nature, another would be to add a top-level file or metadata indicating such (e.g. '.zipimportable'). But other wise I agree that we should explicitly seek to avoid any language that could lead users to expect this functionality of wheels wholesale in any way, even though they happen to be regular zip files.</p>
<div class="gmail_quote">On 29 Jan 2014 17:09, "Donald Stufft" <<a href="mailto:donald@stufft.io">donald@stufft.io</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
On Jan 28, 2014, at 11:14 PM, Vinay Sajip <<a href="mailto:vinay_sajip@yahoo.co.uk">vinay_sajip@yahoo.co.uk</a>> wrote:<br>
<br>
> Donald Stufft <donald <at> <a href="http://stufft.io" target="_blank">stufft.io</a>> writes:<br>
><br>
>> I think we need to reconsider this. I cannot stress how badly an idea<br>
>> I think it is for Wheels to concern itself with the ability to add the<br>
>> Wheel to sys.path and import it.<br>
><br>
> I know that people have had bad experiences in the past with eggs, for the<br>
> reasons Nick outlined in his response. However, you don't say *with<br>
> specifics* why you think putting wheels on sys.path is a bad idea - I don't<br>
> think it's convincing enough just to hand-wavingly reference problems with<br>
> the egg format.<br>
><br>
> When this topic came up before, I asked for specific failure modes which<br>
> were causing concern, but I never got a response IIRC.<br>
><br>
> One can't say that having the same packaging and importable formats is<br>
> inherently bad, since Java shows otherwise. So if there are specific<br>
> problems, they should be identified.<br>
<br>
Last time this topic came up Jim Fulton did point things out.<br>
<br>
1. That unpacking into the home directory is problematic because users<br>
that run services often don’t have home directories. This you waved<br>
away by saying that the home directory isn’t a required place, to which<br>
Jim responded that unpacking them anywhere else was likely to have<br>
access control / security issues and “generally cause pain”. Which I<br>
wholly agree with, intact Mitre has assigned CVE’s to applications that<br>
did switch their Egg Cache to directories other than HOME.<br>
<br>
2. Zipped Eggs are more difficult to work with for debugging purposes, which<br>
you responded saying that Wheels are a “deployment format” (which I<br>
don’t believe is supported by the PEP at all) and Jim responded with his<br>
experience in developing against things that got installed as zipped Eggs<br>
and the pain that has personally caused him.<br>
<br>
3. Zipped imports (In Jim’s experience) are slower than unpacked imports,<br>
which you replied (quite literally) "Caveat emptor”. Jim’s response was that<br>
this had been tried with Egg and had been found to be more pain than it<br>
was worth. In his exact words:<br>
<br>
"It's been tried with eggs. This is not new ground. Encouraging people to<br>
do this is going to cause pain and resentment.<br>
<br>
I think one of the reasons there's so much (IMO mostly irrational) hate for<br>
eggs is that people think you can only used zipped eggs, and zipped eggs<br>
cause pain and agony.”<br>
<br>
He closes up with,<br>
<br>
"Importing from zipped eggs has proved itself to be an anti pattern.<br>
<br>
Buildout (as of buildout 2) always unzips eggs.”<br>
<br>
So you have pip that doesn’t use zipped Eggs, buildout which made sure<br>
in buildout 2 (presumably drawing from the lessons of buildout 1) to always<br>
unzip eggs, and easy_install which does support zipped eggs (sometimes,<br>
if it thinks that particular Egg will support it).<br>
<br>
Why do we insist upon repeating the mistakes of the past?<br>
<br>
><br>
>> Further more it won't even work accurately for all Wheels (as Nick's<br>
>> edit says) so we require that people wanting to do this figure out if<br>
>> their Wheel can or can not be added to the sys.path (which isn't as<br>
>> simple as looking at the tags because a platform specific Wheel may only<br>
>> contain optional C modules).<br>
><br>
> I don't yet see a technical impediment here. For example, distlib's wheel<br>
> implementation uses a "mount" method to add a wheel to sys.path. This uses<br>
> the tags to check for compatibility - there's no "figuring out" that the<br>
> user has to do. If additional metadata about C extensions is available<br>
> (which it is, if the wheel is built from source using distil), then those<br>
> extensions are made available for import, too. I realise that's an extension<br>
> to the current spec, but then no one is forcing any one to use it.<br>
<br>
Zipped Eggs have a long long history of causing very weird failures conditions,<br>
you say your Wheel.mount checks for compatibility, does it also check that<br>
the library to be installed isn’t using __file__ shenanigans instead of<br>
pkgutil.get_data()? easy_install tried to do this with varying degrees of success,<br>
I’ve never seen much except pain from zipped Eggs.<br>
<br>
><br>
> Regards,<br>
><br>
> Vinay Sajip<br>
><br>
> _______________________________________________<br>
> Distutils-SIG maillist - <a href="mailto:Distutils-SIG@python.org">Distutils-SIG@python.org</a><br>
> <a href="https://mail.python.org/mailman/listinfo/distutils-sig" target="_blank">https://mail.python.org/mailman/listinfo/distutils-sig</a><br>
<br>
<br>
-----------------<br>
Donald Stufft<br>
PGP: 0x6E3CBCE93372DCFA // 7C6B 7C5D 5E2B 6356 A926 F04F 6E3C BCE9 3372 DCFA<br>
<br>
<br>_______________________________________________<br>
Distutils-SIG maillist - <a href="mailto:Distutils-SIG@python.org">Distutils-SIG@python.org</a><br>
<a href="https://mail.python.org/mailman/listinfo/distutils-sig" target="_blank">https://mail.python.org/mailman/listinfo/distutils-sig</a><br>
<br></blockquote></div>