-
-
Notifications
You must be signed in to change notification settings - Fork 1.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Discourage using References? #2130
Comments
I've been ignoring this suggestion for a while because it's extra work, so I definitely support dropping the section. |
This follows Guido's suggestion in python#2130.
This follows Guido's suggestion in python#2130.
This follows Guido's suggestion in python#2130.
For what its worth, as an run of the mill Python developer, that gave me the exact same impression. It made sense back when PEPs where plain text and shared on email lists, but aside from feeling a bit archaic nowadays, it has significant usability impacts, requiring an extra layer of indirection to open links (or even see where they point to); in particular, I frequently Ctrl-click links as I'm reading to open them in new tabs to read later or after I've skimmed/read the PEP, only to be frustrated when I come back to them and realized that all I've done is open lots of duplicate pages to the references section, and have to look carefully in each tab to see what link I actually intended to click (if I even remember that was my intent at all). There are some cases where the are used for more than just references, particularly on older or long-established PEPs and meta-PEPs, e.g. PEP 1, PEP 465, etc, along with that of non-web media/journal articles, etc. These cases could be accommodated by renaming the references section "footnotes" (as it is already named in PEP 1 and others that use it for this purpose) and using it as such, and updating the description (PEP 1) and the template (PEP 12) accordingly. So, some proposed concrete steps to implement this issue:
Additionally, the footer transform could potentially be tweaked to not inject automatically generated links into the References section and add superfluous footnotes, while preserving the inline links, and not having any effect on any manually-created footnotes. For PEPs using just link references rather than manual footnotes, this would elide the section entirely, while those using a mix of both would only show the more-useful manual footnotes in that section, while direct-linking the rest. This would also allow use of non-inline references (e.g. referencing the same line multiple times) without the undesired addition of/into a References section. Finally, we could consider updating the rest of the active meta-PEPs to use inline links, as these tend to be the most frequently read, updated, and likely used as exemplars (could include others as well, if desired, but probably best to keep things limited in scope if we do this at all):
Unlike the other meta-PEPs, PEP 6 , much of the content is 1-2 decades outdated (talking about things like CVS, SourceForge, the Patch Czar, the the pre-pre-PEP 602 release process, Python 2.x, BDFL, etc) and hasn't been updated since Python 2.3, and also has some overlap with other commonly referenced PEPs, including PEP 387 PEP 602, and possibly others. As such, it might make sense to either update it or subsume the remaining into other PEP(s). However, that's obviously an issue for another...issue.
Particularly given the core devs have better things to do than this sort of stuff, I offer my help here on the above. Thanks! |
Hi CAM, are you interested in submitting a series of PRs (or perhaps one big one) to make this happen? I don't think any of the other PEP editors would be opposed (@JelleZijlstra, @warsaw, @Rosuav -- I don't recall who else besides @brettcannon and me is a PEP editor :-). |
I support this change in principle, but don't want to be the one to do the work of rewriting everything, so yes, absolutely in favour of seeing a PR if you're willing, CAM :) |
Agree with everything @Rosuav said. Thanks for offering to help @CAM-Gerlach! |
Thanks so much @gvanrossum @Rosuav @JelleZijlstra ! Sorry for the delay; I've been busy working on what ended up being a thorough overhaul of PEP 639 to implement several major changes and additions after discussion and consensus by the community, as well as update it to reflect all the ecosystem/tool/standard changes in the 1-2 years since its initial drafting plus copyediting and various fixes. I hope to have that ready for final review and PR by tomorrow, after which I'll be able to work on this one. Based on your feedback, my tentative plan is to do two PRs split down the lines of the checklists above, with one proposing the documentation modifications to PEP 1 and PEP 12 along with the build tweak to not automatically make footnotes out of inline links (links that are just footnotes would stay as they are, to preserve backwards-compatibility and keep things in scope), and the second implementing the change on the active, core meta/process-PEPs listed that don't already have their links inline (like PEP 609, which the previous PR will fix automatically). Also, should I open a new issue following up on my above footnote about PEP 6 (being an active meta-/process-PEP that contains a large amount of no-longer-accurate/very outdated content)? Or, is it worth bringing it up in a wider venue, like Discourse (if so, any suggestions on which section)? |
I don't know if going back and updating PEPs that use references is worth it, but updating the PEPs that suggest/say to use references are definitely worth updating. |
Yeah; for the PEPs that already use inline links the build changes needed (to get references to not get added automatically even for inline links) will fix it for free, but it would require a fair amount of manual effort to do on old PEPs, principally because it can't be really scripted due to the need to determine what prose text to actually link, and create a lot of low-SNR churn. The one place I think it might be valuable is on the relatively small number of links (no more than a dozen or so total) on the most popular, active meta/process PEPs (as listed above), which (particularly PEPs like PEP 8) likely get a high amount of user and developer traffic relative to the others, which would both benefit users from the standpoint of accessibility, simplicity and concision, and help avoid potential PEP authors picking up on the old practice. As it stands now, I propose submitting three PRs in sequence: One with the build tweaks to not always auto-generate references for inline links (assuming that ends up being doable without any unintended side effects); one with the PEP 0/1/12 changes that say to use references, and one to update the ~dozen or so references on the activate core meta/process PEPs. |
Wow. I didn't even know that that feature existed. I thought that all References were put in there manually -- like they often are, e.g. in PEP 8 there are 5 of these. Do you have an example (i.e., a PEP which uses inline links in the source that are converted to indirect links on the website)? +1 on the general plan BTW. |
Wait, did I just teach @gvanrossum something (vaguely) Python-related? 😮 Actually, its even more complicated than that—there are no less than four different ways link/references are done in the PEPs sources, three of which create a footnote and three of which render differently (times the two different build systems, docutils and Sphinx, which each have different code handling this, which are mostly equivalent but with some edge-case differences). In fact, some PEPs, like PEP 1, use different ones within the very the same file, sometimes even in the very same line; in fact, the PEP Formats and Templates section uses three of the four in the span of a mere two sentences, all of which render visibly differently, and which creates a minor rendering issue in the footnotes with a visible gap and double vertical rule between them.
But wait, there's more! For the first and second approach, if the actual footnote isn't in the footnote section, the rendered location and number of the footnote in the output moves with it, but the same is not true of the third type of footnote (using regular inline links); it always gets rendered in the references section no matter its physical location, and only its order/number is changed. However, regardless, inline references are always listed after manual footnotes in the output, no matter where they are listed in the source. So, not exactly the "only one (obvious) way to do it" ideal :) |
Now for some good news... TL;DR, it ended up being nearly as straightforward as I could have hoped to implement the build changes in both the Sphinx and Docutils build process to support this, and I can go ahead with a PR on that shortly to get things moving. For the Sphinx version of the build process, as I'd hoped, simply commenting out lines 53 - 68 of the footer transform (which is what adds the redundant footnotes in Case 3) makes them render as normal inline lines, just like in Case 4. With just a few small tweaks to the existing cleanup code that already does this, it also removes The legacy docutils version took somewhat more work; removing So, I already have the first PR pretty much ready to go, in spite of myself. |
Amazing! Thanks for the detailed examples. There are definitely too many ways to do links in ReST… |
Opened the first step as PR #2155 |
… info, reformat, update and copyedit (#2164) * PEP 639: Reframe core metadata update as discrete proposal per PEP 643 * PEP 639: Clean up formatting, syntax, spelling, headers and lists * PEP 639: Rewrite to reflect License-Expression field and depr process * PEP 639: Update examples, current tools survey, links and more * PEP 639: Add PEP 621, expand/move examples & reorganize/shorten headings * PEP 639: Further specify and clarify license file handling * PEP 639: Add additional ambigous classifiers and tool recommendations * PEP 639: Rework PEP 621 keys, refine dynamic/globs & add rejected ideas * PEP 639: Specify license path root & subdirs, & expand examples * PEP 639: Add license_files dir, rejected ideas & sdist/wheel/installed * PEP 639: Add PyPI validation of new fields for newly-uploaded files * PEP 639: Add open isssue for back-filling & reject per-dist licenses * PEP 639: Add User Scenarios to provide guidance for common use cases * PEP 639: Update Abstract, Goals, Rationale, Compat. & other sections * PEP 639: Add terminology section & use consistant, clear & correct terms * PEP 639: Make refs inline per #2130, add links, fix others & refine text * PEP 639: Copyedit and proofread for grammar, phrasing, clarity & tone * PEP 639: Address reviewer and community feedback * PEP 639: Add custom IDs issue & clarify rejected license key str value
…2155) Co-authored-by: Adam Turner <[email protected]>
Many PEPs have a "References" section containing hyperlinks to various things. The main text then has a "reference"[1]. For the most part, this feels an outdated mechanism. In particular, when reading a PEP, if there's a link in the text, I want clicking on the link to go directly to the hyperlinked document, not to the References section. The markup to do that exists, it's just that most PEP authors follow the example of older PEPs that make all (or most) links go through the References section.
Perhaps we can encourage placing direct links in the text, and reserve the References section for either books or journal articles, or abandon it altogether?
The text was updated successfully, but these errors were encountered: