change the branch when the branch not shown in git

2019-02-20 17:48发布

问题:

When I cloned a remote repository, I used the following command-

git clone -b mybranch --single-branch git://sub.domain.com/repo.git

After that, when I did a git branch -l it just showed me the branch I cloned. Now, I want a pull of another branch, but it is not showing me other branches. What should I do?

回答1:

You can list the branches directly on the remote with git ls-remote command:

git ls-remote git://sub.domain.com/repo.git

Then use git fetch command to fetch a specific branch and git checkout command to switch to the branch.



回答2:

git branch -l shows you local branches. You want remote branches, so try git branch -r. When you see the branch you want, you can automatically create and checkout a local branch tracking the given remote branch with git checkout <remote branch name>.

For example, if your git branch -r shows a branch you want called origin/my-feature, just do

$ git checkout my-feature


回答3:

Note that:

  • git branch --list, by default, lists local branches, not remote ones (git branch -r): you can create local branches after those remote ones in order to "see other branches".
  • git branch -l only lists local branches as a side-effect:

It is not the same as git branch --list, and '-l' will be deprecated with Git 2.19 (Q3 2019).
The "-l" option in "git branch -l" is an unfortunate short-hand for "--create-reflog", but many users, both old and new, somehow expect it to be something else, perhaps "--list".
This step warns when "-l" is used as a short-hand for "--create-reflog" and warns about the future repurposing of the it when it is used.

See commit 055930b, commit 7687f19, commit 6b15595 (22 Jun 2018) by Jeff King (peff).
(Merged by Junio C Hamano -- gitster -- in commit d18602f, 18 Jul 2018)

branch: deprecate "-l" option

The "-l" option is short for "--create-reflog". This has caused much confusion over the years.
Most people expect it to work as "--list", because that would match the other "mode" options like -d/--delete and -m/--move, as well as the similar -l/--list option of git-tag.

Adding to the confusion, using "-l" appears to work as "--list" in some cases:

$ git branch -l
* master

because the branch command defaults to listing (so even trying to specify --list in the command above is redundant).
But that may bite the user later when they add a pattern, like:

$ git branch -l foo

which does not return an empty list, but in fact creates a new branch (with a reflog, naturally) called "foo".

It's also probably quite uncommon for people to actually use "-l" to create a reflog. Since 0bee591 (Enable reflogs by default in any repository with a working directory., 2006-12-14 Git v1.5.0), this is the default in non-bare repositories.
So it's rather unfortunate that the feature squats on the short-and-sweet "-l" (which was only added in 3a4b3f2 (Create/delete branch ref logs., 2006-05-19, Git v1.4.0), meaning there were only 7 months where it was actually useful).

Let's deprecate "-l" in hopes of eventually re-purposing it to "--list".


With Git 2.20 (Q2 2018), -l is officially short for --list.

See commit 94a1380 (30 Aug 2018), and commit a15d598 (22 Jun 2018) by Jeff King (peff).
(Merged by Junio C Hamano -- gitster -- in commit 7dc341c, 17 Sep 2018)