Sincronizando un tenedor
La puesta en marcha
Antes de poder sincronizar, debe agregar un control remoto que apunte al repositorio ascendente. Es posible que haya hecho esto cuando originalmente se bifurcó.
Sugerencia: la sincronización de su bifurcación solo actualiza su copia local del repositorio; no actualiza su repositorio en 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)
Sincronización
Hay dos pasos necesarios para sincronizar su repositorio con el flujo ascendente: primero debe buscar desde el control remoto, luego debe fusionar la rama deseada en su rama local.
Atractivo
La recuperación desde el repositorio remoto traerá sus ramas y sus respectivas confirmaciones. Estos se almacenan en su repositorio local bajo ramas especiales.
$ 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
Ahora tenemos la rama maestra del flujo ascendente almacenada en una rama local, flujo ascendente / maestro
$ 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
Fusionando
Ahora que hemos obtenido el repositorio ascendente, queremos fusionar sus cambios en nuestra rama local. Esto sincronizará esa rama con el flujo ascendente, sin perder nuestros cambios locales.
$ 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
Si su sucursal local no tenía ninguna confirmación única, git realizará un "avance rápido":
$ git merge upstream/master
Updating 34e91da..16c56ad
Fast-forward
README.md | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
Sugerencia: si desea actualizar su repositorio en GitHub, siga las instrucciones aquí