Skip to main content

Enterprise Server 3.20 в настоящее время доступен в качестве кандидата на выпуск.

Перемещений изменений из одной ветви в другую в GIT в командной строке

Вот краткое руководство по использованию в командной строке.

Перемещение изменений из одной ветви в другую в 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