Jak zmienić nazwę oddziału w Git

Opublikowany: 2022-12-26

Logo Gita na niebieskim tle

Aby zmienić nazwę bieżącej, lokalnej gałęzi, użyj „git branch -m new-name”. Aby zmienić nazwę lokalnego oddziału z poziomu innego, użyj „git branch -m old-name new-name”. Aby zmienić nazwę zdalnej gałęzi, usuń ją za pomocą „git push origin --delete old-name”, a następnie wypchnij lokalną gałąź o zmienionej nazwie za pomocą „git push origin -u new-name”.

Rozgałęzianie to trywialne ćwiczenie w Git. Niestety, trywialnym zadaniom rzadko poświęca się należytą uwagę i zdarzają się pomyłki. Jeśli źle nazwałeś oddział, trzeba będzie zmienić jego nazwę. Oto jak to zrobić.

Spis treści

Dlaczego nazwy oddziałów są ważne w Git
Lista gałęzi w Git przed zmianą ich nazwy
Jak zmienić nazwę lokalnego oddziału w Git
Jak zmienić nazwę oddziału zdalnego w Git
Zmiana nazw oddziałów jest prosta

Dlaczego nazwy oddziałów są ważne w Git

Wszystko, co miało związek z gałęziami w klasycznych systemach kontroli wersji (VCS), było wielką sprawą. Wymagało to skoordynowanego zrozumienia, że ​​gałąź jest dodawana lub scalana, a wszystkie osoby korzystające z tego repozytorium musiały upewnić się, że nic nie zrobiły — lub zapomniały coś zrobić — aby operacja przebiegła pomyślnie.

Operacje z udziałem oddziałów były często bardzo powolne. Za pomocą gałęzi obowiązywała kara czasowa. Git został zaprojektowany od samego początku, aby był inny. Ponieważ jest to rozproszony system kontroli wersji, każdy użytkownik ma kopię pełnego repozytorium na swojej lokalnej maszynie.

Git rebase: wszystko, co musisz wiedzieć
POWIĄZANE Git rebase: wszystko, co musisz wiedzieć

Rozgałęzienie na komputerze lokalnym nie wpływa na nikogo innego, chyba że wypchniesz gałąź do zdalnego repozytorium. A w Git operacje rozgałęzień są zaprojektowane tak, aby były równie łatwe w użyciu, co szybkie w wykonaniu. Rozgałęzianie w Git jest bardzo tanie pod względem obliczeniowym. Jest to trywialna czynność wewnątrz lokalnego repozytorium.

W rzeczywistości programiści są zachęcani do rozgałęziania się i to często. Gałęzie to po prostu kolejne narzędzie w systemie VCS, z którego czerpiesz korzyści. Gałęzie nie są wielkimi przerażającymi rzeczami w Git, są jedną z najczęściej używanych funkcji.

Ale zażyłość może prowadzić do pogardy. Lub przynajmniej do swobodnego szacunku dla gałęzi. Rozgałęzianie może być szybkie i proste w Git, ale nadal musisz być skupiony podczas tworzenia rozgałęzienia. Łatwo jest pomylić nazwę oddziału lub wpisać niewłaściwą nazwę, co skutkuje błędną nazwą oddziału.

Jeśli gałąź ma zostać wypchnięta do zdalnego repozytorium w pewnym momencie, musi być poprawnie napisana. Jeśli tak nie jest, spowoduje to zamieszanie, gdy inni spróbują go użyć.

POWIĄZANE: Jak działają gałęzie Git?

Lista gałęzi w Git przed zmianą ich nazwy

Sprawdzenie, jakie są aktualne nazwy oddziałów, to dobry pierwszy krok. Polecenie git branch wyświetla nam gałęzie. Możesz zobaczyć gałęzie w lokalnym repozytorium za pomocą tego polecenia:

 gałąź git 

Wyświetlanie lokalnych oddziałów za pomocą polecenia git branch

Oddziały są dla nas wymienione. Bieżąca gałąź jest podświetlona na zielono i gwiazdką.

Aby zobaczyć gałęzie i ich zatwierdzenia, możesz użyć polecenia show-branch .

 git show-branch 

Wyświetlanie gałęzi i ich zatwierdzeń za pomocą polecenia git show-branch

Możesz zobaczyć gałęzie w zdalnym repozytorium, włączając opcję -r (remote).

 gałąź git -r 

Wyświetlanie zdalnych gałęzi za pomocą polecenia git branch -r

Aby zobaczyć lokalne i zdalne gałęzie za pomocą jednego polecenia, użyj opcji -a (all).

 gałąź git -a 

Wyświetlanie listy lokalnych i zdalnych gałęzi za pomocą polecenia git branch -a

Mamy więcej oddziałów lokalnych niż oddziałów zdalnych. Gałąź „feature16” nie została jeszcze przekazana do zdalnego repozytorium. To tylko aspekt normalnej pracy, a nie problem.

Nasz problem polega na tym, że gałąź „feature19” powinna mieć nazwę „feature18”. Więc to jest błąd, który naprawimy.

POWIĄZANE: Jak aktualizować i utrzymywać oddzielne gałęzie Git

Jak zmienić nazwę lokalnego oddziału w Git

Istnieją dwa sposoby lokalnej zmiany nazwy oddziału. Możesz wyewidencjonować oddział i zmienić jego nazwę lub możesz zmienić nazwę oddziału podczas pracy w innym oddziale.

Aby zmienić nazwę bieżącego oddziału, upewnij się, że wyrejestrowałeś się i używasz oddziału, którego nazwę chcesz zmienić. Następnie użyj komendy git branch z opcją -m (move).

 funkcja kasy git19
 gałąź git -m funkcja18 

Sprawdzanie gałęzi „feature19” i zmiana jej nazwy

Sprawdziliśmy gałąź „feature19” i zmieniliśmy jej nazwę na „feature18”. Zobaczmy, jak teraz wyglądają nasze gałęzie.

 gałąź git 

Wyświetlanie gałęzi w celu sprawdzenia, czy nazwa gałęzi „feature19” została zmieniona na „feature18”

Nasz oddział ma teraz poprawną nazwę w lokalnym repozytorium.

Jeśli chcesz, możesz zmienić nazwę oddziału podczas pracy w innym oddziale. Oto przykład, w którym pracujemy w gałęzi „master”.

 gałąź git 

Wyświetlanie gałęzi, aby sprawdzić, czy jesteśmy w gałęzi głównej

Polecenie, którego używamy, jest tym samym poleceniem, co poprzednio, ale musimy podać bieżącą nazwę gałęzi, której nazwę zmieniamy, a także nową nazwę, którą chcemy, aby miała.

 git branch -m funkcja19 funkcja18
 gałąź git 

Zmiana nazwy jednej gałęzi z wnętrza innej gałęzi

Ponownie nazwa oddziału w naszym lokalnym repozytorium została zmieniona na poprawną nazwę.

POWIĄZANE: Jak utworzyć nowy oddział w GitHub

Jak zmienić nazwę oddziału zdalnego w Git

Zdalne repozytorium nadal zawiera gałąź ze starą nazwą. Aby zmienić nazwę gałęzi zdalnej, usuwamy starą gałąź i wciskamy nową.

Jeśli inni użytkownicy używają tej gałęzi i wysyłają do niej zatwierdzenia, powinieneś zrobić pull przed lokalną zmianą nazwy. Dzięki temu lokalne repozytorium jest aktualne, a zmiany wprowadzone przez innych użytkowników nie zostaną utracone. Wyciągnięcie ich zmian z powrotem do twojego repozytorium przed lokalną zmianą nazwy gałęzi oznacza, że ​​te zmiany będą w nowej gałęzi, kiedy wypchniesz ją z powrotem do zdalnego repozytorium.

Rzućmy okiem na stan naszych oddziałów. Użyjemy opcji -a (all), aby zobaczyć zarówno lokalną, jak i zdalną gałąź.

 gałąź git -a 

Wyświetlanie listy lokalnych i zdalnych gałęzi za pomocą polecenia git branch -a

Musimy usunąć „feature19” ze zdalnego repozytorium i przesłać „feature18” do pilota.

 git push origin --delete Feature19 

Usuwanie zdalnej gałęzi za pomocą opcji git --delete

Zostaniesz poproszony o podanie hasła do zdalnego repozytorium. Po usunięciu zostanie wyświetlony komunikat z potwierdzeniem.

Teraz wypchniemy naszą nową gałąź do zdalnego i użyjemy opcji -u (ustaw w górę).

 git push origin -u funkcja18 

Wypychanie gałęzi do zdalnego repozytorium

Ponownie zostaniesz poproszony o podanie hasła do pilota. Nowa gałąź jest przesyłana do pilota i powiedziano nam, że gałąź „feature18” jest skonfigurowana do śledzenia zmian w naszej lokalnej kopii gałęzi.

Sprawdźmy jeszcze raz w jakim stanie są nasze oddziały lokalne i zdalne.

 gałąź git -a 

Wyświetlanie listy lokalnych i zdalnych gałęzi za pomocą polecenia git branch -a

Nasz oddział został pomyślnie przemianowany zarówno lokalnie, jak i zdalnie, a zdalny oddział śledzi zmiany w naszym lokalnym oddziale.

POWIĄZANE: Jak usunąć gałęzie Git w lokalnych i zdalnych repozytoriach

Zmiana nazw oddziałów jest prosta

Dzięki Git zmiana nazw gałęzi jest prosta. Jeśli jesteś jedyną osobą, która korzysta z repozytorium lub oddziału wymagającego zmiany nazwy, jest to bardzo proste.

Jeśli inni współużytkują gałąź, upewnij się, że poinformujesz ich, że zamierzasz zmienić nazwę gałęzi i że powinni przeforsować każdą niezatwierdzoną pracę. Kiedy wypchną, możesz wyciągnąć oddział, a następnie zmienić nazwę oddziału lokalnie i zdalnie.

POWIĄZANE: Jak używać git z wieloma zdalnymi repozytoriami