* [PATCH] doc: clarify difference between `push.default` `simple` and `current`
@ 2025-07-23 23:00 Dan Fabulich via GitGitGadget
2025-07-23 23:36 ` Junio C Hamano
0 siblings, 1 reply; 2+ messages in thread
From: Dan Fabulich via GitGitGadget @ 2025-07-23 23:00 UTC (permalink / raw)
To: git; +Cc: Dan Fabulich, Dan Fabulich
From: Dan Fabulich <dan@fabulich.com>
The documentation made `simple` and `current` sound identical. The
difference is that `simple` strictly checks that the upstream tracking
branch's name matches the current branch's name.
Signed-off-by: Dan Fabulich <dan@fabulich.com>
---
doc: clarify difference between push.default simple and current
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-1944%2Fdfabulich%2Fgit-config-simple-doc-v1
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-1944/dfabulich/git-config-simple-doc-v1
Pull-Request: https://github.com/gitgitgadget/git/pull/1944
Documentation/config/push.adoc | 16 +++++++++-------
1 file changed, 9 insertions(+), 7 deletions(-)
diff --git a/Documentation/config/push.adoc b/Documentation/config/push.adoc
index 0acbbea18a3..3e03cb31606 100644
--- a/Documentation/config/push.adoc
+++ b/Documentation/config/push.adoc
@@ -15,7 +15,7 @@ push.default::
Different values are well-suited for
specific workflows; for instance, in a purely central workflow
(i.e. the fetch source is equal to the push destination),
- `upstream` is probably what you want. Possible values are:
+ `simple` is probably what you want. Possible values are:
+
--
@@ -23,8 +23,8 @@ push.default::
given. This is primarily meant for people who want to
avoid mistakes by always being explicit.
-* `current` - push the current branch to update a branch with the same
- name on the receiving end. Works in both central and non-central
+* `current` - push the current branch to update the branch with the same
+ name on the remote. Works in both central and non-central
workflows.
* `upstream` - push the current branch back to the branch whose
@@ -35,11 +35,13 @@ push.default::
* `tracking` - This is a deprecated synonym for `upstream`.
-* `simple` - push the current branch with the same name on the remote.
+* `simple` - push the current branch to its upstream tracking branch,
+ but only if the upstream tracking branch has the same name as the
+ current branch. (`simple` will fail with an error if the upstream
+ tracking branch's name doesn't match the current branch's name.)
+
-If you are working on a centralized workflow (pushing to the same repository you
-pull from, which is typically `origin`), then you need to configure an upstream
-branch with the same name.
+`simple` will also fail if the current branch doesn't have an upstream
+tracking branch configured, unless `push.autoSetupRemote` is enabled.
+
This mode is the default since Git 2.0, and is the safest option suited for
beginners.
base-commit: 3f2a94875d2f41fe4758a439f68d8b73cfb19d0f
--
gitgitgadget
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH] doc: clarify difference between `push.default` `simple` and `current`
2025-07-23 23:00 [PATCH] doc: clarify difference between `push.default` `simple` and `current` Dan Fabulich via GitGitGadget
@ 2025-07-23 23:36 ` Junio C Hamano
0 siblings, 0 replies; 2+ messages in thread
From: Junio C Hamano @ 2025-07-23 23:36 UTC (permalink / raw)
To: Dan Fabulich via GitGitGadget; +Cc: git, Dan Fabulich
"Dan Fabulich via GitGitGadget" <gitgitgadget@gmail.com> writes:
> From: Dan Fabulich <dan@fabulich.com>
>
> The documentation made `simple` and `current` sound identical. The
> difference is that `simple` strictly checks that the upstream tracking
> branch's name matches the current branch's name.
All of the above are correct, and a patch that sticks to fixing that
would have given us a great improvement.
Thanks for working on this documentation update, but it seems some
unrelated changes are mixed in.
> Different values are well-suited for
> specific workflows; for instance, in a purely central workflow
> (i.e. the fetch source is equal to the push destination),
> - `upstream` is probably what you want. Possible values are:
> + `simple` is probably what you want. Possible values are:
This change is not explained/justified at all why it was part of the
patch in the proposed log message.
And I do not think this is a good change. `upstream` is recommended
for most people when they employ a purely central workflow. You can
start working from the common 'master', even on multiple topics in
parallel at the same time, and perform "git push" with push.default
set to 'upstream'. With 'simple' you cannot.
$ git checkout -t -b theme1 origin/master
... work work work ...
$ git checkout -t -b theme2 origin/master
... work work work ...
... changes for theme2 become complete first ...
$ git push
Here, if your push.default is set to 'upstream', your theme2 updates
their master, which is exactly what you want. Then
$ git fetch origin
$ git rebase origin/master theme1
... rebased on updated 'master' at theirs --- at least it should
... contain what we did on our theme2 topic, but possibly
... changes from other people.
... more work ...
$ git push
Again, your theme1 updates their master, which is exactly what you
want.
> @@ -23,8 +23,8 @@ push.default::
> given. This is primarily meant for people who want to
> avoid mistakes by always being explicit.
>
> -* `current` - push the current branch to update a branch with the same
> - name on the receiving end. Works in both central and non-central
> +* `current` - push the current branch to update the branch with the same
> + name on the remote. Works in both central and non-central
> workflows.
Again, a change that is not explained/justified. "a" -> "the" I can
understand (i.e. a branch with the same name is unique over there,
so "the" is more appropriate), but not the other one.
> * `tracking` - This is a deprecated synonym for `upstream`.
>
> -* `simple` - push the current branch with the same name on the remote.
> +* `simple` - push the current branch to its upstream tracking branch,
> + but only if the upstream tracking branch has the same name as the
> + current branch. (`simple` will fail with an error if the upstream
> + tracking branch's name doesn't match the current branch's name.)
That is correct. The additional text may be somewhat helpful for
somebody who just got an error message and wants to understand where
the error comes from.
But stepping back a bit, is understanding why it failed the primary
thing our documentation should aim for? I'd rather see our
documentation help the user achieve what they wanted to do in the
first place. I.e., Be able to push without an error to publish
their work. And for that "this will fail when X" is less helpful
than "this is appropriate if you work this way."
simple - this is like `upstream` but with additional restriction
that the local branch must be named the same as its upstream
branch. Suitable with a very simple centralized workflow, where
you fork off of their 'master' branch to create your own
'master', work there, and push the branch back.
> +
> -If you are working on a centralized workflow (pushing to the same repository you
> -pull from, which is typically `origin`), then you need to configure an upstream
> -branch with the same name.
I do not think this removal is explained/justified, either. Those
who set push.default to 'simple' while using the centralized
workflow must use one-to-one correspondence, so this advice is very
relevant. What makes it a good idea to remove it?
Thanks.
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2025-07-23 23:36 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-07-23 23:00 [PATCH] doc: clarify difference between `push.default` `simple` and `current` Dan Fabulich via GitGitGadget
2025-07-23 23:36 ` Junio C Hamano
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).