[Python-Dev] Proposing PEP 345 : Metadata for Python Software Packages 1.2
Ben Finney
ben+python at benfinney.id.au
Mon Dec 28 02:17:22 CET 2009
Tarek Ziadé <ziade.tarek at gmail.com> writes:
> On Mon, Dec 28, 2009 at 1:41 AM, Sridhar Ratnakumar
> <sridharr at activestate.com> wrote:
> > Also, "Requires-Python: 3" would include all 3.X versions, correct?
>
> Correct, because, "Requires-Python: 3" is equivalent to
> "Requires-Python: ~= 3" which is equivalent to "Requires-Python:
> 3.x.x"
This is totally counter to conventional comparisons, and is an excellent
example of why the equivalence of ‘3’ to ‘>=3, <4’ is a bad idea.
Instead, the default should be ‘==’. That is, ‘Requires-Python: 3’
should be equivalent to ‘Requires-Python: ==3’; and only “3” or “3.0” or
“3.0.0” etc. will match. I maintain that is what most people will expect
on seeing that syntax.
If a less strict range is desired, the existing comparison operators
‘>’, ‘>=’, ‘<’, ‘<=’ are sufficient, more obvious, and more explicit. In
other words, to get the meaning you desire above, the existing operators
can be used: ‘Requires-Python: >=3, <4’.
--
\ “Not using Microsoft products is like being a non-smoker 40 or |
`\ 50 years ago: You can choose not to smoke, yourself, but it's |
_o__) hard to avoid second-hand smoke.” —Michael Tiemann |
Ben Finney
More information about the Python-Dev
mailing list