天天看點

Git圖形界面的使用

導讀 如果你已經掌握了不少使用 Git 指令行操作的知識。 你學會了操作本地檔案,通過網絡連接配接你的倉庫,以及與他人進行有效率的合作。 但是故事并未就此結束;Git 通常隻是更大的生态圈的一部分,在某些情況下使用終端并不是最合适的方式。 現在就讓我們來了解一下如何在其它類型的環境中更好地使用 Git,以及别的應用(包括你的)如何與 Git 進行協作。
Git圖形界面的使用

圖形界面

Git 的原生環境是終端。 在那裡,你可以體驗到最新的功能,也隻有在那裡,你才能盡情發揮 Git 的全部能力。 但是對于某些任務而言,純文字并不是最佳的選擇;有時候你确實需要一個可視化的展示方式,而且有些使用者更習慣那種能點選的界面。

有一點請注意,不同的界面是為不同的工作流程設計的。 一些用戶端的作者為了支援某種他認為高效的工作流程,經過精心挑選,隻顯示了 Git 功能的一個子集。 每種工具都有其特定的目的和意義,從這個角度來看,不能說某種工具比其它的“更好”。 還有請注意,沒有什麼事情是圖形界面用戶端可以做而指令行用戶端不能做的;指令行始終是你可以完全操控倉庫并發揮出全部力量的地方。

gitk 和 git-gui

在安裝 Git 的同時,你也裝好了它提供的可視化工具,gitk 和 git-gui。

gitk 是一個曆史記錄的圖形化檢視器,你可以把它當作是基于 git log 和 git grep 指令的一個強大的圖形操作界面,當你需要查找過去發生的某次記錄,或是可視化檢視項目曆史的時候,你将會用到這個工具。

使用 Gitk 的最簡單方法就是從指令行打開,隻需 cd 到一個 Git 倉庫,然後鍵入:

$ gitk [git log options]      

Gitk 可以接受很多指令行選項,其中的大部分都直接傳給底層的 git log 去執行了。 –all可能是這其中最有用的一個, 它告訴 gitk 去盡可能地從任何引用查找送出并顯示,而不僅僅是從 HEAD,Gitk 的界面看起來長這樣

Git圖形界面的使用

gitk 曆史檢視器

這張圖看起來就和執行 git log –graph指令的輸出差不多;每個點代表一次送出,線代表父子關系,而彩色的方塊則用來标示一個個引用。 黃點表示 HEAD,紅點表示尚未送出的本地變動。 下方的視窗用來顯示目前選中的送出的具體資訊;評論和更新檔顯示在左側,摘要顯示在右側。 中間則是一組用來搜尋曆史的控件。

與之相比,git-gui 則主要是一個用來制作送出的工具。 打開它的最簡單方法也是從指令行啟動:

$ git gui      

它的界面長這個樣子:

Git圖形界面的使用

git-gui 送出工具

左側是索引區;未暫存的修改顯示在上方,已暫存的修改顯示在下方。你可以通過點選檔案名左側的圖示來将該檔案在暫存狀态與未暫存狀态之間切換,你也可以通過選中一個檔案名來檢視它的詳情。

右側視窗的上方以 diff 格式來顯示目前選中檔案發生了變動的地方,你可以通過右擊某一區塊或行進而将這一區塊或行放入暫存區。

右側視窗的下方是寫日志和執行操作的地方,在文本框中鍵入日志然後點選 “送出” 就和執行 git commit 的效果差不多。如果你想要修訂上一次送出, 可以選中“修訂” 按鈕,上次一送出的内容就會顯示在 “暫存區”。 然後你就可以簡單的對修改進行暫存和取消暫存操作,更新送出日志,然後再次點選 “送出” 用這個新的送出來覆寫上一次送出。

gitk 和 git-gui 就是針對某種任務設計的工具的兩個例子,它們分别為了不同的目的(即檢視曆史和制作送出)而進行了精簡,略去了用不到的功能。

Mac 和 Windows 上的 GitHub 用戶端

GitHub 釋出了兩個面向工作流程的 Git 用戶端:Windows 版,和 Mac 版。 它們很好的展示了一個面向工作流程的工具應該是什麼樣子——專注于提升那些常用的功能及其協作的可用性,而不是實作 Git 的所有功能,它們看起來長這個樣子:

Git圖形界面的使用

GitHub Mac 用戶端

Git圖形界面的使用

GitHub Windows 用戶端

我們在設計的時候就努力将二者的外觀和操作體驗都保持一緻,是以本章會把他們當做同一個産品來介紹。 我們并不會詳細地介紹該工具的每一個功能(因為它們本身也有文檔),但請快速了解一下 “變更” 視窗(你大部分時間都會花在使用該視窗上)的以下幾點:

  • 左側是正在追蹤的倉庫的清單;通過點選左上方的 “+” 圖示,你可以添加一個需要追蹤的倉庫(既可以是通過 clone,也可以從本地添加)。
  • 中間是輸入-送出區,你可以在這裡輸入送出日志,以及選擇哪些檔案需要被送出。(在 Windows 上,送出曆史就顯示在這個區域的下方;在 Mac 上,送出曆史有一個單獨的視窗)
  • 右側是修改檢視區,它會告訴你工作目錄裡哪些東西被修改了(譯注:修改模式),或選中的送出裡包括了哪些修改(譯注:曆史模式)。
  • 最後需要熟悉的是右上角的 “Sync” 按鈕,你主要通過這個按鈕來進行網絡上的互動。

NOTE:你不需要注冊 GitHub 賬号也可以使用這些工具。 盡管它們是按照 GitHub 推薦的工作流程來設計的,并突出提升了一些 GitHub 的服務體驗,但它們可以在任何 Git 倉庫上工作良好,也可以通過網絡連接配接到任意 Git 主機。

安裝

GitHub 的 Windows 用戶端可以從 https://windows.github.com 下載下傳,Mac 用戶端可以從 https://mac.github.com 下載下傳。 第一次打開軟體時,它會引導你進行一系列的首次使用設定,例如設定你的姓名和電子郵件,它還會智能地幫你調整一些常用的預設設定,例如憑證緩存和 CRLF 的處理方式。

它們都是“綠色軟體”——如果軟體打開發現有更新,下載下傳和安裝更新包都是在背景完成的,為友善起見它們還打包了一份 Git,也就是說你一旦安裝好就再也無需勞心更新的事情了。 Windows 的用戶端還提供了快捷方式,可以啟動裝了 Posh-git 插件的 Powershell,在本章的後面一節我們會詳細介紹這方面的内容。

接下來我們給它設定一些工作倉庫。 用戶端會顯示你在 GitHub 上有權限操作的倉庫的清單,你可以選擇一個然後一鍵克隆。 如果你本地已經建立了倉庫,隻需要用滑鼠把它從 Finder 或 Windows 資料總管拖進 GitHub 用戶端視窗,就可以把該倉庫添加到左側的倉庫清單裡面去了。

推薦的工作流程

安裝并配置好以後,你就可以使用 GitHub 用戶端來執行一些常見的 Git 任務。 該工具所推薦的工作流程有時也被叫做 “GitHub 流”。 我們在 GitHub 流程 一節中對此有詳細的介紹,其要點是 (a) 你會送出到一個分支;(b) 你需要經常與遠端倉庫保持同步。

兩個平台上的用戶端在分支管理上有所不同。 在 Mac 上,建立分支的按鈕在視窗的上方:

Git圖形界面的使用

Mac 上的“建立分支”按鈕

在 Windows 上,你可以通過在分支切換挂件中輸入新分支的名稱來完成建立:

Git圖形界面的使用

在 Windows 上建立分支

分支建立好以後,建立送出就變得非常簡單直接了。 現在工作目錄中做一些修改,然後切換到 GitHub 用戶端視窗,你所做的修改就會顯示在那裡。 輸入送出日志,選中那些需要被包含在本次送出中的檔案,然後點選 “送出” 按鈕(也可以在鍵盤上按 ctrl-enter 或 ⌘-enter)。

“同步” 功能是你在網絡上和其它倉庫互動的主要途徑。 push,fetch,merge,和 rebase 在 Git 内部是一連串獨立的操作, 而 GitHub 用戶端将這些操作都合并成了單獨一個功能。 你點選同步按鈕時實際上會發生如下這些操作:

  • git pull –rebase。 如果上述指令由于存在合并沖突而失敗,則會退而執行 git pull –no-rebase。
  • git push。

如果你遵循推薦的工作流程,以上就是最常用的一系列指令,是以将它們合并為一個讓事情簡單了很多。

小結

這些工具是為其各自針對的工作流程所量身定做的,開發者和非開發者可以輕松地在分分鐘内就搭建起項目協作環境,它們還内置了其它輔助最佳實踐的功能。但是,如果你的工作流程有所不同,或者你需要在進行網絡操作時有更多的控制,那麼建議你考慮一下其它用戶端或者使用指令行。

其它圖形界面

除此之外,還有許許多多其它的圖形化 Git 用戶端,其中既有單一功能的定制工具,也有試圖提供 Git 所有功能的複雜應用。 Git 的官方網站整理了一份時下最流行的用戶端的清單 http://git-scm.com/downloads/guis。

在 Git 的維基站點還可以看到一份更全的清單 https://git.wiki.kernel.org/index.php/Interfaces,_frontends,_and_tools#Graphical_Interfaces

Git圖形界面的使用

本文轉載自:http://www.linuxprobe.com/git-view.html

免費提供最新Linux技術教程書籍,為開源技術愛好者努力做得更多更好:http://www.linuxprobe.com/