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.

Author larry
Recipients larry, serhiy.storchaka, yselivanov
Date 2015-08-09.10:10:54
SpamBayes Score -1.0
Marked as misclassified Yes
Message-id <1439115056.44.0.0298304719355.issue24834@psf.upfronthosting.co.za>
In-reply-to
Content
As discussed in #24824, inspect.Parameter currently only has a place to store the value of a default argument.  Which means, if a complicated bit of code was used to produce that default argument, all we have left is the value, not the code that arrived at that value.  Which means all pydoc can do is display the value.

When C extensions pass in their default arguments as expressions, it'd be great if we could preserve that text and present it to the user.  The example that resulted in us creating this issue: _codecs.encode() and _codecs.decode() both took an "encoding" parameter that defaulted to sys.getdefaultencoding().  The value of that function was (always) "utf-8".  It's slightly more meaningful to display
    encoding=sys.getdefaultencoding(),
than
    encoding="utf-8",
in pydoc.

As a first approach, I propose we add a new member to inspect.Parameter, call it "symbolic_default_value", which contains the expression passed in by Argument Clinic (if present).  pydoc should look for this member when computing the documentation for a function, and prefer to present it to the user over the actual default value.
History
Date User Action Args
2015-08-09 10:10:56larrysetrecipients: + larry, serhiy.storchaka, yselivanov
2015-08-09 10:10:56larrysetmessageid: <1439115056.44.0.0298304719355.issue24834@psf.upfronthosting.co.za>
2015-08-09 10:10:56larrylinkissue24834 messages
2015-08-09 10:10:54larrycreate