Tworzę nowy oddział w Git:
git branch my_branch
Popchnij:
git push origin my_branch
Teraz powiedz, że ktoś dokonał pewnych zmian na serwerze, a ja chcę z niego skorzystać origin/my_branch
. Ja robię:
git pull
Ale dostaję:
You asked me to pull without telling me which branch you
want to merge with, and 'branch.my_branch.merge' in
your configuration file does not tell me, either. Please
specify which branch you want to use on the command line and
try again (e.g. 'git pull <repository> <refspec>').
See git-pull(1) for details.
If you often merge with the same branch, you may want to
use something like the following in your configuration file:
[branch "my_branch"]
remote = <nickname>
merge = <remote-ref>
[remote "<nickname>"]
url = <url>
fetch = <refspec>
See git-config(1) for details.
Nauczyłem się, że mogę sprawić, by działał z:
git branch --set-upstream my_branch origin/my_branch
Ale dlaczego muszę to robić dla każdej tworzonej gałęzi? Czy to nie jest oczywiste, że jeśli pcham my_branch
się origin/my_branch
, a potem chciałbym ciągnąć origin/my_branch
się my_branch
? Jak mogę ustawić to jako domyślne zachowanie?
--set-upstream
opcja jest przestarzała. Powinieneś użyć --track
lub --set-upstream-to
zamiast tego.
--set-upstream
jest przestarzałe, to być może deweloperzy git powinni usunąć go z komunikatu pomocy, który wyświetla się, gdy uruchamiasz git push
się bez opcji i nie jest ustawiony żaden upstream?
git branch --set-upstream
jest przestarzały. git push --set-upstream
nie jest.
branch.autosetupmerge
oznacza, że konfiguracja początkowa dla nowej gałęzi jest ustawiana automatycznie tylko podczas tworzenia gałęzi ze zdalnej gałęzi śledzenia (np.<remote-name>/<branch-name>
) (Patrz git-config (1) ). Prawdopodobnie tworzysz swoje oddziały z istniejących oddziałów lokalnych. Jeśli skutecznie rozgałęziasz się bezpośrednio z wierzchołka gałęzi zdalnej (pomimo tego, że jesteś w gałęzi lokalnej), możesz użyćgit branch my_branch <remote-name>/<branch-name>
do automatycznego skonfigurowania konfiguracji nadrzędnej.