成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Git Rebase教程: 用Git Rebase讓時光倒流

運維 系統(tǒng)運維 開源
本文作者 Christoph Burgdorf自10歲時就是一名程序員,他是HannoverJS Meetup網(wǎng)站的創(chuàng)始人,并且一直活躍在AngularJS社區(qū)。他也是非常了解gti的內(nèi)內(nèi)外外,在那里他舉辦一個thoughtram的工作室來幫助初學者掌握該技術(shù)。

想象一下你正在開發(fā)一個激進的新功能。這將是很燦爛的但它需要一段時間。您這幾天也許是幾個星期一直在做這個。

[[122011]]

你的功能分支已經(jīng)超前master有6個提交了。你是一個優(yōu)秀的開發(fā)人員并做了有意義的語義提交。但有一件事情:你開始慢慢意識到,這個瘋狂的東西仍需要更多的時間才能真的做好準備被合并回主分支。

  1. m1-m2-m3-m4 (master)
  2. \
  3. f1-f2-f3-f4-f5-f6(feature)

你也知道的是,一些地方實際上是交叉不大的新功能。它們可以更早地合并到主分支。不幸的是,你想將部分合并到主分支的內(nèi)容存在于你六個提交中的某個 地方。更糟糕的是,它也包含了依賴于你的功能分支的之前的提交。有人可能會說,你應(yīng)該在***處地方做兩次提交,但沒有人是***的。

  1. m1-m2-m3-m4 (master)
  2. \
  3. f1-f2-f3-f4-f5-f6(feature)
  4. ^
  5. |
  6. mixed commit

在你準備提交的時間,你沒有預見到,你可能要逐步把該功能合并入主分支。哎呀!你不會想到這件事會有這么久。

你需要的是一種方法可以回溯歷史,把它并分成兩次提交,這樣就可以把代碼都安全地分離出來,并可以移植到master分支。

用圖說話,就是我們需要這樣。

  1. m1-m2-m3-m4 (master)
  2. \
  3. f1-f2-f3a-f3b-f4-f5-f6(feature)

在將工作分成兩個提交后,我們就可以cherry-pick出前面的部分到主分支了。

原來Git自帶了一個功能強大的命令git rebase -i ,它可以讓我們這樣做。它可以讓我們改變歷史。改變歷史可能會產(chǎn)生問題,作為一個經(jīng)驗,應(yīng)盡快避免歷史與他人共享。不過在我們的例子中,我們只是改變我們 的本地功能分支的歷史。沒有人會受到傷害。就這么做了!

好吧,讓我們來仔細看看f3提交究竟修改了什么。原來我們共修改了兩個文件:userService.js和 wishlistService.js。比方說,userService.js的更改可以直接合入主分支而wishlistService.js不能。因 為wishlistService.js甚至不存在在主分支里面。它是f1提交中引入的。

專家提示:即使是在一個文件中更改,git也可以搞定。但這篇博客中我們先簡化情況。

我們已經(jīng)建立了一個公眾演示倉庫,我們將使用這個來練習。為了便于跟蹤,每一個提交信息的前綴是在上面的圖表中使用的假的SHA。以下是git在分開提交f3時的分支圖。

現(xiàn)在,我們要做的***件事就是使用git的checkout功能checkout出我們的功能分支。用git rebase -i master開始做rebase。

現(xiàn)在接下來git會用所配置的編輯器打開(默認為Vim)一個臨時文件。

該文件為您提供一些rebase選擇,它帶有一個提示(藍色文字)。對于每一個提交,我們可以選擇的動作有pick、rwork、edit、 squash、fixup和exec。每一個動作也可以通過它的縮寫形式p、r、e、s、f和e引用。描述每一個選項超出了本文范疇,所以讓我們專注于我 們的具體任務(wù)。

我們要為f3提交選擇edit選項,因此我們把內(nèi)容改變成這樣。

現(xiàn)在我們保存文件(在Vim中是按下后輸入:wq,***是按下回車)。接下來我們注意到git在編輯選項中選擇的提交處停止了rebase。

這意味這git開始將f1、f2、f3生效仿佛它就是常規(guī)的rebase,但是在f3生效之后停止。事實上,我們可以看一眼停止的地方的日志就可以證明這一點。

要將f3分成兩個提交,我們所要做的是重置git的指針到先前的提交(f2)而保持工作目錄和現(xiàn)在一樣。這就是git reset在混合模式在做的。由于混合模式是git reset的默認模式,我們可以直接用git reset head~1。就這么做并在運行后用git status看下發(fā)生了什么。

git status告訴我們userService.js和wishlistService.js被修改了。如果我們運行 git diff 我們就可以看見在f3里面確切地做了哪些更改。

如果我們看一眼日志我們會發(fā)現(xiàn)f3已經(jīng)消失了。

現(xiàn)在我們有了準備提交的先前的f3提交,而原先的f3提交已經(jīng)消失了。記住雖然我們?nèi)耘f在rebase的中間過程。我們的f4、f5、f6提交還沒有缺失,它們會在接下來回來。

讓我們創(chuàng)建兩個新的提交:首先讓我們?yōu)榭梢蕴峤坏街鞣种У膗serService.js創(chuàng)建一個提交。運行g(shù)it add userService.js 接著運行 git commit -m "f3a: add updateUser method"。

太棒了!讓我們?yōu)閣ishlistService.js的改變創(chuàng)建另外一個提交。運行g(shù)it add wishlistService.js,接著運行g(shù)it commit -m "f3b: add addItems method".

讓我們在看一眼日志。

這就是我們想要的,除了f4、f5、f6仍舊缺失。這是因為我們?nèi)栽趓ebase交互的中間,我們需要告訴git繼續(xù)rebase。用下面的命令繼續(xù):git rebase --continue。

讓我們再次檢查一下日志。

就是這樣。我們現(xiàn)在已經(jīng)得到我們想要的歷史了。先前的f3提交現(xiàn)在已經(jīng)被分割成兩個提交f3a和f3b。剩下的***一件事是cherry-pick出f3a提交到主分支上。

為了完成***一步,我們首先切換到主分支。我們用git checkout master。現(xiàn)在我們就可以用cherry-pick命令來拾取f3a commit了。本例中我們可以用它的SHA值bd47ee1來引用它。

現(xiàn)在f3a這個提交就在主分支的最上面了。這就是我們需要的!

這篇文章的長度看起來需要花費很大的功夫,但實際上對于一個git高級用戶而言這只是一會會。

注:Christoph目前正在與Pascal Precht寫一本關(guān)于Git rebase的書,您可以在leanpub訂閱它并在準備出版時獲得通知。

[[122012]]

本文作者 Christoph Burgdorf自10歲時就是一名程序員,他是HannoverJS Meetup網(wǎng)站的創(chuàng)始人,并且一直活躍在AngularJS社區(qū)。他也是非常了解gti的內(nèi)內(nèi)外外,在那里他舉辦一個thoughtram的工作室來幫助初學者掌握該技術(shù)。

本的教程最初發(fā)表在他的blog


via: https://www.codementor.io/git-tutorial/git-rebase-split-old-commit-master

作者:cburgdorf 譯者:geekpi 校對:wxy

本文由 LCTT 原創(chuàng)翻譯,Linux中國 榮譽推出

責任編輯:林師授 來源: Linux中國
相關(guān)推薦

2024-07-22 14:14:01

2024-06-03 00:01:00

2024-06-28 10:25:18

2023-07-26 00:46:25

GitMain主分支

2021-01-04 13:25:10

Git開源工具

2017-11-08 17:16:50

和力記易災(zāi)備

2021-08-17 07:15:16

Git RebaseGit Merge面試

2024-07-05 15:26:59

代碼Merge分支

2024-10-14 08:35:29

2024-02-26 08:00:00

MergeRebase開發(fā)

2020-10-15 06:32:46

Git 變基GIT

2015-10-12 09:34:29

git教程

2019-12-09 14:50:44

LinuxWindow Make桌面

2021-10-25 10:02:50

芯片半導體技術(shù)

2023-12-01 15:54:44

2015-08-20 10:42:17

2021-08-04 10:36:34

git項目開發(fā)

2019-12-06 11:14:57

Git開發(fā)系統(tǒng)

2021-01-04 13:40:59

Git開源工具

2021-02-08 12:59:12

Git 控制系統(tǒng)
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 精品自拍视频在线观看 | 麻豆视频国产在线观看 | 欧美午夜剧场 | 国产精品成人一区二区三区 | 5060网一级毛片 | 久久人人爽人人爽人人片av免费 | 国产一区二区三区四区三区四 | 精品一区精品二区 | 亚洲综合在线视频 | 99精品国产一区二区三区 | 欧美1区2区 | 日韩欧美亚洲 | 免费在线观看一区二区 | 在线国产视频 | 国产一区二区影院 | 精品一区二区三区四区外站 | 亚洲欧美视频一区 | 在线日韩精品视频 | 91成人在线视频 | 成人免费视频观看 | 欧美视频中文字幕 | 日本一区二区不卡视频 | 日韩精品一区二 | 亚洲精品久久久一区二区三区 | 亚洲成人久久久 | 在线看中文字幕 | 精品久久久久久亚洲国产800 | 亚洲国产精品久久久 | 91精品国产91久久久久游泳池 | 日韩一级电影免费观看 | 欧美视频二区 | 成人在线播放网址 | 欧美日韩国产在线 | 天天射影院| 久久专区| 免费在线观看av | 色屁屁在线观看 | 亚洲免费视频在线观看 | 97色在线视频 | 亚洲高清成人在线 | 国内自拍真实伦在线观看 |