Git 的好處之一就是把代碼的分支管理變成了一件極其便捷的事情,分支只保留差異,不用復制任何文件,不用連接網(wǎng)絡,快速創(chuàng)建,用完即刪。Git 分支與項目的復雜程度無關,不管你的項目多么復雜,創(chuàng)建 Git 分支永遠都是瞬間的事情。同時,因為保留了父類分支的信息,所以分支的合并也變得異常簡單。
當在一個項目中頻繁使用多個分支時,可以使用 git status 命令查詢自己現(xiàn)在正工作在哪個分支下面,不過難免有腦子發(fā)昏的時候,忘記自己在哪個分支下面,因而發(fā)生誤操作之類的杯具。
那么把分支顯示在 Shell 提示符中無疑方便了很多,再也不需要頻繁的使用 git status 命令了…
實現(xiàn)原理很簡單,大體就是查詢當前目錄下面的 Git 分支名稱,然后嵌入到 PS1 變量中。那么,Git 分支名稱可以通過下面的腳本輕松的獲得:
復制代碼 代碼如下:
git branch --no-color 2> /dev/null | sed -e '/^[^*]/d' -e 's/* \(.*\)/(\1)/'
把上面的腳本封裝到函數(shù)中,修改 PS1 變量,嵌入函數(shù)… 大體是這樣。但是這樣也意味著一個問題,就是每次 shell 活動(比如切換目錄,甚至只是敲下回車)都會執(zhí)行一次 git … sed 命令,這樣每次都啟動2個進程,實在是有些不爽。
好在,可以使用另外一種方式來獲取 Git 分支名稱,在每個 Git 項目中,都有一個 .git 目錄,這個目錄下面有個叫做 HEAD 的文件,里面包含的當前分支的路徑信息:
復制代碼 代碼如下:
ref: refs/heads/BRANCH-NAME
我們只要讀取這個文件,然后再和對應的路徑互相匹配一下就知道正確地分支名稱了。不要只是簡單的從 HEAD 內(nèi)容中拆分出最后的 BRANCH-NAME,因為它不一定是正確地。
以下是 Aaron Crane 的實現(xiàn)方式:
復制代碼 代碼如下:
## Parses out the branch name from .git/HEAD:
find_git_branch () {
local dir=. head
until [ "$dir" -ef / ]; do
if [ -f "$dir/.git/HEAD" ]; then
head=$( "$dir/.git/HEAD")
if [[ $head = ref:\ refs/heads/* ]]; then
git_branch=" → ${head#*/*/}"
elif [[ $head != '' ]]; then
git_branch=" → (detached)"
else
git_branch=" → (unknow)"
fi
return
fi
dir="../$dir"
done
git_branch=''
}
接下來,將這個函數(shù)加入到 PROMPT_COMMAND 中,保證 Bash 在創(chuàng)建 prompt 之前調(diào)用這個函數(shù)取得分支名稱:
復制代碼 代碼如下:
PROMPT_COMMAND="find_git_branch; $PROMPT_COMMAND"
最后只要重新定義 PS1 變量即可:
復制代碼 代碼如下:
# Here is bash color codes you can use
black=$'\[\e[1;30m\]'
red=$'\[\e[1;31m\]'
green=$'\[\e[1;32m\]'
yellow=$'\[\e[1;33m\]'
blue=$'\[\e[1;34m\]'
magenta=$'\[\e[1;35m\]'
cyan=$'\[\e[1;36m\]'
white=$'\[\e[1;37m\]'
normal=$'\[\e[m\]'
PS1="$white[$magenta\u$white@$green\h$white:$cyan\w$yellow\$git_branch$white]\$ $normal"
以上的代碼你可以放在 ~/.profile 或者 ~/.bash_profile 等文件中即可,我的系統(tǒng)是 Snow Leopard,PS1 定義在 /etc/bashrc 中,所以我直接修改的這個文件。
最終效果如下:
UPDATE – 2010/06/23:
如果你安裝了隨 Git 附送的 git-completion.sh 子命令自動完成腳本,也可以使用該腳本提供的方法:
復制代碼 代碼如下:
export PS1="[\u@\h \W"'$(__git_ps1 " (%s)")'"]\$ "
Ubuntu 系統(tǒng),請參考: /etc/bash_completion.d/git
您可能感興趣的文章:- 淺談Git分支管理策略
- git恢復刪除的分支及內(nèi)容的方法
- Git 創(chuàng)建分支提交遠程分支詳解
- Git 詳細介紹查看、刪除、重命名遠程分支和tag
- git分支的創(chuàng)建、切換、合并及刪除操作小結
- Git常用場景使用之分支操作