Docs: Expand explanation of the use of + in git push refspecs.
Signed-off-by: Marc Branchaud <marcnarc@xiplink.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
6ab149ea89
commit
149f6ddfb3
@ -48,17 +48,19 @@ push. Arbitrary expressions cannot be used here, an actual ref must
|
|||||||
be named. If `:`<dst> is omitted, the same ref as <src> will be
|
be named. If `:`<dst> is omitted, the same ref as <src> will be
|
||||||
updated.
|
updated.
|
||||||
+
|
+
|
||||||
The object referenced by <src> is used to fast forward the ref <dst>
|
The object referenced by <src> is used to update the <dst> reference
|
||||||
on the remote side. If the optional leading plus `{plus}` is used, the
|
on the remote side, but by default this is only allowed if the
|
||||||
remote ref is updated even if it does not result in a fast forward
|
update can fast forward <dst>. By having the optional leading `{plus}`,
|
||||||
update.
|
you can tell git to update the <dst> ref even when the update is not a
|
||||||
|
fast forward. This does *not* attempt to merge <src> into <dst>. See
|
||||||
|
EXAMPLES below for details.
|
||||||
+
|
+
|
||||||
`tag <tag>` means the same as `refs/tags/<tag>:refs/tags/<tag>`.
|
`tag <tag>` means the same as `refs/tags/<tag>:refs/tags/<tag>`.
|
||||||
+
|
+
|
||||||
Pushing an empty <src> allows you to delete the <dst> ref from
|
Pushing an empty <src> allows you to delete the <dst> ref from
|
||||||
the remote repository.
|
the remote repository.
|
||||||
+
|
+
|
||||||
The special refspec `:` (or `+:` to allow non-fast forward updates)
|
The special refspec `:` (or `{plus}:` to allow non-fast forward updates)
|
||||||
directs git to push "matching" branches: for every branch that exists on
|
directs git to push "matching" branches: for every branch that exists on
|
||||||
the local side, the remote side is updated if a branch of the same name
|
the local side, the remote side is updated if a branch of the same name
|
||||||
already exists on the remote side. This is the default operation mode
|
already exists on the remote side. This is the default operation mode
|
||||||
@ -218,6 +220,30 @@ git push origin :experimental::
|
|||||||
Find a ref that matches `experimental` in the `origin` repository
|
Find a ref that matches `experimental` in the `origin` repository
|
||||||
(e.g. `refs/heads/experimental`), and delete it.
|
(e.g. `refs/heads/experimental`), and delete it.
|
||||||
|
|
||||||
|
git push origin {plus}dev:master::
|
||||||
|
Update the origin repository's master branch with the dev branch,
|
||||||
|
allowing non-fast forward updates. *This can leave unreferenced
|
||||||
|
commits dangling in the origin repository.* Consider the
|
||||||
|
following situation, where a fast forward is not possible:
|
||||||
|
+
|
||||||
|
----
|
||||||
|
o---o---o---A---B origin/master
|
||||||
|
\
|
||||||
|
X---Y---Z dev
|
||||||
|
----
|
||||||
|
+
|
||||||
|
The above command would change the origin repository to
|
||||||
|
+
|
||||||
|
----
|
||||||
|
A---B (unnamed branch)
|
||||||
|
/
|
||||||
|
o---o---o---X---Y---Z master
|
||||||
|
----
|
||||||
|
+
|
||||||
|
Commits A and B would no longer belong to a branch with a symbolic name,
|
||||||
|
and so would be unreachable. As such, these commits would be removed by
|
||||||
|
a `git gc` command on the origin repository.
|
||||||
|
|
||||||
|
|
||||||
Author
|
Author
|
||||||
------
|
------
|
||||||
|
Loading…
Reference in New Issue
Block a user