Перемещение изменений из одной ветви в другую в GIT
В этом примере будут рассмотрены все доступные команды , кроме .
Мы начнем перемещение изменений из одной ветви в другую с ввода в терминале. В выбранном текстовом редакторе отобразятся следующие строки:
pick 1fc6c95 Patch A
pick 6b2481b Patch B
pick dd1475d something I want to split
pick c619268 A fix for Patch B
pick fa39187 something to add to patch A
pick 4ca2acc i cant' typ goods
pick 7b36971 something to move before patch B
В этом примере будут выполнены следующие действия:
- сжатие пятой фиксации () с фиксацией () с помощью команды ;
- перемещение последней фиксации () вверх в положение перед фиксацией () и сохранение ее как ;
- слияние фиксации () с фиксацией () и игнорирование сообщения о фиксации с помощью команды ;
- разделение третьей фиксации () на две фиксации меньшего размера с помощью команды ;
- исправление сообщения о фиксации с орфографической ошибкой () с помощью команды .
Наконец-то. Похоже, предстоит потрудиться, но, действуя последовательно, мы сможем легко внести все эти изменения.
Для начала нам потребуется изменить команды в файле, чтобы они выглядели следующим образом:
pick 1fc6c95 Patch A
squash fa39187 something to add to patch A
pick 7b36971 something to move before patch B
pick 6b2481b Patch B
fixup c619268 A fix for Patch B
edit dd1475d something I want to split
reword 4ca2acc i cant' typ goods
Мы изменили команду в каждой строке на интересующую нас команду.
Теперь сохраните и закройте редактор Будет запущено интерактивной перемещение изменения из одной ветви в другую.
GIT пропускает первую команду перемещения изменений, , так как она не нужна, и переходит к следующей команде: . Так как для этой операции требуются входные данные, GIT снова открывает текстовый редактор. Открываемый файл выглядит примерно так:
# This is a combination of two commits.
# The first commit's message is:
Patch A
# This is the 2nd commit message:
something to add to patch A
# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
# Not currently on any branch.
# Changes to be committed:
# (use "git reset HEAD <file>..." to unstage)
#
# modified: a
#
Посредством этого файла GIT сообщает, что произойдет в результате данной операции . В нем указывается первое сообщение о фиксации () и второе сообщение (). Если эти сообщения о фиксациях вас устраивают, вы можете сохранить файл и закрыть редактор. В противном случае можно изменить сообщение фиксации, просто изменив текст.
После закрытия редактора перемещение изменений из одной ветви в другую продолжается:
pick 1fc6c95 Patch A
squash fa39187 something to add to patch A
pick 7b36971 something to move before patch B
pick 6b2481b Patch B
fixup c619268 A fix for Patch B
edit dd1475d something I want to split
reword 4ca2acc i cant' typ goods
GIT обрабатывает две команды (для и ). Также обрабатывается команда (), так как она не требует взаимодействия. Команда объединяет изменения из с предыдущей фиксацией (). Оба изменения будут иметь одно и то же сообщение о фиксации: .
GIT достигает операции , останавливается и выводит следующее сообщение в терминале:
You can amend the commit now, with
git commit --amend
Once you are satisfied with your changes, run
git rebase --continue
На этом этапе можно внести дополнительные изменения в любой из файлов проекта. Для каждого вносимого изменения необходимо выполнить новую фиксацию, и это можно сделать с помощью команды . Завершив внесение всех изменений, можно выполнить .
После этого GIT переходит к команде . Снова открывается текстовый редактор, и выводятся следующие сведения:
i cant' typ goods
# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
# Not currently on any branch.
# Changes to be committed:
# (use "git reset HEAD^1 <file>..." to unstage)
#
# modified: a
#
Как и ранее, GIT отображает сообщение о фиксации для редактирования. Вы можете изменить текст (), сохранить файл и закрыть редактор. GIT завершит перемещение изменений из одной ветви в другую, и вы вернетесь в терминал.
Отправка переориентированного кода на #REF!
Так как вы изменили журнал GIT, стандартная команда работать не будет. Вам потребуется изменить команду путем принудительной отправки последних изменений:
# Don't override changes
$ git push origin main --force-with-lease
# Override changes
$ git push origin main --force
Предупреждение
Принудительная отправка имеет серьезные последствия, так как она приводит к изменению исторической последовательности фиксаций для ветви. Используйте ее с осторожностью, особенно если к репозиторию имеет доступ множество пользователей.
Дополнительные материалы
- AUTOTITLE