Menyinkronkan garpu
Pengaturan
Sebelum Anda bisa menyinkronkan, Anda perlu menambahkan remote yang menunjuk ke repositori hulu. Anda mungkin telah melakukan ini ketika Anda awalnya bercabang.
Tip: Menyinkronkan garpu Anda hanya akan memperbarui salinan lokal repositori Anda; itu tidak memperbarui repositori Anda di GitHub.
$ git remote -v
# List the current remotes
origin https://github.com/user/repo.git (fetch)
origin https://github.com/user/repo.git (push)
$ git remote add upstream https://github.com/otheruser/repo.git
# Set a new remote
$ git remote -v
# Verify new remote
origin https://github.com/user/repo.git (fetch)
origin https://github.com/user/repo.git (push)
upstream https://github.com/otheruser/repo.git (fetch)
upstream https://github.com/otheruser/repo.git (push)
Sinkronisasi
Ada dua langkah yang diperlukan untuk menyinkronkan repositori Anda dengan upstream: pertama Anda harus mengambil dari jarak jauh, kemudian Anda harus menggabungkan cabang yang diinginkan ke cabang lokal Anda.
Mengambil
Mengambil dari repositori jarak jauh akan membawa cabang dan komitmen masing-masing. Ini disimpan di repositori lokal Anda di bawah cabang khusus.
$ git fetch upstream
# Grab the upstream remote's branches
remote: Counting objects: 75, done.
remote: Compressing objects: 100% (53/53), done.
remote: Total 62 (delta 27), reused 44 (delta 9)
Unpacking objects: 100% (62/62), done.
From https://github.com/otheruser/repo
* [new branch] master -> upstream/master
Kami sekarang memiliki cabang master hulu yang disimpan di cabang lokal, hulu / master
$ git branch -va
# List all local and remote-tracking branches
* master a422352 My local commit
remotes/origin/HEAD -> origin/master
remotes/origin/master a422352 My local commit
remotes/upstream/master 5fdff0f Some upstream commit
Penggabungan
Sekarang kami telah mengambil repositori hulu, kami ingin menggabungkan perubahannya ke cabang lokal kami. Ini akan membuat cabang itu sinkron dengan hulu, tanpa kehilangan perubahan lokal kami.
$ git checkout master
# Check out our local master branch
Switched to branch 'master'
$ git merge upstream/master
# Merge upstream's master into our own
Updating a422352..5fdff0f
Fast-forward
README | 9 -------
README.md | 7 ++++++
2 files changed, 7 insertions(+), 9 deletions(-)
delete mode 100644 README
create mode 100644 README.md
Jika cabang lokal Anda tidak memiliki komitmen unik, git akan melakukan "fast-forward":
$ git merge upstream/master
Updating 34e91da..16c56ad
Fast-forward
README.md | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
Tip: Jika Anda ingin memperbarui repositori di GitHub, ikuti instruksi di sini