Один из первых вопросов, который возник у меня при изучении Git - как переключиться на более раннюю фиксацию (т. е. старый commit), чтобы вернуть предыдущее состояние рабочего каталога проекта?
1. Сначала командой git log выведите список фиксаций, чтобы узнать их хеши, например:
$ git log --pretty=oneline
1b11970fd272176da7872f5b9f7a6c2b5c95b4be (HEAD -> master, origin/master, origin/HEAD) 220209 рег. громк. Si4735
23cc805326427be3db40bcb5d2829311478d29b1 220201 косметические исправления в команде tp
f2459c4624ef818e06959ba5fe4c15c1e37d35d4 220127 Исправил влево-вправо для курсора
93daeff2400033f00e5adbf04fb68cab27e7f9ff 220123 Добавил кнопки TX и RX
509c2f29d919624d3b333fb819a08d94676652bd 220128 Исправил DEL, добавил индикатор РУС-ENG-dig
6c432e5613e0f099ec575833c5aabbc63e681df6 220115 Исправление режимов под клавиатуру TCA8418
65b292b712292b7ed6e88b7e5e2eadea480a52e9 220111 Исправил ошибку обработки ~INT для TCA8418
9048b714cbd83d3c3edffb5f8890ef9c935ef027 220110 Продолжение работы над TCA8418
2fb1f10e57de7bc3887574212172bb772c0d8f9f 220109 Начало добавления новой клавиатуры на TCA8418
1281f26518378f44ea669a3fd96317a391d7745c 211121 CMSIS в отдельной библиотеке
1f920bb4327e43b58b6b3f735a63a21759dab351 211120 Драйверы HAL в отдельной библиотеке
ab331d95634e248d9bbe4b291614e798c3ccc56d 220128 Исправил маяки и передачу.
7ad03121d46f6ef7c7f992aaff6f033f1d6d3dc8 211119 Исправил перекос в меню настроек
:
Подсказка: двоеточие в конце выведенного лога означает, что его можно либо продолжить клавишей Page Down (лог можно листать вверх/вниз клавишами прокрутки страниц), либо выйти из отображения лога в приглашение команд, если нажать на клавишу q.
2. Выберите тот commit, к которому хотите откатиться. Предположим, это будет фиксация с комментарием "220123 Добавил кнопки TX и RX", у которой хеш 93daeff2400033f00e5adbf04fb68cab27e7f9ff. Чтобы откатиться к этой фиксации, будем использовать команду git checkout, и для этого нам достаточно знать только шесть начальных HEX-символов хеша 93daef:
$ git checkout 93daef
Note: switching to '93daef'.
You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by switching back to a branch.
If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -c with the switch command. Example:
git switch -c < new-branch-name>
Or undo this operation with:
git switch -
Turn off this advice by setting config variable advice.detachedHead to false
HEAD is now at 93daeff 220123 Добавил кнопки TX и RX
microsin@DESKTOP-35RMF7F MINGW64 /d/asm/radiopager ((93daeff...))
Перевод выведенного текста после команды git checkout: "Внимание, произошло переключение на фиксацию '93daef'. Вы находитесь в состоянии 'отключенной головы'. Можно осмотреться, сделать экспериментальные изменения и сделать для них фиксацию (commit), и можно отменить любые фиксации, сделанные в этом состоянии, не оказывая влияния ни на какие ветки репозитория, переключившись обратно на любую ветку. Если нужно создать новую ветку для сохранения созданных фиксаций, то это можно сделать (сейчас или позже) использованием ключа -c командной строки, например git switch -c имяновойветки. Или можно отменить эту операцию командой git switch -. Отменить этот совет можно установкой переменной конфигурации advice.detachedHead в состояние false".
Что произошло? Те файлы в текущем каталоге, которые были сохранены в репозитории на момент фиксации 93daeff, и были изменены фиксациями после 93daeff будут перезаписаны в свое предыдущее состояние, которое было на момент фиксации 93daeff. Все остальные файлы останутся без изменений.
Внимание: когда файлы перезаписываются, у них меняется дата и время файла на текущие дату и время. Это может доставлять неудобство тем, кто привык смотреть на дату и время файла для дополнительной информации об истории его изменения.
Еще одно изменение, которое вносится в файлы при перезаписи. Если в текстовом файле конец строк был оформлен в стиле *nix (одиночным символом перевода строки LF, ASCII-код 0x0A, '\n'), то этот файл будет исправлен таким образом, что все одиночные символы 0x0A будут заменены на пару символов 0x0D 0x0A (окончания строк в стиле Windows, CR LF, '\r' '\n').
3. Вернуться обратно в начало истории фиксаций можно командой git checkout master:
$ git checkout master
Previous HEAD position was 93daeff 220123 Добавил кнопки TX и RX
Switched to a new branch 'master'
Branch 'master' set up to track remote branch 'master' from 'origin'.
microsin@DESKTOP-35RMF7F MINGW64 /d/asm/radiopager (master)
[Как принудительно переключиться на предыдущий commit]
Предположим, что вы сделали несколько изменений в проекте, и не хотите делать фиксацию (commit) этих изменений. И вам нужно переключиться на какую-то предыдущую фиксацию, сбросив все эти изменения. Для этого нужно сначала сбросить все изменения командой git reset --hard, а потом командой git checkout переключиться на нужную фиксацию, указав её контрольную сумму:
$ git reset --hard
$ git checkout 93daeff2400033f00e5adbf04fb68cab27e7f9ff
[git checkout -b имя_ветки]
Важно понимать, что команда git checkout с опцией -b не просто переключается на указанную ветку, она еще и создает эту ветку локально. Так что если на сетевом репозитории уже есть такая ветка, то ваша локальная ветка окажется рассинхронизированной с веткой сетевого репозитория, и последние фиксации, которые есть на сервере вы у себя не увидите. Если у вас на сетевом репозитории ветка уже существует, то не указывайте опцию -b для команды git checkout!
Чтобы засинхронизировать локальный и сетевой репозитории в такой ситуации, используйте команды git branch --set-upstream-to=имя_сетевой_ветки имя_локальной_ветки и git pull. На примере ветки my_branch:
$ git branch --set-upstream-to=origin/my_branch my_branch
$ git pull
Если ветки не синхронизированы, то команда git pull выдаст подсказку, как синхронизировать репозитории:
$ git pull
There is no tracking information for the current branch.
Please specify which branch you want to merge with.
See git-pull(1) for details.
git pull < remote> < branch>
If you wish to set tracking information for this branch you can do so with:
git branch --set-upstream-to=origin/< branch> feature/ROUTER-591.wifi-country-code-ru
[Ссылки]
1. Краткий справочник по Git. 2. Git: как восстановить потерянный commit? 3. Как вернуться (откатиться) к более раннему коммиту? site:stackoverflow.com. |