Tiek merge, tiek rebase integruoja pakeitimus iš vienos šakos į kitą, bet jie tai daro skirtingai: merge išsaugo istoriją su merge commit, o rebase perrašo istoriją, kad būtų sukurta tiesinė seka. Svarbu suprasti skirtumą ir kada naudoti kiekvieną.
Merge — išsaugo istoriją (sujungia)
main: A───B───C───────M ← M is a MERGE COMMIT (two parents)
\ /
feature: D───E
→ git merge feature: creates M combining the branches
✓ Preserves the actual history (shows the branch existed, when it merged)
✗ History has merge commits (can look cluttered with many merges)
