分布式版本控制軟件水銀(Mercurial)使用指南4

merging

翻譯自:http://hginit.com/04.html

有時(shí)合并導(dǎo)致沖突舷蒲。通常它們很容易解決,但你需要解決它們否則你的倉庫將會(huì)有多個(gè)頭。誰又想要多個(gè)頭呢惨恭?

版本控制一個(gè)非常重要的組成部分是在同一個(gè)代碼庫中進(jìn)行多人協(xié)同工作。

想象一下Rose和我都想對果醬食譜進(jìn)行修改耙旦。Rose提高了牛油果的品質(zhì)脱羡。在她開始工作前,她將從中央倉庫拉取所有的最新變動(dòng)免都,以便自己在最新版本上工作锉罐。


現(xiàn)在看下編輯情況:


她提交并且推送這一變化到中央倉庫:


同時(shí),我在這一文件的不同的地方做了一些更改:


我能夠提交绕娘,但是我不能夠推送到中央倉庫脓规。


這也許是在水銀中最沒有用的錯(cuò)誤信息,它應(yīng)該這樣說:


事實(shí)险领,那正是我將要做的:


好奇剛剛來了什么侨舆?輸入** hg log -P**。這一命令可以幫助你方便地查看绢陌。


事實(shí)上挨下,那是Rose較早的改動(dòng),我的倉庫現(xiàn)在該怎么辦呢脐湾?


我有“多個(gè)頭”臭笆。本質(zhì)上,我的倉庫看起來如下:


看到兩個(gè)頭了嗎沥割?這是因?yàn)镽ose的改動(dòng)是基于變更集7的耗啦,而我的改動(dòng)也是基于變更集7的。所以現(xiàn)在有必要進(jìn)行合并机杜。(千萬不要忽略它)


合并命令帜讲,hg merge,合并兩個(gè)頭椒拗,并將結(jié)果保存在我的工作目錄似将,它沒有提交,這給了一個(gè)機(jī)會(huì)讓我來檢查合并是否正確:


這看起來是對的蚀苛,鱷梨是Hass在验,辣椒是胡椒,所以我將繼續(xù)下一步堵未,將其推送到服務(wù)器腋舌。


我推送了兩個(gè)變更集:我原來的墨西哥胡椒變更,和之后的合并渗蟹,這是它自己的變更集块饺。

注意我倆各自的變更之間沒有沖突赞辩。因?yàn)槲液蚏ose在修改配方的不同部分。所以合并非常容易授艰。這是最常見的情況辨嗽,因?yàn)樵诖蠖鄶?shù)組織中,每個(gè)程序員被分配在不同的代碼段進(jìn)行工作淮腾。

但是糟需,即便是管理再好的、健康的組織谷朝,合并沖突時(shí)有發(fā)生洲押,這時(shí)水銀會(huì)要求人為地來解決這些沖突。讓我們看看那是什么樣子的徘禁。

首先......我想要讓Rose的把我的變更集給拉下來:


現(xiàn)在诅诱,我們來看下將要發(fā)生什么髓堪,當(dāng)有一些沖突送朱,我們都要修改一下配料。

我添加了一個(gè)香蕉:


我先檢查下香蕉的變化:


而Rose干旁,在完全相同的一行添加了一個(gè)芒果驶沼。


確切地說是“ripe young mango”。


這次我先上傳了我的變更争群,所以Rose必須進(jìn)行合并回怜。哈!


忽然换薄,沖突被檢測到玉雾,并彈出一些合并沖突的解決工具,是不太友好的界面轻要,但是他們通常是非好好用的复旬,你能想到的功能都有。一個(gè)常見的合并沖突解決工具是 KDiff3, 如下:


在KDiff3中冲泥,你能看到4塊窗口驹碍,左上角是原始文件,上面中間部分顯示Rose的版本凡恍,右上方顯示我的版本志秃。下面的窗口中是一個(gè)編輯器,Rose在這里解決沖突并構(gòu)建出合并的文件嚼酝。

修改沖突是一個(gè)相對簡單的問題浮还,要做的是遍歷每一個(gè)沖突并且做一個(gè)選擇題。Rose決定用香蕉芒果醬闽巩。


Rose保存了她的改動(dòng)并且退出了KDiff3钧舌。


沖突解決了流码。

有一件事你要牢記:你不必按照任何人的時(shí)刻表去合并。你在任何時(shí)候都可以使用hg pull延刘,如果你不想要合并沖突漫试,你完全可以繼續(xù)工作,然后愉快地提交碘赖。等到你什么時(shí)候想合并了驾荣,你再合并。

自測

以下是你讀完本篇教程應(yīng)當(dāng)會(huì)做的事:

  1. 與他人在相同的代碼塊上工作普泡。
  2. 獲得他人的變更播掷。
  3. 推送你自己的變更。
  4. 解決合并沖突撼班。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末歧匈,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子砰嘁,更是在濱河造成了極大的恐慌件炉,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件矮湘,死亡現(xiàn)場離奇詭異斟冕,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)缅阳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進(jìn)店門磕蛇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人十办,你說我怎么就攤上這事秀撇。” “怎么了向族?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵呵燕,是天一觀的道長。 經(jīng)常有香客問我炸枣,道長虏等,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任适肠,我火速辦了婚禮霍衫,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘侯养。我一直安慰自己敦跌,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著柠傍,像睡著了一般麸俘。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上惧笛,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天从媚,我揣著相機(jī)與錄音,去河邊找鬼患整。 笑死拜效,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的各谚。 我是一名探鬼主播紧憾,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼昌渤!你這毒婦竟也來了赴穗?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤膀息,失蹤者是張志新(化名)和其女友劉穎般眉,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體履婉,經(jīng)...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡煤篙,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年斟览,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了毁腿。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,115評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡苛茂,死狀恐怖已烤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情妓羊,我是刑警寧澤胯究,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站躁绸,受9級特大地震影響裕循,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜净刮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一剥哑、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧淹父,春花似錦株婴、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽大审。三九已至,卻和暖如春座哩,著一層夾襖步出監(jiān)牢的瞬間徒扶,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工根穷, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留酷愧,地道東北人瓷们。 一個(gè)月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓盐须,卻偏偏與公主長得像枣抱,于是被迫代替她去往敵國和親播赁。 傳聞我的和親對象是個(gè)殘疾皇子彤叉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評論 2 355

推薦閱讀更多精彩內(nèi)容