เริ่มต้นด้วย repo ในสถานะเดิม
data:image/s3,"s3://crabby-images/ed493/ed49327ea98844b173422697bb3941d00e534b99" alt="ประวัติ repo ดั้งเดิม"
ในการลบคอมมิตการผสานและสควอชสาขาเป็นคอมมิตเดียวในเมนไลน์
data:image/s3,"s3://crabby-images/4c6e9/4c6e90363922975262e2c680b22cab00a12f5163" alt="บีบคอมมิตไม่มีการรวมคอมมิต"
ใช้คำสั่งเหล่านี้ (แทนที่ 5 และ 1 ด้วย SHAs ของคอมมิตที่เกี่ยวข้อง):
git checkout 5
git reset --soft 1
git commit --amend -m '1 2 3 4 5'
git rebase HEAD master
หากต้องการรักษาการผสานรวม แต่สควอชสาขาจะรวมเป็นหนึ่ง:
data:image/s3,"s3://crabby-images/ce74a/ce74a7ffe0119183415dd594d632d1b12d4c2679" alt="Squashed กระทำการรวมการกระทำที่ยังคงอยู่"
ใช้คำสั่งเหล่านี้ (แทนที่ 5, 1 และ C ด้วย SHAs ของคอมมิตที่เกี่ยวข้อง):
git checkout -b tempbranch 5
git reset --soft 1
git commit --amend -m '1 2 3 4 5'
git checkout C
git merge --no-ff tempbranch
git rebase HEAD master
ในการลบคอมมิตการผสานและแทนที่ด้วยคอมมิตแต่ละรายการจากสาขา
data:image/s3,"s3://crabby-images/a9531/a9531d7e7e18591ce2fe695705be3c6666055b32" alt="ย้ายสาขาเข้าสู่เมนไลน์ไม่มีการรวมคอมมิต"
เพียงแค่ทำ (แทนที่ 5 ด้วย SHA ของคอมมิตที่เกี่ยวข้อง):
git rebase 5 master
และสุดท้ายเพื่อลบสาขาทั้งหมด
data:image/s3,"s3://crabby-images/31173/3117307320dc7091f9b9155670fc90a0e31d06af" alt="ลบสาขาทั้งหมด"
ใช้คำสั่งนี้ (แทนที่ C และ D ด้วย SHAs ของคอมมิตที่เกี่ยวข้อง):
git rebase --onto C D~ master