d3115660b4
It can be helpful when creating a new branch to use the existing tracking configuration from the branch point. However, there is currently not a method to automatically do so. Teach git-{branch,checkout,switch} an "inherit" argument to the "--track" option. When this is set, creating a new branch will cause the tracking configuration to default to the configuration of the branch point, if set. For example, if branch "main" tracks "origin/main", and we run `git checkout --track=inherit -b feature main`, then branch "feature" will track "origin/main". Thus, `git status` will show us how far ahead/behind we are from origin, and `git pull` will pull from origin. This is particularly useful when creating branches across many submodules, such as with `git submodule foreach ...` (or if running with a patch such as [1], which we use at $job), as it avoids having to manually set tracking info for each submodule. Since we've added an argument to "--track", also add "--track=direct" as another way to explicitly get the original "--track" behavior ("--track" without an argument still works as well). Finally, teach branch.autoSetupMerge a new "inherit" option. When this is set, "--track=inherit" becomes the default behavior. [1]: https://lore.kernel.org/git/20180927221603.148025-1-sbeller@google.com/ Signed-off-by: Josh Steadmon <steadmon@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
277 lines
8.4 KiB
Plaintext
277 lines
8.4 KiB
Plaintext
git-switch(1)
|
|
=============
|
|
|
|
NAME
|
|
----
|
|
git-switch - Switch branches
|
|
|
|
SYNOPSIS
|
|
--------
|
|
[verse]
|
|
'git switch' [<options>] [--no-guess] <branch>
|
|
'git switch' [<options>] --detach [<start-point>]
|
|
'git switch' [<options>] (-c|-C) <new-branch> [<start-point>]
|
|
'git switch' [<options>] --orphan <new-branch>
|
|
|
|
DESCRIPTION
|
|
-----------
|
|
Switch to a specified branch. The working tree and the index are
|
|
updated to match the branch. All new commits will be added to the tip
|
|
of this branch.
|
|
|
|
Optionally a new branch could be created with either `-c`, `-C`,
|
|
automatically from a remote branch of same name (see `--guess`), or
|
|
detach the working tree from any branch with `--detach`, along with
|
|
switching.
|
|
|
|
Switching branches does not require a clean index and working tree
|
|
(i.e. no differences compared to `HEAD`). The operation is aborted
|
|
however if the operation leads to loss of local changes, unless told
|
|
otherwise with `--discard-changes` or `--merge`.
|
|
|
|
THIS COMMAND IS EXPERIMENTAL. THE BEHAVIOR MAY CHANGE.
|
|
|
|
OPTIONS
|
|
-------
|
|
<branch>::
|
|
Branch to switch to.
|
|
|
|
<new-branch>::
|
|
Name for the new branch.
|
|
|
|
<start-point>::
|
|
The starting point for the new branch. Specifying a
|
|
`<start-point>` allows you to create a branch based on some
|
|
other point in history than where HEAD currently points. (Or,
|
|
in the case of `--detach`, allows you to inspect and detach
|
|
from some other point.)
|
|
+
|
|
You can use the `@{-N}` syntax to refer to the N-th last
|
|
branch/commit switched to using "git switch" or "git checkout"
|
|
operation. You may also specify `-` which is synonymous to `@{-1}`.
|
|
This is often used to switch quickly between two branches, or to undo
|
|
a branch switch by mistake.
|
|
+
|
|
As a special case, you may use `A...B` as a shortcut for the merge
|
|
base of `A` and `B` if there is exactly one merge base. You can leave
|
|
out at most one of `A` and `B`, in which case it defaults to `HEAD`.
|
|
|
|
-c <new-branch>::
|
|
--create <new-branch>::
|
|
Create a new branch named `<new-branch>` starting at
|
|
`<start-point>` before switching to the branch. This is a
|
|
convenient shortcut for:
|
|
+
|
|
------------
|
|
$ git branch <new-branch>
|
|
$ git switch <new-branch>
|
|
------------
|
|
|
|
-C <new-branch>::
|
|
--force-create <new-branch>::
|
|
Similar to `--create` except that if `<new-branch>` already
|
|
exists, it will be reset to `<start-point>`. This is a
|
|
convenient shortcut for:
|
|
+
|
|
------------
|
|
$ git branch -f <new-branch>
|
|
$ git switch <new-branch>
|
|
------------
|
|
|
|
-d::
|
|
--detach::
|
|
Switch to a commit for inspection and discardable
|
|
experiments. See the "DETACHED HEAD" section in
|
|
linkgit:git-checkout[1] for details.
|
|
|
|
--guess::
|
|
--no-guess::
|
|
If `<branch>` is not found but there does exist a tracking
|
|
branch in exactly one remote (call it `<remote>`) with a
|
|
matching name, treat as equivalent to
|
|
+
|
|
------------
|
|
$ git switch -c <branch> --track <remote>/<branch>
|
|
------------
|
|
+
|
|
If the branch exists in multiple remotes and one of them is named by
|
|
the `checkout.defaultRemote` configuration variable, we'll use that
|
|
one for the purposes of disambiguation, even if the `<branch>` isn't
|
|
unique across all remotes. Set it to e.g. `checkout.defaultRemote=origin`
|
|
to always checkout remote branches from there if `<branch>` is
|
|
ambiguous but exists on the 'origin' remote. See also
|
|
`checkout.defaultRemote` in linkgit:git-config[1].
|
|
+
|
|
`--guess` is the default behavior. Use `--no-guess` to disable it.
|
|
+
|
|
The default behavior can be set via the `checkout.guess` configuration
|
|
variable.
|
|
|
|
-f::
|
|
--force::
|
|
An alias for `--discard-changes`.
|
|
|
|
--discard-changes::
|
|
Proceed even if the index or the working tree differs from
|
|
`HEAD`. Both the index and working tree are restored to match
|
|
the switching target. If `--recurse-submodules` is specified,
|
|
submodule content is also restored to match the switching
|
|
target. This is used to throw away local changes.
|
|
|
|
-m::
|
|
--merge::
|
|
If you have local modifications to one or more files that are
|
|
different between the current branch and the branch to which
|
|
you are switching, the command refuses to switch branches in
|
|
order to preserve your modifications in context. However,
|
|
with this option, a three-way merge between the current
|
|
branch, your working tree contents, and the new branch is
|
|
done, and you will be on the new branch.
|
|
+
|
|
When a merge conflict happens, the index entries for conflicting
|
|
paths are left unmerged, and you need to resolve the conflicts
|
|
and mark the resolved paths with `git add` (or `git rm` if the merge
|
|
should result in deletion of the path).
|
|
|
|
--conflict=<style>::
|
|
The same as `--merge` option above, but changes the way the
|
|
conflicting hunks are presented, overriding the
|
|
`merge.conflictStyle` configuration variable. Possible values are
|
|
"merge" (default) and "diff3" (in addition to what is shown by
|
|
"merge" style, shows the original contents).
|
|
|
|
-q::
|
|
--quiet::
|
|
Quiet, suppress feedback messages.
|
|
|
|
--progress::
|
|
--no-progress::
|
|
Progress status is reported on the standard error stream
|
|
by default when it is attached to a terminal, unless `--quiet`
|
|
is specified. This flag enables progress reporting even if not
|
|
attached to a terminal, regardless of `--quiet`.
|
|
|
|
-t::
|
|
--track [direct|inherit]::
|
|
When creating a new branch, set up "upstream" configuration.
|
|
`-c` is implied. See `--track` in linkgit:git-branch[1] for
|
|
details.
|
|
+
|
|
If no `-c` option is given, the name of the new branch will be derived
|
|
from the remote-tracking branch, by looking at the local part of the
|
|
refspec configured for the corresponding remote, and then stripping
|
|
the initial part up to the "*". This would tell us to use `hack` as
|
|
the local branch when branching off of `origin/hack` (or
|
|
`remotes/origin/hack`, or even `refs/remotes/origin/hack`). If the
|
|
given name has no slash, or the above guessing results in an empty
|
|
name, the guessing is aborted. You can explicitly give a name with
|
|
`-c` in such a case.
|
|
|
|
--no-track::
|
|
Do not set up "upstream" configuration, even if the
|
|
`branch.autoSetupMerge` configuration variable is true.
|
|
|
|
--orphan <new-branch>::
|
|
Create a new 'orphan' branch, named `<new-branch>`. All
|
|
tracked files are removed.
|
|
|
|
--ignore-other-worktrees::
|
|
`git switch` refuses when the wanted ref is already
|
|
checked out by another worktree. This option makes it check
|
|
the ref out anyway. In other words, the ref can be held by
|
|
more than one worktree.
|
|
|
|
--recurse-submodules::
|
|
--no-recurse-submodules::
|
|
Using `--recurse-submodules` will update the content of all
|
|
active submodules according to the commit recorded in the
|
|
superproject. If nothing (or `--no-recurse-submodules`) is
|
|
used, submodules working trees will not be updated. Just
|
|
like linkgit:git-submodule[1], this will detach `HEAD` of the
|
|
submodules.
|
|
|
|
EXAMPLES
|
|
--------
|
|
|
|
The following command switches to the "master" branch:
|
|
|
|
------------
|
|
$ git switch master
|
|
------------
|
|
|
|
After working in the wrong branch, switching to the correct branch
|
|
would be done using:
|
|
|
|
------------
|
|
$ git switch mytopic
|
|
------------
|
|
|
|
However, your "wrong" branch and correct "mytopic" branch may differ
|
|
in files that you have modified locally, in which case the above
|
|
switch would fail like this:
|
|
|
|
------------
|
|
$ git switch mytopic
|
|
error: You have local changes to 'frotz'; not switching branches.
|
|
------------
|
|
|
|
You can give the `-m` flag to the command, which would try a three-way
|
|
merge:
|
|
|
|
------------
|
|
$ git switch -m mytopic
|
|
Auto-merging frotz
|
|
------------
|
|
|
|
After this three-way merge, the local modifications are _not_
|
|
registered in your index file, so `git diff` would show you what
|
|
changes you made since the tip of the new branch.
|
|
|
|
To switch back to the previous branch before we switched to mytopic
|
|
(i.e. "master" branch):
|
|
|
|
------------
|
|
$ git switch -
|
|
------------
|
|
|
|
You can grow a new branch from any commit. For example, switch to
|
|
"HEAD~3" and create branch "fixup":
|
|
|
|
------------
|
|
$ git switch -c fixup HEAD~3
|
|
Switched to a new branch 'fixup'
|
|
------------
|
|
|
|
If you want to start a new branch from a remote branch of the same
|
|
name:
|
|
|
|
------------
|
|
$ git switch new-topic
|
|
Branch 'new-topic' set up to track remote branch 'new-topic' from 'origin'
|
|
Switched to a new branch 'new-topic'
|
|
------------
|
|
|
|
To check out commit `HEAD~3` for temporary inspection or experiment
|
|
without creating a new branch:
|
|
|
|
------------
|
|
$ git switch --detach HEAD~3
|
|
HEAD is now at 9fc9555312 Merge branch 'cc/shared-index-permbits'
|
|
------------
|
|
|
|
If it turns out whatever you have done is worth keeping, you can
|
|
always create a new name for it (without switching away):
|
|
|
|
------------
|
|
$ git switch -c good-surprises
|
|
------------
|
|
|
|
SEE ALSO
|
|
--------
|
|
linkgit:git-checkout[1],
|
|
linkgit:git-branch[1]
|
|
|
|
GIT
|
|
---
|
|
Part of the linkgit:git[1] suite
|