Skip to content

Instantly share code, notes, and snippets.

@HakaCode
Forked from rdeavila/git-update-fork.sh
Created August 2, 2020 19:03
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save HakaCode/23b85966e1d2f0d26ccb94b87e2c5850 to your computer and use it in GitHub Desktop.
Save HakaCode/23b85966e1d2f0d26ccb94b87e2c5850 to your computer and use it in GitHub Desktop.
Git: como atualizar um fork com as mudanças do original?
#!/bin/bash
# Adicione um novo remote; pode chamá-lo de "upstream":
git remote add upstream https://github.com/usuario/projeto.git
# Obtenha todos os branches deste novo remote,
# como o upstream/master por exemplo:
git fetch upstream
# Certifique-se de que você está no branch master:
git checkout master
# Reescreva o seu branch master, de forma que os seus commits
# que não estão no projeto original apareçam, e que os seus
# commits fiquem no topo da lista:
git rebase upstream/master
# Se você não quiser reescrever o histórico do seu branch master
# (talvez porque alguém já o tenha clonado) então você deve
# substituir o último comando por um
git merge upstream/master
# No entanto, para fazer com que futuros pull requests fiquem o mais
# limpos possível, é uma boa ideia fazer o rebase.
# Se você fez o rebase do seu branch a partir de upstream/master, talvez
# você precise forçar um push para o seu próprio repositório do Github.
# Você pode fazer isso com:
git push -f origin master
# VocÊ vai precisar fazer isso com o -f apenas na primeira vez que você
# faz um rebase.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment