Differences
This shows you the differences between two versions of the page.
| Both sides previous revision Previous revision Next revision | Previous revision | ||
| git_rebase [2019/03/06 15:45] – [DESCRIPTION] rpjday | git_rebase [2019/04/06 21:34] (current) – [Removing a sequence of commits] rpjday | ||
|---|---|---|---|
| Line 6: | Line 6: | ||
| < | < | ||
| - | git rebase [-i | --interactive] [< | + | $ git rebase [-i | --interactive] [< | 
| - | [< | + |  | 
| - | git rebase [-i | --interactive] [< | + | [< | 
| - | --root [< | + | |
| - | git rebase --continue | --skip | --abort | --quit | --edit-todo | --show-current-patch | + | $ git rebase [-i | --interactive] [< | 
| + |  | ||
| + | --root [< | ||
| + | - | ||
| + | $ git rebase --continue | --skip | --abort | --quit | | ||
| + | --edit-todo | --show-current-patch | ||
| </ | </ | ||
| - | ===== DESCRIPTION | + | ===== The fundamental rebase operation | 
| + | |||
| + | Three components define a rebase: | ||
| + | |||
| + | * the //branch// to be rebased | ||
| + | * the amount of that branch to be rebased | ||
| + | * the target //commit// onto which to rebase | ||
| + | |||
| + | ===== Examples ===== | ||
| + | |||
| + | ==== Simple example | ||
| < | < | ||
| - | If < | + | A---B---C | 
| - | git checkout < | + | / | 
| - | remains on the current branch. | + |  | 
| </ | </ | ||
| - | In other words, the final optional argument '' | + | One of: | 
| < | < | ||
| - | $ git checkout <branch> | + | $ git checkout | 
| + | $ git rebase master | ||
| + | </code> | ||
| + | |||
| + | or: | ||
| + | |||
| + | < | ||
| + | $ git rebase master topic | ||
| + | </ | ||
| + | |||
| + | < | ||
| + | A' | ||
| + | / | ||
| + | D---E---F---G | ||
| + | </ | ||
| + | |||
| + | ==== Example requiring " | ||
| + | |||
| + | < | ||
| + | o---o---o---o---o | ||
| + | \ | ||
| + | o---o---o---o---o | ||
| + | \ | ||
| + | o---o---o | ||
| + | </ | ||
| + | |||
| + | < | ||
| + | $ git rebase --onto master next topic | ||
| + | </ | ||
| + | |||
| + | < | ||
| + | o---o---o | ||
| + | / | ||
| + | o---o---o---o---o | ||
| + | \ | ||
| + | o---o---o---o---o | ||
| </ | </ | ||
| - | then just pretend it says '' | ||
| - | ===== Examples ===== | ||
| ==== Removing a sequence of commits ===== | ==== Removing a sequence of commits ===== | ||
| Line 42: | Line 90: | ||
| < | < | ||
| - | $ git rebase --onto B D | + | $ git rebase --onto B D [HEAD] | 
| </ | </ | ||