Opened 3 months ago
Last modified 4 weeks ago
#35894 assigned Cleanup/optimization
Move away from the term "patch" to refer to a contribution/pull request in the contributor documentation
Reported by: | Baptiste Mispelon | Owned by: | Baptiste Mispelon |
---|---|---|---|
Component: | Documentation | Version: | dev |
Severity: | Normal | Keywords: | |
Cc: | Triage Stage: | Accepted | |
Has patch: | yes | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | yes |
Easy pickings: | no | UI/UX: | no |
Description
No one effectively contributes via patches anymore (according to the Trac database, only ~10 patches were submitted in the past 12 months), I think it's time we update Trac and our documentation to reflect that.
I've created a PR to change the wording on Trac itself: βhttps://github.com/django/code.djangoproject.com/pull/224
What's left now is to update our contributing guides in the documentation.
Attachments (1)
Change History (15)
by , 3 months ago
Attachment: | issue35894.diff added |
---|
comment:1 by , 3 months ago
Has patch: | set |
---|
comment:2 by , 3 months ago
I also considered replacing the expression "ready for checkin" with "ready for merging" (which has the huge advantage of having the exact same number of letters), but that would require a database migration on Trac which could be a bit annoying (though not impossible).
If you think that's worth it I can look into that as well.
follow-up: 5 comment:3 by , 3 months ago
There were some recent changes along these lines in 55a2e3136b13d1af95a4129001dac963c26d8415.
I'd prefer not to rename files and cause external broken links (βCool URIs Don't Change). (E.g. you proposed to rename ....writing-code/submitting-patches.txt to .../writing-code/pull-requests.txt.)
You also proposed to remove the ".. _patch-review-checklist:" heading which I have used extensively in Trac comments as well as on the PatchReviewChecklist wiki page (but if the page is renamed the link will break anyway).
It's possible Django will use Git, GitHub, and "pull requests" forever, but it might be worth considering if these specific terms should really be embedded in URLs.
comment:4 by , 3 months ago
I also think that "pull request" is a GitHubism. Not that we should not use it, but having "patch" here and there as a more generic term doesn't shock me.
comment:5 by , 3 months ago
Summary: | Rename "patch" to "pull request" in the contributor documentation β Move away from the term "patch" to refer to a contribution/pull request in the contributor documentation |
---|---|
Triage Stage: | Unreviewed β Accepted |
Replying to Tim Graham:
I'd prefer not to rename files and cause external broken links (βCool URIs Don't Change). (E.g. you proposed to rename ....writing-code/submitting-patches.txt to .../writing-code/pull-requests.txt.)
You also proposed to remove the ".. _patch-review-checklist:" heading which I have used extensively in Trac comments as well as on the PatchReviewChecklist wiki page (but if the page is renamed the link will break anyway).
I agree we should be careful not to break links here
I'm in favor of updating from patch, to either "pull request"/"contribution"/"solution"/"fix"
I think "Has patch" -> "Has pull request" as when someone marks this as Yes, I expect to see something reviewable in GitHub which has also triggered our CI
"Patch needs improvement" could be "Requested changes" (I have stolen that from GitHub but is perhaps less of a GitHubism)
Will review the PR in detail for more specific cases
comment:6 by , 3 months ago
Patch needs improvement: | set |
---|
comment:7 by , 3 months ago
Thanks everyone for the feedback, I'll try to address it point by point
1) Not breaking existing URLs
This is a very good point, but I think we should address that via setting up 301 redirects in the server configuration (this is something I can do as a member of the ops team)
I'll also note that there is some precedent for breaking docs links (found via git log --diff-filter=RD --stat -- docs/
): d8b6a76bc745b21c6cf2b29c220a91bcae7fd3d7, 8eae094638acf802c8047b341d126d94bc9b45a3, or 3d14cbc86781ea1051af7f0c421bee3ecf2f9842
2) Not breaking URL fragments / heading names
I'm not opposed to re-adding some directives like .. _patch-review-checklist
to try and preserve deep links people might have used, but I think it should be part of a documented policy. Why is this heading on this page important that it requires preserving? Should that apply to all references throughout the documentation? If not, what's the cutoff, how do we measure it?
I don't think it's realistic to expect headings not to ever change names, and without a policy in place (ideally enforced by some kind of automated tool) those "backwards-compatibilty" references are at risk of being removed by accident.
3) Githubisms
I would argue that the term "pull request" is general enough as to not be a "githubism" (it is used on bitbucket for example). In any case, this word reflects the reality of our contributing process today and for the foreseeable future, unlike the word "patch" which one could also call an "SVNism" .
4) Patch is a generic term
I think that one might be a matter of opinion (and mine is that it's not) which would be hard to quantify objectively. My belief is that the majority of our new contributors do not know what a "patch" is, but they know what a "pull reqest" is.
I'll also point out that the Python devguide recently made changes in a similar direction: βhttps://github.com/python/devguide/commit/0ad84cdd913dfd58df1fe4862eb7bf06cc8f4882
Also also, our documentation currently uses the word "patch" for several different meanings:
1) As a synonym for "pull request" essentially
2) To point to a specific commit in the context of a security release
3) A "patch" release
4) The HTTP method
Replacing one of these (1) would be an improvement in my opinion.
comment:8 by , 3 months ago
I'm not opposed to re-adding some directives like .. _patch-review-checklist to try and preserve deep links people might have used, but I think it should be part of a documented policy. Why is this heading on this page important that it requires preserving?
For example, βhttps://docs.djangoproject.com/en/dev/internals/contributing/writing-code/submitting-patches/#patch-review-checklist has been on an automated welcome message on GitHub PRs for first time contributors for quite a while - so this link is used and shared quite extensively. I think it's normal to share a particular version of the docs in a link, but often in the internal docs, I share "dev" links so folks get the latest information on our processes - unfortunately these links are more "brittle".
Setting a redirect would be great π
This is not a documented policy. I'd say we change header names (though never really touched the Wiki). References we don't change very often and file renaming/removing is also quite rare.
comment:9 by , 3 months ago
unlike the word "patch" which one could also call an "SVNism"
I don't agree, "patch" is still used in the Git world (see βhttps://git-scm.com/docs/git-format-patch for example). Once again, I don't oppose to this proposal, just that we don't need to purge all "patch" occurrences in our docs. It may still make sense in some contexts.
comment:10 by , 3 months ago
If "patch" has lost its meaning among new contributors, or makes people think we're using SVN, I'm very surprised.
βhttps://en.wikipedia.org/wiki/Patch_(computing)
βhttps://git-scm.com/docs/SubmittingPatches
For "pull request", I was thinking about GitLab, which uses "merge request."
comment:11 by , 2 months ago
Patch needs improvement: | unset |
---|
I've updated the PR after some reviews, here's the current summary:
- "patch" is replaced with a mixture of "pull request", "change" or "contribution" on all the pages that talk about contributing to Django (this matches the current effective practice and is similar to what was done on the Python devguide)
- The word "patch" is kept when talking about an actual patch file
- The word "patch" is kept in the names of some files and in some anchors, so as not to break existing links
There are also two PRs connected to this ticket:
- One for Trac itself to rename the fields on the UI (the name of the field is not affected, so things like report links will continue to work): βhttps://github.com/django/code.djangoproject.com/pull/224
- One for the dashboard to rename some of the metrics: βhttps://github.com/django/djangoproject.com/pull/1729
While these two PRs are related, they don't technically require to be merged/deployed in any specific order. I personally suggest waiting until the docs change in this ticket are live before deploying them.
comment:12 by , 2 months ago
Thank you, Baptiste, for initiating this discussion!
Iβm on the side of avoiding the term "pull request" (except when referring to GitHub-concrete docs, specifically the βWorking with Git and GitHub docs). As Tim mentioned, Andreu and I worked to replace several instances of "patch" in the docs βin this patch :clown:
In that revision, my priority was to avoid breaking existing anchors and to ensure that "pull request" was not used as a direct synonym for "patch," since they have distinct meanings. Iβll be adding comments on each PR, but if we are moving away from "patch," I think itβs important to use platform-neutral terms, unless we're specifically referring to a GitHub pull request.
I also believe "patch" is not exclusive to SVN. Iβve used it for a long time to describe a diff file containing code changes, even before tools like CVS came along. GitHub itself uses the term as well, you can download the patch for any PR by appending .patch
to the PR URL:
βhttps://github.com/django/djangoproject.com/pull/18780.patch
Additionally, I donβt see "pull request" as a generic term. It seems specific to GitHub, especially since other platforms like GitLab use βMerge Request and Launchpad uses βMerge Proposal. For that reason, Iβd prefer not to replace "patch" with "pull request." In fact, "patch" is one of the more platform-agnostic terms we have, though I agree that we should use it carefully and in its original sense (i.e., a diff of code proposing a change).
comment:13 by , 2 months ago
Thanks for your beed back Natalia!
I do not agree that "Pull request" is a github-specific term (it might have started that way, but it is not anymore). It's also used by:
And for what it's worth, wikipedia also says that "pull request" and "merge request" are equivalent [5].
But even with all this, my argument is that we should meet the contributors where they are, and today that's on github, using pull requests. If and when that process changes, we can amend the documentation again.
With the current state of my merge request, no URL has changed, and the only headings that were modified did not lead to any internal links being broken. Plus there's currently no documented policy I could find around backwards-compatibility of anchors.
The change I'm proposing in this merge request is not to erase "patch" altogether, nor is it to replace all of its occurences by "pull request". The word "patch" has been kept where it reflects the reality, and replaced by a variation of "pull request", "change", "contribution", "proposal", ... where it makes more sense.
[1] βhttps://www.atlassian.com/git/tutorials/making-a-pull-request
[2] βhttps://docs.aws.amazon.com/codecommit/latest/userguide/pull-requests.html
[3] βhttps://docs.gitea.com/next/usage/pull-request
[4] βhttps://docs.codeberg.org/collaborating/pull-requests-and-git-flow/
[5] βhttps://en.wikipedia.org/wiki/Distributed_version_control#Pull_requests
comment:14 by , 4 weeks ago
Patch needs improvement: | set |
---|---|
Version: | 5.0 β dev |
Updating ticket flags following the latest unresolved comments in the PR.
I've attached a patch for the documentation changes π
(If you insist, I've also opened a PR: βhttps://github.com/django/django/pull/18780)