This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

classification
Title: inspect.Signature could provide readable expressions for default values for builtins
Type: enhancement Stage: needs patch
Components: Versions: Python 3.5
process
Status: open Resolution:
Dependencies: Superseder:
Assigned To: Nosy List: larry, ncoghlan, serhiy.storchaka, yselivanov
Priority: normal Keywords:

Created on 2014-01-23 09:12 by larry, last changed 2022-04-11 14:57 by admin.

Messages (2)
msg208892 - (view) Author: Larry Hastings (larry) * (Python committer) Date: 2014-01-23 09:12
The signatures for builtins are stored as text and interpreted at runtime on demand.  inspect.Signature gets the default value for a parameter as a text string, which it evaluates (by hand, in a highly constrained way) to produce the parameter's value member.

Serhiy cleverly suggested that it'd be nice if Signature objects could also make this string available, as it's often more readable than the value.  For example, there's a parameter in zlib with the default "MAX_DECOMPRESSION - 1"; that turns into 7 I think.  Which would you prefer?

Right now there's no place to store this in the parameter object, so it can't happen for 3.4.  But perhaps in 3.5 we could add it, and figure out how to present it to the user.  For example __str__ could use it.


Thinking a little laterally: we *could* hide it in a *private* member on the Parameter object, then only use it for calculating __str__.  That would look so fancy!  Should we consider doing that for 3.4?
msg208934 - (view) Author: Nick Coghlan (ncoghlan) * (Python committer) Date: 2014-01-23 14:25
It wouldn't be the first time I've used a private variable to fix a
problem while still abiding by the no-new-features rule, but I think
in this particular case we're better off waiting :)
History
Date User Action Args
2022-04-11 14:57:57adminsetgithub: 64559
2020-03-18 18:40:46brett.cannonsetnosy: - brett.cannon
2014-01-23 14:25:59ncoghlansetmessages: + msg208934
2014-01-23 09:12:36larrycreate