Requesting pronouncement on PEP 0424
data:image/s3,"s3://crabby-images/c9c6e/c9c6eac43d1767be7719cd707451187176ad2431" alt=""
Hi all, The discussion on PEP 0424 seems to have subsided (and I haven't gotten angry emails in a week!). So I would like to request a BDFL or BDFP pronouncement on PEP 0424, text available here: http://hg.python.org/peps/file/tip/pep-0424.txt Alex
data:image/s3,"s3://crabby-images/c9c6e/c9c6eac43d1767be7719cd707451187176ad2431" alt=""
Guido van Rossum <guido <at> python.org> writes:
Looks good to me, so accepted.But why isn't it visible on python.org/dev/peps/
yet? I just realized the text in the python.org repo did not match what I had locally. I've pushed what I intended to be the latest text, if everyone could take a new look at that I would be very grateful. Sorry for the mixup. Alex
data:image/s3,"s3://crabby-images/3c3b2/3c3b2a6eec514cc32680936fa4e74059574d2631" alt=""
On Sun, Jul 29, 2012 at 6:11 PM, Alex Gaynor <alex.gaynor@gmail.com> wrote:
NP. I look a careful look at what's in Hg (still totally different from what python.org displays) and am proposing a few editorial changes; please see the review at http://codereview.appspot.com/6447061 Also, I have a few content quibbles: - Is it really worth flagging a negative return value with ValueError? I'd just as well clip this to zero. What's the worry? That the computed value is wrong? But it's only meant to be a hint, and why would -1 be any more wrong than e.g. 1000000000? - Did you mean to define operator.length_hint()? - The default can be zero with no semantic impact, so I think there's no need to require the caller to specify a default. - Most importantly: calling len(obj) and catching TypeError can only be a substitute for the real implementation, which IMO ought to check for the presence of a tp_len slot. Alas, checking hasattr(obj, '__len__') doesn't quite cut it either, since this returns true for a class object that defines a __len__ method for its instances (the class itself doesn't have a length). Still, I worry that calling len(obj) and catching all TypeErrors overspecifies the desired behavior; what I *want* to happen is to check if there is a __len__ method, and if so, call it and let any exceptions bubble through. It may be best to add a comment explaining that am implementation doesn't have to follow the letter of the Python code in the PEP, in particular, if obj *has* a __len__() method but calling it raises an exception, then length_hint(obj) may (ought to?) pass this exception on instead of calling obj.__length_hint__(). -- --Guido van Rossum (python.org/~guido)
data:image/s3,"s3://crabby-images/c9c6e/c9c6eac43d1767be7719cd707451187176ad2431" alt=""
On Mon, Jul 30, 2012 at 9:51 AM, Guido van Rossum <guido@python.org> wrote:
This was done for consistency with len(), I'm not particularly attached to any behavior.
- Did you mean to define operator.length_hint()?
Of course :)
- The default can be zero with no semantic impact, so I think there's no need to require the caller to specify a default.
I suppose that's fair.
Seems reasonable, rather than try to spec that out precisely in the pseudocode (aka Python ;)) a note like you suggest sounds good.
-- --Guido van Rossum (python.org/~guido)
Alex -- "I disapprove of what you say, but I will defend to the death your right to say it." -- Evelyn Beatrice Hall (summarizing Voltaire) "The people's good is the highest law." -- Cicero
data:image/s3,"s3://crabby-images/bb604/bb60413610b3b0bf9a79992058a390d70f9f4584" alt=""
On Mon, Jul 30, 2012 at 12:51 PM, Guido van Rossum <guido@python.org> wrote:
This isn't the only place this pattern comes up; maybe a hasmethod() function somewhere (builtin, operator, inspect?) for this would be a good idea. (i.e., something that returns true only if the method is for the instance.) (But perhaps that's a python-ideas topic, since it raises the question of whether it should really be something more like instancehasattr(), or whether it should be limited to special slots or something else.)
data:image/s3,"s3://crabby-images/fef1e/fef1ed960ef8d77a98dd6e2c2701c87878206a2e" alt=""
On Sat, 28 Jul 2012 17:05:01 +0000 (UTC) Alex Gaynor <alex.gaynor@gmail.com> wrote:
"It may raise a ``TypeError`` if a 32 specific instance cannot have its length estimated." -> what is the consumer supposed to do in this case? Propagate the error, or use a default value? Regards Antoine. -- Software development and contracting: http://pro.pitrou.net
data:image/s3,"s3://crabby-images/387f6/387f67b67aeaa6515bdb2aaaedb1782f04c69850" alt=""
Hi Alex, just a small info (view pep-0424.txt @ 4491:7838a83c3ad1): - Section Proposal: [...] than the actual size >>> ofthe <<< container. [...] - Section Rationale: The first line is really long (seems to need a newline before ``__length_hint__``) Regards francis
data:image/s3,"s3://crabby-images/c9c6e/c9c6eac43d1767be7719cd707451187176ad2431" alt=""
Guido van Rossum <guido <at> python.org> writes:
Looks good to me, so accepted.But why isn't it visible on python.org/dev/peps/
yet? I just realized the text in the python.org repo did not match what I had locally. I've pushed what I intended to be the latest text, if everyone could take a new look at that I would be very grateful. Sorry for the mixup. Alex
data:image/s3,"s3://crabby-images/3c3b2/3c3b2a6eec514cc32680936fa4e74059574d2631" alt=""
On Sun, Jul 29, 2012 at 6:11 PM, Alex Gaynor <alex.gaynor@gmail.com> wrote:
NP. I look a careful look at what's in Hg (still totally different from what python.org displays) and am proposing a few editorial changes; please see the review at http://codereview.appspot.com/6447061 Also, I have a few content quibbles: - Is it really worth flagging a negative return value with ValueError? I'd just as well clip this to zero. What's the worry? That the computed value is wrong? But it's only meant to be a hint, and why would -1 be any more wrong than e.g. 1000000000? - Did you mean to define operator.length_hint()? - The default can be zero with no semantic impact, so I think there's no need to require the caller to specify a default. - Most importantly: calling len(obj) and catching TypeError can only be a substitute for the real implementation, which IMO ought to check for the presence of a tp_len slot. Alas, checking hasattr(obj, '__len__') doesn't quite cut it either, since this returns true for a class object that defines a __len__ method for its instances (the class itself doesn't have a length). Still, I worry that calling len(obj) and catching all TypeErrors overspecifies the desired behavior; what I *want* to happen is to check if there is a __len__ method, and if so, call it and let any exceptions bubble through. It may be best to add a comment explaining that am implementation doesn't have to follow the letter of the Python code in the PEP, in particular, if obj *has* a __len__() method but calling it raises an exception, then length_hint(obj) may (ought to?) pass this exception on instead of calling obj.__length_hint__(). -- --Guido van Rossum (python.org/~guido)
data:image/s3,"s3://crabby-images/c9c6e/c9c6eac43d1767be7719cd707451187176ad2431" alt=""
On Mon, Jul 30, 2012 at 9:51 AM, Guido van Rossum <guido@python.org> wrote:
This was done for consistency with len(), I'm not particularly attached to any behavior.
- Did you mean to define operator.length_hint()?
Of course :)
- The default can be zero with no semantic impact, so I think there's no need to require the caller to specify a default.
I suppose that's fair.
Seems reasonable, rather than try to spec that out precisely in the pseudocode (aka Python ;)) a note like you suggest sounds good.
-- --Guido van Rossum (python.org/~guido)
Alex -- "I disapprove of what you say, but I will defend to the death your right to say it." -- Evelyn Beatrice Hall (summarizing Voltaire) "The people's good is the highest law." -- Cicero
data:image/s3,"s3://crabby-images/bb604/bb60413610b3b0bf9a79992058a390d70f9f4584" alt=""
On Mon, Jul 30, 2012 at 12:51 PM, Guido van Rossum <guido@python.org> wrote:
This isn't the only place this pattern comes up; maybe a hasmethod() function somewhere (builtin, operator, inspect?) for this would be a good idea. (i.e., something that returns true only if the method is for the instance.) (But perhaps that's a python-ideas topic, since it raises the question of whether it should really be something more like instancehasattr(), or whether it should be limited to special slots or something else.)
data:image/s3,"s3://crabby-images/fef1e/fef1ed960ef8d77a98dd6e2c2701c87878206a2e" alt=""
On Sat, 28 Jul 2012 17:05:01 +0000 (UTC) Alex Gaynor <alex.gaynor@gmail.com> wrote:
"It may raise a ``TypeError`` if a 32 specific instance cannot have its length estimated." -> what is the consumer supposed to do in this case? Propagate the error, or use a default value? Regards Antoine. -- Software development and contracting: http://pro.pitrou.net
data:image/s3,"s3://crabby-images/387f6/387f67b67aeaa6515bdb2aaaedb1782f04c69850" alt=""
Hi Alex, just a small info (view pep-0424.txt @ 4491:7838a83c3ad1): - Section Proposal: [...] than the actual size >>> ofthe <<< container. [...] - Section Rationale: The first line is really long (seems to need a newline before ``__length_hint__``) Regards francis
participants (7)
-
Alex Gaynor
-
Antoine Pitrou
-
Benjamin Peterson
-
francis
-
Guido van Rossum
-
martin@v.loewis.de
-
PJ Eby