我来自Subversion的背景,当我有一个分支时,我知道我正在使用“这些工作文件指向此分支”的内容。
但是使用Git时,我不确定在NetBeans或Notepad ++中编辑文件时,是将文件绑定到主文件还是其他分支。
bash中的git
没问题,它告诉我我在做什么。
好简单,我把它放在一根衬里(bash)
git branch | sed -n '/\* /s///p'
(信用:有限赎罪)
当我在那里的时候,一个班轮去了远程跟踪分支机构(如果有的话)
git rev-parse --symbolic-full-name --abbrev-ref @{u}
您还可以使用git symbolic-ref HEAD
来显示完整的refspec。
在Git v1.8及更高版本中仅显示分支名称(感谢Greg指出):
$ git symbolic-ref --short HEAD
在Git v1.7 +上,您还可以执行以下操作:
$ git rev-parse --abbrev-ref HEAD
如果您在分支机构上,则两者都应使用相同的分支机构名称。 如果您是一个超脱的人,答案会有所不同。
注意:
在较早的客户端上,这似乎可行:
$ git symbolic-ref HEAD | sed -e "s/^refs\\/heads\\///"
– 达里安2014年3月26日
在Netbeans中,确保已启用版本注释(查看->显示版本标签)。 然后,您可以在项目名称旁边看到分支名称。
http://netbeans.org/bugzilla/show_bug.cgi?id=213582
要显示当前所在的分支,而未列出其他分支,可以执行以下操作:
git rev-parse --abbrev-ref HEAD
参考:
那这个呢?
{ git symbolic-ref HEAD 2> /dev/null || git rev-parse --short HEAD 2> /dev/null } | sed "s#refs/heads/##"
git symbolic-ref -q --short HEAD
我在需要当前分支名称的脚本中使用它。 它将向您显示当前对HEAD的简短符号引用,这将是您当前的分支名称。
供我自己参考(但可能对其他人有用),我对该线程中提到的大多数(基本命令行)技术进行了概述,每种技术都适用于几种用例:HEAD(指向):
结果:
git branch | sed -n '/\\* /s///p'
master
(detached from origin/master)
(detached from origin/feature-foo)
(detached from v1.2.3)
(HEAD detached at 285f294)
(detached from 285f294)
git status | head -1
# On branch master
# HEAD detached at origin/master
# HEAD detached at origin/feature-foo
# HEAD detached at v1.2.3
# HEAD detached at 285f294
# HEAD detached at 285f294
git describe --all
heads/master
heads/master
(注意: 不是 remotes/origin/master
) remotes/origin/feature-foo
v1.2.3
remotes/origin/HEAD
v1.0.6-5-g2393761
cat .git/HEAD
:
ref: refs/heads/master
cat: .git/HEAD: Not a directory
git rev-parse --abbrev-ref HEAD
master
HEAD
git symbolic-ref --short HEAD
master
fatal: ref HEAD is not a symbolic ref
(仅供参考,这是使用git版本1.8.3.1完成的)
找到了与Oliver Refalo一样长的命令行解决方案,使用了很好的awk:
git branch | awk '/^\*/{print $2}'
awk
读取为“在与正则表达式匹配的行上执行{}
的内容”。 默认情况下,它采用空格分隔的字段,因此您打印第二个。 如果可以假定只有分支所在的行带有*,则可以删除^。 啊,打高尔夫球!
您还可以使用如下所示的GIT_BRANCH变量: https ://wiki.jenkins-ci.org/display/JENKINS/Git+Plugin
git插件设置了几个可以在脚本中使用的环境变量:
GIT_COMMIT-当前的SHA
GIT_BRANCH-当前正在使用的分支的名称,例如“ master”或“ origin / foo”
GIT_PREVIOUS_COMMIT-来自同一分支的先前构建提交的SHA(当前在第一个构建分支中的SHA)
GIT_URL-存储库远程URL
GIT_URL_N-存在多个远程目录时的存储库远程URL,例如GIT_URL_1,GIT_URL_2
GIT_AUTHOR_EMAIL-提交人/作者的电子邮件
GIT_COMMITTER_EMAIL-提交人/作者的电子邮件
随着时间的流逝,我们的分支机构列表可能会很长。
尽管其他一些解决方案也很棒,但是这是我的工作(从Jacob的回答中简化):
git branch | grep \*
现在,
git status
工作,但只如果有任何局部变化
如果您确实希望以分离的HEAD状态签出最后一个分支/标记。
git reflog HEAD | grep 'checkout:' | head -1 | rev | cut -d' ' -f1 | rev
更新如果您有并且不害怕awk,这会更好。
git reflog HEAD | grep 'checkout:' | head -1 | awk '{print $NF}'
我知道这很晚,但是在linux / mac上,可以从终端使用以下命令。
git status | sed -n 1p
说明:
git status->获取工作树状态
sed -n 1p->从状态正文中获取第一行
对以上命令的响应如下所示:
"On branch your_branch_name"
另一种选择:
git name-rev --name-only HEAD
抱歉,这是另一个命令行答案,但是当我找到这个问题时,这就是我想要的东西,其中许多答案都很有帮助。 我的解决方案是以下bash shell函数:
get_branch () {
git rev-parse --abbrev-ref HEAD | grep -v HEAD || \
git describe --exact-match HEAD 2> /dev/null || \
git rev-parse HEAD
}
这应该总是给我一些既可读又可直接用作git checkout
的参数的东西。
feature/HS-0001
v3.29.5
我有一个简单的脚本git-cbr
( current branch ),它打印出当前的分支名称。
#!/bin/bash
git branch | grep -e "^*"
我将此脚本放在自定义文件夹( ~/.bin
)中。 该文件夹位于$PATH
。
因此,现在当我进入git存储库时,只需键入git cbr
即可打印出当前分支名称。
$ git cbr
* master
之所以可行,是因为git
命令采用第一个参数,并尝试运行名为git-arg1
的脚本。 例如, git branch
尝试运行一个名为git-branch
的脚本,等等。
git branch | grep -e "^*" | cut -d' ' -f 2
将仅显示分支名称
您可以永久设置bash输出以显示git-branch名称。 当您使用不同的分支时,这非常方便,无需始终键入$ git status
。 Github回购git-aware-prompt 。
打开终端(ctrl-alt-t)并输入命令
mkdir ~/.bash
cd ~/.bash
git clone git://github.com/jimeh/git-aware-prompt.git
使用sudo nano ~/.bashrc
命令(对于Ubuntu)编辑.bashrc,并将以下内容添加到顶部:
export GITAWAREPROMPT=~/.bash/git-aware-prompt
source "${GITAWAREPROMPT}/main.sh"
然后粘贴代码
export PS1="\${debian_chroot:+(\$debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\] \[$txtcyn\]\$git_branch\[$txtred\]\$git_dirty\[$txtrst\]\$ "
在同一文件的末尾,您将安装代码粘贴到了前面。 这将为您提供彩色输出:
使用Mac将其添加到PS1
:
PS1='\W@\u >`[ -d .git ] && git branch | grep ^*|cut -d" " -f2`> $ '
在运行上面的命令之前:
运行该命令后:
不用担心,如果它不是GIT存储库,则不会显示错误,因为[-d .git]
会检查.git
文件夹是否存在。
以下shell命令告诉您当前所在的分支。
git branch | grep ^\*
当您不想每次都想知道分支并且要使用Bash时都键入该长命令时,请为该命令提供一个简短的别名,例如别名cb
,就像这样。
alias cb='git branch | grep ^\*'
当您在分支master中,并且提示符为$
,将获得* master
,如下所示。
$ cb
* master
您可以在工作目录命令上使用git bash如下
git status -b
它会告诉您所在的分支上有很多有用的命令,其中一些是
-s
--short以短格式给出输出。
-b --branch即使以短格式显示分支和跟踪信息。
--porcelain [=]以易于解析的格式为脚本提供输出。 这类似于简短的输出,但是无论用户配置如何,在Git版本之间都将保持稳定。 有关详情,请参见下文。
version参数用于指定格式版本。 这是可选的,默认为原始版本v1格式。
--long以长格式给出输出。 这是默认值。
-v --verbose除了已更改的文件名之外,还显示已暂存的文本更改(即,例如git diff --cached的输出)。 如果两次指定-v,那么还将显示尚未上演的工作树中的更改(即,类似于git diff的输出)。
位于分离头上时返回分支名称或SHA1:
git rev-parse --abbrev-ref HEAD | grep -v ^HEAD$ || git rev-parse HEAD
这是@ dmaestro12答案的简短版本,没有标签支持。
git status
还将给出分支名称以及更改。
例如
>git status
On branch master // <-- branch name here
.....
我建议使用这两个命令中的任何一个。
git branch | grep -e "^*" | cut -d' ' -f 2
要么
git status | sed -n 1p | cut -d' ' -f 3
或(更详细)
git status -uno -bs| cut -d'#' -f 3 | cut -d . -f 1| sed -e 's/^[ \\t]//1'| sed -n 1p
较低的git status版本可以解决问题
git status -bsuno
打印出来
## branch-name
git branch
仅显示当前分支名称。
虽然git branch将显示所有分支并用星号突出显示当前分支,但在使用许多分支时可能会很麻烦。
要仅显示您当前所在的分支,请使用:
git rev-parse --abbrev-ref HEAD
从git的2.22版开始,您可以使用:
git branch --show-current
git branch
应该显示您的仓库的所有本地分支。 已加星号的分支是您当前的分支。
如果只想检索所在分支的名称,则可以执行以下操作:
git rev-parse --abbrev-ref HEAD
您只需在Linux的存储库目录中输入命令行(控制台)即可:
$ git status
您会看到一些文本,其中类似于:
...
On branch master
...
这意味着您当前在master
分支上。 如果此时正在编辑任何文件,并且该文件位于同一本地存储库(包含Git版本控制管理下的文件的本地目录)中,则您正在此分支中编辑文件。
为什么不使用git-aware shell提示,它会告诉您当前分支的名称? git status
也有帮助。
__git_ps1
辅助函数中定义的来自contrib/
git-prompt.sh是如何做到的 (git版本2.3.0):
首先,在特殊情况下,如果检测到正在进行重新设置基准 。 Git在改基过程中使用未命名的分支(分离的HEAD)使其成为原子,原始分支保存在其他位置。
如果.git/HEAD
文件是符号链接(在Git的古代历史中非常罕见),则使用git symbolic-ref HEAD 2>/dev/null
否则,它读取.git/HEAD
文件。 后续步骤取决于其内容:
如果此文件不存在,则没有当前分支。 如果存储库是裸露的,通常会发生这种情况。
如果它以'ref: '
前缀开头,则.git/HEAD
是symref(符号引用),并且我们在常规分支上。 剥离此前缀可获得全名,剥离refs/heads/
可获得当前分支的简称:
b="${head#ref: }" # ... b=${b##refs/heads/}
如果它不是以'ref: '
开头,则它是分离的HEAD(匿名分支),直接指向某个提交。 使用git describe ...
以易于阅读的形式编写当前提交。
希望对您有所帮助。
#!/bin/bash
function git.branch {
br=`git branch | grep "*"`
echo ${br/* /}
}
git.branch