詳解Git圖形界面的使用
圖形界面
Git 的原生環(huán)境是終端。 在那里,你可以體驗(yàn)到***的功能,也只有在那里,你才能盡情發(fā)揮 Git 的全部能力。 但是對(duì)于某些任務(wù)而言,純文本并不是***的選擇;有時(shí)候你確實(shí)需要一個(gè)可視化的展示方式,而且有些用戶更習(xí)慣那種能點(diǎn)擊的界面。
有一點(diǎn)請(qǐng)注意,不同的界面是為不同的工作流程設(shè)計(jì)的。 一些客戶端的作者為了支持某種他認(rèn)為高效的工作流程,經(jīng)過精心挑選,只顯示了 Git 功能的一個(gè)子集。 每種工具都有其特定的目的和意義,從這個(gè)角度來看,不能說某種工具比其它的“更好”。 還有請(qǐng)注意,沒有什么事情是圖形界面客戶端可以做而命令行客戶端不能做的;命令行始終是你可以完全操控倉庫并發(fā)揮出全部力量的地方。
gitk 和 git-gui
在安裝 Git 的同時(shí),你也裝好了它提供的可視化工具,gitk 和 git-gui。
gitk 是一個(gè)歷史記錄的圖形化查看器,你可以把它當(dāng)作是基于 git log 和 git grep 命令的一個(gè)強(qiáng)大的圖形操作界面,當(dāng)你需要查找過去發(fā)生的某次記錄,或是可視化查看項(xiàng)目歷史的時(shí)候,你將會(huì)用到這個(gè)工具。
使用 Gitk 的最簡(jiǎn)單方法就是從命令行打開,只需 cd 到一個(gè) Git 倉庫,然后鍵入:
- $ gitk [git log options]
Gitk 可以接受很多命令行選項(xiàng),其中的大部分都直接傳給底層的 git log 去執(zhí)行了。 --all可能是這其中最有用的一個(gè), 它告訴 gitk 去盡可能地從任何引用查找提交并顯示,而不僅僅是從 HEAD,Gitk 的界面看起來長(zhǎng)這樣
gitk 歷史查看器
這張圖看起來就和執(zhí)行 git log --graph命令的輸出差不多;每個(gè)點(diǎn)代表一次提交,線代表父子關(guān)系,而彩色的方塊則用來標(biāo)示一個(gè)個(gè)引用。 黃點(diǎn)表示 HEAD,紅點(diǎn)表示尚未提交的本地變動(dòng)。 下方的窗口用來顯示當(dāng)前選中的提交的具體信息;評(píng)論和補(bǔ)丁顯示在左側(cè),摘要顯示在右側(cè)。 中間則是一組用來搜索歷史的控件。
與之相比,git-gui 則主要是一個(gè)用來制作提交的工具。 打開它的最簡(jiǎn)單方法也是從命令行啟動(dòng):
- $ git gui
它的界面長(zhǎng)這個(gè)樣子:
git-gui 提交工具
左側(cè)是索引區(qū);未暫存的修改顯示在上方,已暫存的修改顯示在下方。你可以通過點(diǎn)擊文件名左側(cè)的圖標(biāo)來將該文件在暫存狀態(tài)與未暫存狀態(tài)之間切換,你也可以通過選中一個(gè)文件名來查看它的詳情。
右側(cè)窗口的上方以 diff 格式來顯示當(dāng)前選中文件發(fā)生了變動(dòng)的地方,你可以通過右擊某一區(qū)塊或行從而將這一區(qū)塊或行放入暫存區(qū)。
右側(cè)窗口的下方是寫日志和執(zhí)行操作的地方,在文本框中鍵入日志然后點(diǎn)擊 “提交” 就和執(zhí)行 git commit 的效果差不多。如果你想要修訂上一次提交, 可以選中“修訂” 按鈕,上次一提交的內(nèi)容就會(huì)顯示在 “暫存區(qū)”。 然后你就可以簡(jiǎn)單的對(duì)修改進(jìn)行暫存和取消暫存操作,更新提交日志,然后再次點(diǎn)擊 “提交” 用這個(gè)新的提交來覆蓋上一次提交。
gitk 和 git-gui 就是針對(duì)某種任務(wù)設(shè)計(jì)的工具的兩個(gè)例子,它們分別為了不同的目的(即查看歷史和制作提交)而進(jìn)行了精簡(jiǎn),略去了用不到的功能。
Mac 和 Windows 上的 GitHub 客戶端
GitHub 發(fā)布了兩個(gè)面向工作流程的 Git 客戶端:Windows 版,和 Mac 版。 它們很好的展示了一個(gè)面向工作流程的工具應(yīng)該是什么樣子——專注于提升那些常用的功能及其協(xié)作的可用性,而不是實(shí)現(xiàn) Git 的所有功能,它們看起來長(zhǎng)這個(gè)樣子:
GitHub Mac 客戶端
GitHub Windows 客戶端
我們?cè)谠O(shè)計(jì)的時(shí)候就努力將二者的外觀和操作體驗(yàn)都保持一致,因此本章會(huì)把他們當(dāng)做同一個(gè)產(chǎn)品來介紹。 我們并不會(huì)詳細(xì)地介紹該工具的每一個(gè)功能(因?yàn)樗鼈儽旧硪灿形臋n),但請(qǐng)快速了解一下 “變更” 窗口(你大部分時(shí)間都會(huì)花在使用該窗口上)的以下幾點(diǎn):
- 左側(cè)是正在追蹤的倉庫的列表;通過點(diǎn)擊左上方的 “+” 圖標(biāo),你可以添加一個(gè)需要追蹤的倉庫(既可以是通過 clone,也可以從本地添加)。
- 中間是輸入-提交區(qū),你可以在這里輸入提交日志,以及選擇哪些文件需要被提交。(在 Windows 上,提交歷史就顯示在這個(gè)區(qū)域的下方;在 Mac 上,提交歷史有一個(gè)單獨(dú)的窗口)
- 右側(cè)是修改查看區(qū),它會(huì)告訴你工作目錄里哪些東西被修改了(譯注:修改模式),或選中的提交里包括了哪些修改(譯注:歷史模式)。
- ***需要熟悉的是右上角的 “Sync” 按鈕,你主要通過這個(gè)按鈕來進(jìn)行網(wǎng)絡(luò)上的交互。
NOTE:你不需要注冊(cè) GitHub 賬號(hào)也可以使用這些工具。 盡管它們是按照 GitHub 推薦的工作流程來設(shè)計(jì)的,并突出提升了一些 GitHub 的服務(wù)體驗(yàn),但它們可以在任何 Git 倉庫上工作良好,也可以通過網(wǎng)絡(luò)連接到任意 Git 主機(jī)。
安裝
GitHub 的 Windows 客戶端可以從 https://windows.github.com 下載,Mac 客戶端可以從 https://mac.github.com 下載。 ***次打開軟件時(shí),它會(huì)引導(dǎo)你進(jìn)行一系列的***使用設(shè)置,例如設(shè)置你的姓名和電子郵件,它還會(huì)智能地幫你調(diào)整一些常用的默認(rèn)設(shè)置,例如憑證緩存和 CRLF 的處理方式。
它們都是“綠色軟件”——如果軟件打開發(fā)現(xiàn)有更新,下載和安裝升級(jí)包都是在后臺(tái)完成的,為方便起見它們還打包了一份 Git,也就是說你一旦安裝好就再也無需勞心升級(jí)的事情了。 Windows 的客戶端還提供了快捷方式,可以啟動(dòng)裝了 Posh-git 插件的 Powershell,在本章的后面一節(jié)我們會(huì)詳細(xì)介紹這方面的內(nèi)容。
接下來我們給它設(shè)置一些工作倉庫。 客戶端會(huì)顯示你在 GitHub 上有權(quán)限操作的倉庫的列表,你可以選擇一個(gè)然后一鍵克隆。 如果你本地已經(jīng)建立了倉庫,只需要用鼠標(biāo)把它從 Finder 或 Windows 資源管理器拖進(jìn) GitHub 客戶端窗口,就可以把該倉庫添加到左側(cè)的倉庫列表里面去了。
推薦的工作流程
安裝并配置好以后,你就可以使用 GitHub 客戶端來執(zhí)行一些常見的 Git 任務(wù)。 該工具所推薦的工作流程有時(shí)也被叫做 “GitHub 流”。 我們?cè)? GitHub 流程 一節(jié)中對(duì)此有詳細(xì)的介紹,其要點(diǎn)是 (a) 你會(huì)提交到一個(gè)分支;(b) 你需要經(jīng)常與遠(yuǎn)程倉庫保持同步。
兩個(gè)平臺(tái)上的客戶端在分支管理上有所不同。 在 Mac 上,創(chuàng)建分支的按鈕在窗口的上方:
Figure 1-5. Mac 上的“創(chuàng)建分支”按鈕。
在 Windows 上,你可以通過在分支切換掛件中輸入新分支的名稱來完成創(chuàng)建:
在 Windows 上創(chuàng)建分支
分支創(chuàng)建好以后,新建提交就變得非常簡(jiǎn)單直接了。 現(xiàn)在工作目錄中做一些修改,然后切換到 GitHub 客戶端窗口,你所做的修改就會(huì)顯示在那里。 輸入提交日志,選中那些需要被包含在本次提交中的文件,然后點(diǎn)擊 “提交” 按鈕(也可以在鍵盤上按 ctrl-enter 或 ⌘-enter)。
“同步” 功能是你在網(wǎng)絡(luò)上和其它倉庫交互的主要途徑。 push,fetch,merge,和 rebase 在 Git 內(nèi)部是一連串獨(dú)立的操作, 而 GitHub 客戶端將這些操作都合并成了單獨(dú)一個(gè)功能。 你點(diǎn)擊同步按鈕時(shí)實(shí)際上會(huì)發(fā)生如下這些操作:
- git pull --rebase。 如果上述命令由于存在合并沖突而失敗,則會(huì)退而執(zhí)行 git pull --no-rebase。
- git push。
如果你遵循推薦的工作流程,以上就是最常用的一系列命令,因此將它們合并為一個(gè)讓事情簡(jiǎn)單了很多。
小結(jié)
這些工具是為其各自針對(duì)的工作流程所量身定做的,開發(fā)者和非開發(fā)者可以輕松地在分分鐘內(nèi)就搭建起項(xiàng)目協(xié)作環(huán)境,它們還內(nèi)置了其它輔助***實(shí)踐的功能。但是,如果你的工作流程有所不同,或者你需要在進(jìn)行網(wǎng)絡(luò)操作時(shí)有更多的控制,那么建議你考慮一下其它客戶端或者使用命令行。
其它圖形界面
除此之外,還有許許多多其它的圖形化 Git 客戶端,其中既有單一功能的定制工具,也有試圖提供 Git 所有功能的復(fù)雜應(yīng)用。 Git 的官方網(wǎng)站整理了一份時(shí)下***的客戶端的清單 http://git-scm.com/downloads/guis。 在 Git 的維基站點(diǎn)還可以看到一份更全的清單 https://git.wiki.kernel.org/index.php/Interfaces,_frontends,_and_tools#Graphical_Interfaces。