[Distutils] [Pythonmac-SIG] pkg_resources and Mac OS X compatibility

Bob Ippolito bob at redivi.com
Tue Feb 7 20:48:15 CET 2006


On Feb 7, 2006, at 5:37 AM, Phillip J. Eby wrote:

> At 02:07 PM 2/5/2006 -0800, Bob Ippolito wrote:
>> On Feb 5, 2006, at 2:00 PM, Bob Ippolito wrote:
>>> With the way that we're returning the distutils platform on the
>>> universal branch of Mac OS X, we need another patch to
>>> pkg_resources.  The reason for this is that
>>> distutils.util.get_platform() returns the platform that it is
>>> trying to produce binaries for, which is often not the exact
>>> current platform.  More specifically, our current strategy is to
>>> produce a version of Python that will build extensions that are
>>> compatible with Mac OS X 10.3, but the actual building of
>>> extensions requires Mac OS X 10.4 or later (because the toolchain
>>> doesn't exist on Mac OS X 10.3).
>>>
>>> In some rare cases, people will want to produce packages that
>>> explicitly require Mac OS X 10.4 or later, which they can do by
>>> setting the MACOSX_DEPLOYMENT_TARGET=10.4 environment variable when
>>> running setup.py.  This will influence the value returned by
>>> disutils.util.get_platform(), and will influence the compiler and
>>> linker if extensions are built.
>>>
>>> This patch adds an internal _get_max_platform(plat) function that
>>> returns the actual runtime version of Mac OS X, for use in
>>> compatible_platforms.
>>
>> Oops, wrong patch.. here's the correct one.  Sorry about that:
>
> I've implemented a similar - but different - patch.  Yours causes  
> setuptools' tests to fail on non-Mac platforms, including non-Mac  
> darwin.

Could you explain how?  I don't see it.  The condition is::

	if m is not None and sys.platform == "darwin":
		...

How does that fail on pure Darwin?  The condition should be False  
because m has to be None at that point and the branch shouldn't happen.

-bob



More information about the Distutils-SIG mailing list