Message ID | 20211022064044.28761-1-bagasdotme@gmail.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | MyFirstContribution: teach to use "format-patch --base=auto" | expand |
On Fri, Oct 22, 2021 at 2:43 AM Bagas Sanjaya <bagasdotme@gmail.com> wrote: > From: Junio C Hamano <gitster@pobox.com> > > Let's encourage first-time contributors to tell us what commit they > based their work with the format-patch invocation. As the example > already forks from origin/master and branch.autosetupmerge by > default records the upstream when the psuh branch was created, we > can use --base=auto for this. Also, mention to the readers that the > range of commits can simply be given with `@{u}` if they are on the > `psuh` branch already. > > As we are getting one more option on the command line, and spending > one paragraph each to explain them, let's reformat that part of the > description as a bulletted list. s/bulletted/bulleted/ > Signed-off-by: Junio C Hamano <gitster@pobox.com> > [Bagas Sanjaya: fix grammar in commit message and explain `auto` value] > Signed-off-by: Bagas Sanjaya <bagasdotme@gmail.com>
Bagas Sanjaya <bagasdotme@gmail.com> writes: > From: Junio C Hamano <gitster@pobox.com> > > Let's encourage first-time contributors to tell us what commit they > based their work with the format-patch invocation. As the example > already forks from origin/master and branch.autosetupmerge by > default records the upstream when the psuh branch was created, we > can use --base=auto for this. Also, mention to the readers that the > range of commits can simply be given with `@{u}` if they are on the > `psuh` branch already. > > As we are getting one more option on the command line, and spending > one paragraph each to explain them, let's reformat that part of the > description as a bulletted list. > > Signed-off-by: Junio C Hamano <gitster@pobox.com> > [Bagas Sanjaya: fix grammar in commit message and explain `auto` value] > Signed-off-by: Bagas Sanjaya <bagasdotme@gmail.com> Hmph, the log message changes, relative to what is queued, look like so: Let's encourage first-time contributors to tell us what commit they based their work[-on-] with the format-patch invocation. As the example already forks from origin/master and branch.autosetupmerge by default records the upstream when the psuh branch was created, we can use --base=auto for this. Also, mention {+to the readers+} that the range of commits can simply be given with `@{u}` if they are on the `psuh` branch already. As we are getting one more option on the command line, and spending one paragraph each to explain them, let's reformat that part of the description as a bulletted list. Contributors will tell us what commit they based their work on, and removal of "on" does not look like fixing grammar to me (it looks more like breaking). Adding "to the readers" is not _wrong_ per-se, but given that everything you write in the documentation is telling to the readers and to nobody else, it does not seem to add anything. It is something different from "fix grammar". In short, I do not think anything needs to be changed in the proposed log message in the version that has been queued. > + . The `--base=auto` option tells the command to record the "base > + commit", on which the recipient is expected to apply the patch > + series. The `auto` value will cause `format-patch` to track > + the base commit automatically, which is the merge base of tip > + commit of the remote-tracking branch and the specified > + revision range. Everything after "The `auto` value will..." is new and is a welcome addition, as I agree that giving a brief explanation of the option is a good idea. Thanks for highlighting the careless addition I made in the original version. But use of verb "track" in the format-patch documentation that was copied to this patch should be fixed first. format-patch does not change any history and it does not track anything. Perhaps "track" -> "compute", e.g. The `auto` value will cause `format-patch` to compute the base commit automatically, which is the merge base of tip commit of the remote-tracking branch and the specified revision range. And the matching correction to the existing documentation should look like the attached patch. Thanks. ----- >8 --------- >8 --------- >8 --------- >8 --------- >8 ---- Subject: [PATCH] format-patch (doc): clarify --base=auto What --base=auto tells format-patch is to compute the base commit itself, using the tracking information. It does not make anything track anything. Tighten the phrasing so that it won't be copied and pasted to other places. Signed-off-by: Junio C Hamano <gitster@pobox.com> --- Documentation/git-format-patch.txt | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git c/Documentation/git-format-patch.txt w/Documentation/git-format-patch.txt index fe2f69d36e..113eabc107 100644 --- c/Documentation/git-format-patch.txt +++ w/Documentation/git-format-patch.txt @@ -689,10 +689,10 @@ You can also use `git format-patch --base=P -3 C` to generate patches for A, B and C, and the identifiers for P, X, Y, Z are appended at the end of the first message. -If set `--base=auto` in cmdline, it will track base commit automatically, -the base commit will be the merge base of tip commit of the remote-tracking +If set `--base=auto` in cmdline, it will automatically compute +the base commit as the merge base of tip commit of the remote-tracking branch and revision-range specified in cmdline. -For a local branch, you need to track a remote branch by `git branch +For a local branch, you need to make it to track a remote branch by `git branch --set-upstream-to` before using this option. EXAMPLES
Eric Sunshine <sunshine@sunshineco.com> writes: > On Fri, Oct 22, 2021 at 2:43 AM Bagas Sanjaya <bagasdotme@gmail.com> wrote: >> From: Junio C Hamano <gitster@pobox.com> >> >> Let's encourage first-time contributors to tell us what commit they >> based their work with the format-patch invocation. As the example >> already forks from origin/master and branch.autosetupmerge by >> default records the upstream when the psuh branch was created, we >> can use --base=auto for this. Also, mention to the readers that the >> range of commits can simply be given with `@{u}` if they are on the >> `psuh` branch already. >> >> As we are getting one more option on the command line, and spending >> one paragraph each to explain them, let's reformat that part of the >> description as a bulletted list. > > s/bulletted/bulleted/ Thanks; will fix locally.
diff --git a/Documentation/MyFirstContribution.txt b/Documentation/MyFirstContribution.txt index b20bc8e914..b896d10755 100644 --- a/Documentation/MyFirstContribution.txt +++ b/Documentation/MyFirstContribution.txt @@ -905,19 +905,34 @@ Sending emails with Git is a two-part process; before you can prepare the emails themselves, you'll need to prepare the patches. Luckily, this is pretty simple: ---- -$ git format-patch --cover-letter -o psuh/ master..psuh ----- - -The `--cover-letter` parameter tells `format-patch` to create a cover letter -template for you. You will need to fill in the template before you're ready -to send - but for now, the template will be next to your other patches. - -The `-o psuh/` parameter tells `format-patch` to place the patch files into a -directory. This is useful because `git send-email` can take a directory and -send out all the patches from there. - -`master..psuh` tells `format-patch` to generate patches for the difference -between `master` and `psuh`. It will make one patch file per commit. After you +$ git format-patch --cover-letter -o psuh/ --base=auto psuh@{u}..psuh +---- + + . The `--cover-letter` option tells `format-patch` to create a + cover letter template for you. You will need to fill in the + template before you're ready to send - but for now, the template + will be next to your other patches. + + . The `-o psuh/` option tells `format-patch` to place the patch + files into a directory. This is useful because `git send-email` + can take a directory and send out all the patches from there. + + . The `--base=auto` option tells the command to record the "base + commit", on which the recipient is expected to apply the patch + series. The `auto` value will cause `format-patch` to track + the base commit automatically, which is the merge base of tip + commit of the remote-tracking branch and the specified + revision range. + + . The `psuh@{u}..psuh` option tells `format-patch` to generate + patches for the commits you created on the `psuh` branch since it + forked from its upstream (which is `origin/master` if you + followed the example in the "Set up your workspace" section). If + you are already on the `psuh` branch, you can just say `@{u}`, + which means "commits on the current branch since it forked from + its upstream", which is the same thing. + +The command will make one patch file per commit. After you run, you can go have a look at each of the patches with your favorite text editor and make sure everything looks alright; however, it's not recommended to make code fixups via the patch file. It's a better idea to make the change the