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 josh.r
Recipients docs@python, josh.r
Date 2019-03-18.19:18:18
SpamBayes Score -1.0
Marked as misclassified Yes
Message-id <1552936699.26.0.01319442845.issue36355@roundup.psfhosted.org>
In-reply-to
Content
While looking up background info for #36347, I noticed that the docs for PyMemberDef ( https://docs.python.org/3/extending/newtypes.html#generic-attribute-management ) define the following flags:

* READONLY
* READ_RESTRICTED
* WRITE_RESTRICTED
* RESTRICTED

Of those, WRITE_RESTRICTED has been documented incorrectly since Python 3.0a2 (it got renamed to PY_WRITE_RESTRICTED in structmember.h, apparently due to a name clash with VS 2008 on Windows).

Luckily, the constants are useless; AFAICT they were there solely to support restricted mode (via the rexec and Bastion modules). The modules were apparently disabled in Python 2.3 "due to various known and not readily fixable security holes" ( https://docs.python.org/2/library/restricted.html ), and the modules themselves officially deprecated in 2.6, and removed completely in 3.0.

Rather than fixing up the docs, maybe it's time to kill these constants for good? Probably shouldn't remove the definitions in structmember.h (if someone wrote code using them, we shouldn't needlessly break compilation), but the interpreter and standard library should stop setting them, and the documentation for them should be removed.
History
Date User Action Args
2019-03-18 19:18:19josh.rsetrecipients: + josh.r, docs@python
2019-03-18 19:18:19josh.rsetmessageid: <1552936699.26.0.01319442845.issue36355@roundup.psfhosted.org>
2019-03-18 19:18:19josh.rlinkissue36355 messages
2019-03-18 19:18:18josh.rcreate