[Image-SIG] Pillow, the "friendly" PIL fork
aclark at aclark.net
Mon Aug 2 10:01:31 CEST 2010
On 8/1/10 10:29 PM, in article 4C562DA3.8030508 at noaa.gov, "Christopher
Barker" <Chris.Barker at noaa.gov> wrote:
> Alex Clark wrote:
>> On 8/1/10 3:04 PM, in article 4C55C525.9090809 at noaa.gov, "Christopher
>> Barker" <Chris.Barker at noaa.gov> wrote:
>>> Is packaging the only "issues" this fork is for?
>> Yes. In Plone-land we rely a great deal on packages on PyPI.
>> Buildout is a
>> tool (which my 'Plone site admin' book covers in great detail, FWIW) we use
>> exclusively to build Plone CMS applications.
> couldn't you have "recipes" for buildout that does a little extra for
> certain packages -- like in this case, remove the PIL.pth file.
Maybe. But that breaks the paradigm of "easy to add packages to your
buildout". A recipe is a layer of abstraction that provides additional
functionality. Installing PIL should be part of the existing functionality
> Or maybe change the name of the Zope package named "Image", as Fredrik
> mentioned, PIL has been around a long time.
Maybe. But I'm not quite sure how that would work. Zope 2 has also been
around a long time… ~12 years I think?
> But in any case, a fork seems like a lot of work for such a simple conflict!
If only it were a simple conflict. Like I said, this has been going on a
long time. And like Fredrik said, the approach from the Zope/Plone community
has not always been the most friendly. I'm trying to see if we can fix this
once and for all, in one way or another. I'm still hopeful we can come up
with a patch, but a fork that breaks backwards compatibility wouldn't be the
worst thing in the world IMO.
>> Using Buildout to install packages is more or less the equivalent of running
>> "easy_install SomePackage", only the result is an "instance" script with the
>> packages specified in the buildout packages added to the sys.path. E.g.:
>> import sys
>> sys.path[0:0] = [
>> If I list PIL in Buildout, I get the latest on PyPI (or some version I
>> specify) and it "breaks Zope" due to the issues we discussed.
>> As such, various alternative re-packages have appeared:
>> - http://download.zope.org/distribution/PILwoTk-188.8.131.52.tar.gz
>> - http://dist.repoze.org/PIL-1.1.6.tar.gz
>> - http://dist.plone.org/thirdparty/PIL-1.1.7.tar.gz
>> Now, you can use Buildout to install PILwoTk quite easily simply by telling
>> Buildout where to find it, e.g.:
>> find-links = http://download.zope.org/distribution/PILwoTk-184.108.40.206.tar.gz
>> But it's not clear (to me at least) if the same is true of the re-packages
>> that are not *renamed* e.g.
>> That is because Buildout's default index is PyPI and it will always find PIL
>> there first (I think).
>> So, I wanted a fork, because I wanted to take the latest re-packaging (
>> http://dist.plone.org/thirdparty/PIL-1.1.7.tar.gz) and "release" it to PyPI.
>> Now I can specify the Pillow package in Buildout, and Buildout will find
>> "the right one". (Here's a simple Plone buildout example:
>> Let me parse the rest of your and Fredrik's comments, and let them sink in a
>> bit, and get back to youŠ
>> (This is a very helpful dialogue I think, thank you all!)
Alex Clark · http://aclark.net
Author — Plone 3.3 Site Administration · http://aclark.net/admin
More information about the Image-SIG